Use Framework Kit
Framework Kit is a React library that simplifies Solana dapp development. It handles RPC connections, wallet adapters, and state management, so you can interact with Solana using React hooks.
Framework Kit supports MetaMask out-of-the-box. This guide walks you through setting it up.
Prerequisites
- Node.js version 19 or later
- A package manager such as npm, Yarn, pnpm, or bun
- A React or Next.js project
Steps
1. Install dependencies
Install Framework Kit's Solana client and React hooks:
npm install @solana/client @solana/react-hooks
2. Create the Solana provider
Create a SolanaProviderWrapper component that initializes the Solana client with MetaMask support:
components/SolanaProvider.tsx
'use client';
import { createClient, metamask } from "@solana/client";
import { SolanaProvider } from "@solana/react-hooks";
import { FC, ReactNode } from 'react';
// Create a client pointing to Solana devnet
const client = createClient({
endpoint: "https://solana-devnet.infura.io/v3/YOUR_INFURA_API_KEY",
walletConnectors: [...metamask()],
});
interface SolanaProviderWrapperProps {
children: ReactNode;
}
export const SolanaProviderWrapper: FC<SolanaProviderWrapperProps> = ({ children }) => {
return (
<SolanaProvider client={client}>
{children}
</SolanaProvider>
);
};
3. Add the provider to your root layout
Wrap your application with SolanaProviderWrapper so all components can access Solana hooks:
import './globals.css';
import { SolanaProviderWrapper } from '@/components/SolanaProvider';
export default function RootLayout({
children
}: Readonly<{
children: React.ReactNode;
}>) {
return (
<html>
<body>
<SolanaProviderWrapper>{children}</SolanaProviderWrapper>
</body>
</html>
);
}
4. Connect to MetaMask
Use the useWalletConnection hook in any component to connect to the user's wallet:
import { useWalletConnection } from "@solana/react-hooks";
export const ConnectWallet = () => {
const { wallet, connect, disconnect } = useWalletConnection();
if (wallet) {
return (
<div>
<p>Connected: {wallet.accounts[0].address}</p>
<button onClick={disconnect}>Disconnect</button>
</div>
);
}
return <button onClick={() => connect("metamask")}>Connect MetaMask</button>;
};
Next steps
See how to send a legacy transaction and a versioned transaction.