Library for embedded React components that enable anyone to send SOL and SPL tokens 🍬
Demo
·
Report Bug
·
Request Feature
This library allows anyone to embed SOL and SPL token transfers into a React project. The goal is to help builders create increasingly richer Solana dApps.
CookieJar makes token transfers super easy with the top level CookieJar
component. You can also customize implementation with individual components that allow users to select tokens from a connected wallet, input a token amount, invoke a wallet signature request to authorize a token transfer, and more!
Some initial use cases include:
- custom application token transfers,
- tipping mechanic for content, or
- payment functionality gating content or dApp functionality
Obviously, this list is very short. I'm sure there will be a plethora of ideas and use cases over time.
Don't get burnt by creating components in your own oven — use CookieJar 🍪
This section covers how you can setup up this project locally. If any steps are missing or you can add additional context, open a pull request with your changes.
You must have npm
or yarn
installed before working with this library locally. Depending on your operating system, there will be different approaches to installing these libraries.
The internet already has copious documentation on this, so I wonn't repeat here. It's just a internet quick search away.
- Clone the repo
git clone https://github.com/jshiohaha/solana-cookie-jar.git
- Navigate to new directory with repository
cd solana-cookie-jar
- Install required packages
yarn
- Build code
yarn build
- Explore other script commands in package.json.
Using the out-of-the-box CookieJar component is easy. It allows the caller to easily
- specify which network the component connects to (e.g. devnet, testnet, or mainnet)
- decide wether or not to show text input to attach a message via the SPL Memo program
- include an input component to control token input amount
- include a token selector based on tokens in a wallet
- send SOL or SPL tokens via invoking signed transactions from the browser
import { ENV } from "@solana/spl-token-registry";
import { PublicKey } from '@solana/web3.js';
import { CookieJar } from "solana-cookie-jar";
// configure as variable, react state, environment variable, etc.
const destinationAddress = somePublicKey;
// create WalletContextState by connecting wallet via @solana/wallet-adapter-react
const walletStore = walletContextStateInstance;
<CookieJar
title="Send Tokens"
actionButtonText="Send"
// optional: default is ENV.MainnetBeta
env={ENV.MainnetBeta}
// @ts-ignore
walletContextState={walletStore}
destinationAddress={destinationAddress}
onError={(err: Error) => console.log('custom error callback function. error: ', err)}
onSubmit={(signature: string | undefined) => console.log('on successful transaction handler: ', signature)}
/>
The sub-components that make up the default CookieJar component are exported from this library. So, you can piece together your own custom CookieJar as you please.
You could also fork this repo and add your own features/updates via a pull request. Or, fork this repo and work on your own independent implemenation, if you please.
If you're going to develop locally, you will need to reference the local component since you will be working with a non-published version. You might run into issues if you do not setup local development correctly. I personally ran into an "invalid hook" issue, which was solved by this StackOverflow post.
- Add base components for genesis version 🥳
- Add a working demo
- [] Add a changelog
- [] Create common package for shared logic/components
- [] Improve documentation 🔁
- [] More to come 🧞
See the open issues for a full list of proposed features (and known issues).
Any contributions to improve and/or extend the library are greatly appreciated 🙂
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement".
Don't forget to give the project a star! Thanks again!
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/NewCookieRecipe
) - Commit your Changes (
git commit -m 'Add some NewCookieRecipe'
) - Push to the Branch (
git push origin feature/NewCookieRecipe
) - Open a Pull Request
Distributed under the MIT License. See LICENSE
for more information.
Jacob Shiohira - @jshiohaha - [email protected]
Project Link: https://github.com/jshiohaha/solana-cookie-jar
I couldn't have done this without the work of many before myself. Below are links to documentation for libraries & tech integral to building this library. There are likely many that I missed, so I hope to keep adding more over time.