Getting Started
To get started, install the package into your project.
- npm
- yarn
- pnpm
npm i @thirdweb-dev/wallets
yarn add @thirdweb-dev/wallets
pnpm add @thirdweb-dev/wallets
Now you’re ready to use any of our supported wallets, prompt the user to connect with the wallet, access information such as the signer and wallet address, and more.
// 1. Import the wallet you want to use from the package
import { CoinbaseWallet } from "@thirdweb-dev/wallets";
// 2. Instantiate the wallet class
const coinbaseWallet = new CoinbaseWallet();
// 3. Connect to the wallet (prompts the user when required)
const walletAddress = await coinbaseWallet.connect();
// 4. Use the connected wallet to access information such as the signer
const signer = await coinbaseWallet.getSigner();
Methods available on wallet instance
All wallets in wallet SDK extend from the AbstractWallet base class, and all client-side wallets (web, mobile) extend from AbstractClientWallet base class. Each wallet may have its own unique methods. Below are the common methods shared by all wallets
getAddress
Get the address of the currently connected wallet
const address = await wallet.getAddress();
getChainId
Get the chain ID of the network the wallet is currently connected to
const chainId = await wallet.getChainId();
getSigner
Get the signer for the currently connected wallet.
const signer = await wallet.getSigner();
signMessage
Sign a message with the currently connected wallet. This function must be implemented by the parent class.
const signature = await wallet.signMessage("Hello world!");
verifySignature
Verify if a signature is valid or not
const isValid = await wallet.verifySignature(
"Message",
"Signature",
"wallet_address",
);
transfer
Transfer native or ERC20 tokens from this wallet to another wallet
// for native tokens
const txResult = await wallet.transfer(recipientAddress, amount);
// for ERC20 tokens
const txResult = await wallet.transfer(recipientAddress, amount, tokenAddress);
recipientAddress
Address of the recipient to send the tokens to
string
amount
Amount of tokens to send
string | number
Return Value
Promise<TransactionResult>
getBalance
Get the the native token balance or ERC20 token balance of the wallet.
// for native token balance
const balance = await wallet.getBalance();
// for ERC20 token balance
const balance = await wallet.getBalance(tokenAddress);
tokenAddress
Address of the ERC20 token. If no address is provided, the native token balance is returned.
Return Value
Promise<{
symbol: string;
value: BigNumber;
name: string;
decimals: number;
displayValue: string;
}>;