React components and TypeScript utilities to help you build top-tier onchain apps.
For documentation and guides, visit onchainkit.xyz.
To integrate OnchainKit into your project, begin by installing the necessary packages.
# Yarn: Add library
yarn add @coinbase/onchainkit
# or
# Use NPM
npm install @coinbase/onchainkit
# Use PNPM
pnpm add @coinbase/onchainkit
# Use BUN
bun add @coinbase/onchainkit
Add this at the top of your application entry point
import "@coinbase/onchainkit/styles.css";
For tailwindcss users, use this Tailwindcss Integration Guide.
const EAS_SCHEMA_ID = '0xf8b05c79f090979bf4a80270aba232dff11a10d9ca55c4f88de95317970f0de9';
const ACCOUNT_ADDRESS = '0x838aD0EAE54F99F1926dA7C3b6bFbF617389B4D9';
<OnchainKitProvider chain={base} schemaId={EAS_SCHEMA_ID}>
<Identity>
<Avatar />
<Badge />
</Avatar>
<Name />
<Address />
<Identity>
</OnchainKitProvider>;
data:image/s3,"s3://crabby-images/f07ff/f07ff671f5fcde9627c9300452788bff61837e3b" alt="OnchainKit Identity components"
Convert your web page into a Frame
import { FrameMetadata } from '@coinbase/onchainkit/frame';
export default function HomePage() {
return (
...
<FrameMetadata
buttons={[
{
label: 'Tell me the story',
},
{
action: 'link',
label: 'Link to Google',
target: 'https://www.google.com'
},
{
action: 'post_redirect',
label: 'Redirect to cute pictures',
},
]}
image={{
src: 'https://zizzamia.xyz/park-3.png',
aspectRatio: '1:1'
}}
input={{
text: 'Tell me a boat story',
}}
postUrl="https://zizzamia.xyz/api/frame"
/>
...
);
}
Create or connect your wallet with Connect Account, powered by Smart Wallet.
<div className="flex flex-grow">
{(() => {
if (status === "disconnected") {
return <ConnectAccount />; // [!code focus]
}
return (
<div className="flex h-8 w-8 items-center justify-center">
<button type="button" onClick={() => disconnect()}>
<Avatar address={address} />
</button>
</div>
);
})()}
</div>
data:image/s3,"s3://crabby-images/2413a/2413a7d12a8f888a97b66564641ba444ed1bef77" alt="OnchainKit Wallet components"
data:image/s3,"s3://crabby-images/c53e1/c53e1eccb2cadf99dfbfc7fbb899c61a16d553c7" alt="OnchainKit Wallet components"
Search Tokens using getTokens and display them with TokenSearch, TokenChip, TokenImage and TokenRow
const [filteredTokens, setFilteredTokens] = useState<Token[]>([]);
const handleChange = useCallback((value) => {
async function getData(value) {
const tokens: Token[] = await getTokens({ search: value }); // [!code focus]
setFilteredTokens(filteredTokens);
}
getData(value);
}, []);
...
<div className="flex flex-col gap-4 rounded-3xl bg-white p-4">
<TokenSearch onChange={handleChange} delayMs={200} /> // [!code focus]
{filteredTokens.length > 0 && (
<div className="flex gap-2">
{filteredTokens.map((token) => (
<TokenChip key={token.name} token={token} onClick={handleSelect} /> // [!code focus]
))}
</div>
)}
{filteredTokens.length > 0 ? (
<div>
<div className="text-body text-black">Tokens</div>
<div>
{filteredTokens.map((token) => (
<TokenRow key={token.name} token={token} onClick={handleSelect} /> // [!code focus]
))}
</div>
</div>
) : (
<div className="text-body text-black">No tokens found</div>
)}
</div>
data:image/s3,"s3://crabby-images/fd765/fd76540821f30079d3b976b39d290bc355bbb2f0" alt="OnchainKit Wallet components"
If you're seeking basic TypeScript utilities, we have plenty of ready-to-use options available.
All our component designs are open-sourced. You can access the Figma file to use them for your onchain project.
Figma - How to use
data:image/s3,"s3://crabby-images/5a1a1/5a1a126ee59391218aab3b672fe3573d907658b8" alt="OnchainKit logo vibes"
Figma - Components
data:image/s3,"s3://crabby-images/421d5/421d577d519dfd6cd5e95f50191205047bfd7c8c" alt="OnchainKit logo vibes"
Check out the following places for more OnchainKit-related content:
- Follow @onchainkit or @zizzamia (X, Warpcast) for project updates
- Join the discussions on our OnchainKit warpcast channel
- @zizzamia (X, Warpcast)
- @0xchiaroscuro (X, Warpcast)
- Ky Lee
- Tina He (X)
- Mind Apivessa (X)
- Alec Chen (X)
- Alissa Crane (X)
- Paul Cramer (X)
This project is licensed under the MIT License - see the LICENSE.md file for details