Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
@web3modal/react
Advanced tools
Make sure to read our main readme first to find out details about projectId, chain specific packages and modal customisation options. Please ensure you are updated to the latest React / Next.js or similar version, as web3modal libraries target es2020
. Web3Modal hooks are based on wagmi, so it is good idea to read through their documentation as well. Do note, you have to import and use these hooks from @web3modal
packages.
npm install @web3modal/react @web3modal/ethereum ethers
See @web3modal/ethereum readme for all available ethereum
options. NextJS example is also available in examples/react folder.
import type { ConfigOptions } from '@web3modal/react'
import { Web3Modal } from '@web3modal/react'
const config: ConfigOptions = {
projectId: '<YOUR_PROJECT_ID>',
theme: 'dark',
accentColor: 'default',
ethereum: {
appName: 'web3Modal'
}
}
export default function App() {
return (
<>
<YourAppContent />
<Web3Modal config={config} />
</>
)
}
import { ConnectButton, useConnectModal } from '@web3modal/react'
export default function YourAppContent() {
const { isOpen, open, close } = use
return (
<>
<ConnectButton />
{/* or */}
<button onClick={open}>Open Modal</button>
</>
)
}
Hooks to manage web3modal.
Hook to check state of the modal, open or close it.
import { useConnectModal } from '@web3modal/ethereum'
// Usage
const { isOpen, open, close } = useConnectModal()
// Returns
interface Return {
isOpen: boolean
open: () => void
close: () => void
}
Hooks that return blockchain, account or network data. By default these automatically retrieve data for currently active network (chainId) one time when they are mounted. You can tweak this behaviour with following shared options (where available).
interface Options {
// Specify concrete chainId for which to retrieve data, defaults to currently selected chain id
chainId?: number
// Specify whether hook should retrieve data when mounted or not, defaults to true
enabled?: boolean
// Specify whether hook should continuously watch for new data (every block). This uses websocket if available or falls back to pooling, default false
watch?: boolean
}
Hook to get account data.
import { useAccount } from '@web3modal/ethereum'
// Usage
const { address, isConnected } = useAccount()
// Returns
interface Return {
address?: string
connector?: Connector
isConnecting?: boolean
isReconnecting?: boolean
isConnected?: boolean
isDisconnected?: boolean
status?: 'connecting' | 'reconnecting' | 'connected' | 'disconnected'
}
Hook for fetching balance information for Ethereum or ERC-20 tokens.
import { useBalance } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useBalance({ formatUnits: 'ether' })
// Returns
interface Return {
data?: {
decimals: number
formatted: string
symbol: string
value: BigNumber
}
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
watch?: boolean
enabled?: boolean
addressOrName: string
chainId?: number
formatUnits?: number | 'wei' | 'kwei' | 'mwei' | 'gwei' | 'szabo' | 'finney' | 'ether'
token?: string
}
Hook for fetching the current block number.
import { useBlockNumber } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useBlockNumber({ watch: true })
// Returns
interface Return {
data?: number
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
watch?: boolean
enabled?: boolean
chainId?: number
}
Hook for declaratively creating an ethers Contract instance.
import { useContract } from '@web3modal/ethereum'
import ensRegistryABI from './yourAbi/ensRegistryABI.json'
// Usage
const contract = useContract({
addressOrName: '0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e',
contractInterface: ensRegistryABI
})
// Returns
ethers.Contract | undefined
// Options
interface Options {
addressOrName: string
contractInterface: ContractInterface
signerOrProvider?: Provider | Signer
}
Hook for subscribing to ethers Contract events.
import { useContractEvent } from '@web3modal/ethereum'
import ensRegistryABI from './yourAbi/ensRegistryABI.json'
// Usage
useContractEvent({
addressOrName: '0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e',
contractInterface: ensRegistryABI,
eventName: 'NewOwner',
listener: event => console.log(event)
})
// Options
interface Options {
addressOrName: string
contractInterface: ContractInterface
eventName: string
listener: (event?: any) => void
chainId? number
once?: boolean
}
Hook for calling an ethers Contract read-only method.
import { useContractRead } from '@web3modal/ethereum'
import wagmigotchiABI from './yourAbi/wagmigotchiABI.json'
// Usage
const { data, error, isLoading, refetch } = useContractRead({
addressOrName: '0xecb504d39723b0be0e3a9aa33d646642d1051ee1',
contractInterface: wagmigotchiABI,
functionName: 'getHunger'
})
// Returns
interface Return {
data?: Result
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
addressOrName: string
contractInterface: ContractInterface
functionName: string
args?: any
overrides?: CallOverrides
chainId?: number
enabled?: boolean
watch?: boolean
}
Hook for fetching address for ENS name.
import { useEnsAddress } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useEnsAddress({
name: 'vitalik.eth'
})
// Returns
interface Return {
data?: string
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
name: string
chainId?: number
enabled?: boolean
}
Hook for fetching avatar for ENS name.
import { useEnsAvatar } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useEnsAvatar({
addressOrName: 'vitalik.eth'
})
// Returns
interface Return {
data?: string
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
addressOrName: string
chainId?: number
enabled?: boolean
}
Hook for fetching ENS name for address.
import { useEnsName } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useEnsName({
address: '0xd8da6bf26964af9d7eed9e03e53415d37aa96045'
})
// Returns
interface Return {
data?: string
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
address: string
chainId?: number
enabled?: boolean
}
Hook for fetching the resolver for ENS name.
import { useEnsResolver } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useEnsResolver({
name: 'vitalik.eth'
})
// Returns
interface Return {
data?: string
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
name: string
chainId?: number
enabled?: boolean
}
Hook for fetching network fee information.
import { useFeeData } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useFeeData({
name: 'vitalik.eth'
})
// Returns
interface Return {
data?: {
gasPrice: BigNumber
maxFeePerGas: BigNumber
maxPriorityFeePerGas: BigNumber
formatted: {
gasPrice: string
maxFeePerGas: string
maxPriorityFeePerGas: string
}
}
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
formatUnits?: number | 'wei' | 'kwei' | 'mwei' | 'gwei' | 'szabo' | 'finney' | 'ether'
chainId?: number
watch?: boolean
enabled?: boolean
}
Hook for accessing network data, such as current connected chain and connector chains.
import { useNetwork } from '@web3modal/ethereum'
// Usage
const { chain, chains } = useNetwork()
// Returns
interface Return {
chain?: Chain & { unsupported?: boolean }
chains?: Chain[]
}
Hook for accessing Client's ethers Provider.
import { useProvider } from '@web3modal/ethereum'
// Usage
const provider = useProvider()
// Returns
ethers.Provider?
Hook for accessing the Client's ethers WebSocket Provider.
import { useWebsocketProvider } from '@web3modal/ethereum'
// Usage
const websocketProvider = useWebsocketProvider()
// Returns
ethers.WebSocketProvider?
Hook for accessing ethers Signer object for connected account.
import { useSigner } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading } = useSigner()
// Returns
interface Return {
data?: ethers.providers.JsonRpcSigner
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
chainId?: number
}
Hook for fetching ERC-20 token information.
import { useToken } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useToken({
address: '0xc18360217d8f7ab5e7c516566761ea12ce7f9d72'
})
// Returns
interface Return {
data?: {
address: string
decimals: number
name: string
symbol: string
totalSupply: {
formatted: string
value: BigNumber
}
}
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
address: string
chainId?: number
enabled?: boolean
formatUnits?: number | 'wei' | 'kwei' | 'mwei' | 'gwei' | 'szabo' | 'finney' | 'ether'
}
Hook for fetching transaction by hash.
import { useTransaction } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useTransaction({
hash: '0xe75fb554e433e03763a1560646ee22dcb74e5274b34c5ad644e7c0f619a7e1d0'
})
// Returns
interface Return {
data?: TransactionResponse
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
hash: string
chainId?: number
enabled?: boolean
}
Hook for declaratively waiting until transaction is processed. Pairs well with useContractWrite
and useSendTransaction
.
import { useWaitForTransaction } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, refetch } = useWaitForTransaction({
hash: '0xe75fb554e433e03763a1560646ee22dcb74e5274b34c5ad644e7c0f619a7e1d0'
})
// Returns
interface Return {
data?: TransactionResponse
error?: Error
isLoading: boolean
refetch: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
confirmations?: number
hash?: string
timeout?: number
chainId?: number
enabled?: boolean
}
Hooks that expose action / write opperations.
Hook for calling an ethers Contract write method. Perpares transaction under the hood i.e. estimates gas price.
import { useContractWrite } from '@web3modal/ethereum'
import wagmigotchiABI from './yourAbi/wagmigotchiABI.json'
// Usage
const { data, error, isLoading, write } = useContractWrite({
addressOrName: '0xecb504d39723b0be0e3a9aa33d646642d1051ee1',
contractInterface: wagmigotchiABI,
functionName: 'feed'
})
write()
// Returns
interface Return {
data?: TransactionResponse
error?: Error
isLoading: boolean
write: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
functionName: string
chainId?: number | undefined
args?: any
overrides?: CallOverrides
signer?: Signer
}
Hook for disconnecting the connected account.
import { useDisconnect } from '@web3modal/ethereum'
// Usage
const disconnect = useDisconnect()
disconnect()
// Returns
() => void
Hook for sending a transaction. Perpares transaction under the hood i.e. estimates gas price.
import { useSendTransaction } from '@web3modal/ethereum'
import { BigNumber } from 'ethers'
// Usage
const { data, error, isLoading, sendTransaction } = useSendTransaction({
request: {
to: 'vitalik.eth',
value: BigNumber.from('10000000000000000')
}
})
sendTransaction()
// Returns
interface Return {
data?: TransactionResponse
error?: Error
isLoading: boolean
sendTransaction: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
request: TransactionRequest & {
to: string
}
chainId?: number
signer?: Signer
}
Hook for signing messages with connected account.
import { useSignMessage } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, signMessage } = useSendTransaction({
message: 'WalletConnect web3modal message'
})
signMessage()
// Returns
interface Return {
data?: string
error?: Error
isLoading: boolean
signMessage: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
message: string | Bytes
}
Hook for signing messages with connected account.
import { useSignTypedData } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, signTypedData } = useSignTypedData({
domain,
types,
value
})
signTypedData()
// Returns
interface Return {
data?: string
error?: Error
isLoading: boolean
signTypedData: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
domain: {
name?: string
version?: string
chainId?: string | number | bigint
verifyingContract?: string
salt?: BytesLike
}
types: Record<
string,
Array<{
name: string
type: string
}>
>
value: Record<string, any>
}
Hook for switching networks with a connector.
import { useSwitchNetwork } from '@web3modal/ethereum'
// Usage
const { data, error, isLoading, switchNetwork } = useSwitchNetwork({
chainId: 1
})
switchNetwork()
// Returns
interface Return {
data?: Chain
error?: Error
isLoading: boolean
switchNetwork: (options?: Options) => Promise<Return['data']>
}
// Options
interface Options {
chainId?: number
}
FAQs
#### 🔎 [Examples](https://github.com/WalletConnect/web3modal-examples)
The npm package @web3modal/react receives a total of 2,377 weekly downloads. As such, @web3modal/react popularity was classified as popular.
We found that @web3modal/react demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.