wagmi
Version:
React Hooks for Ethereum
74 lines (70 loc) • 2.4 kB
text/typescript
'use client'
import type {
Config,
ReadContractErrorType,
ResolvedRegister,
} from '@wagmi/core'
import type { ConfigParameter, UnionCompute } from '@wagmi/core/internal'
import {
type ReadContractData,
type ReadContractOptions,
readContractQueryOptions,
} from '@wagmi/core/query'
import type { Abi, ContractFunctionArgs, ContractFunctionName } from 'viem'
import { type UseQueryReturnType, useQuery } from '../utils/query.js'
import { useChainId } from './useChainId.js'
import { useConfig } from './useConfig.js'
export type UseReadContractParameters<
abi extends Abi | readonly unknown[] = Abi,
functionName extends ContractFunctionName<
abi,
'pure' | 'view'
> = ContractFunctionName<abi, 'pure' | 'view'>,
args extends ContractFunctionArgs<
abi,
'pure' | 'view',
functionName
> = ContractFunctionArgs<abi, 'pure' | 'view', functionName>,
config extends Config = Config,
selectData = ReadContractData<abi, functionName, args>,
> = UnionCompute<
ReadContractOptions<abi, functionName, args, config, selectData> &
ConfigParameter<config>
>
export type UseReadContractReturnType<
abi extends Abi | readonly unknown[] = Abi,
functionName extends ContractFunctionName<
abi,
'pure' | 'view'
> = ContractFunctionName<abi, 'pure' | 'view'>,
args extends ContractFunctionArgs<
abi,
'pure' | 'view',
functionName
> = ContractFunctionArgs<abi, 'pure' | 'view', functionName>,
selectData = ReadContractData<abi, functionName, args>,
> = UseQueryReturnType<selectData, ReadContractErrorType>
/** https://wagmi.sh/react/api/hooks/useReadContract */
export function useReadContract<
const abi extends Abi | readonly unknown[],
functionName extends ContractFunctionName<abi, 'pure' | 'view'>,
const args extends ContractFunctionArgs<abi, 'pure' | 'view', functionName>,
config extends Config = ResolvedRegister['config'],
selectData = ReadContractData<abi, functionName, args>,
>(
parameters: UseReadContractParameters<
abi,
functionName,
args,
config,
selectData
> = {} as any,
): UseReadContractReturnType<abi, functionName, args, selectData> {
const config = useConfig(parameters)
const chainId = useChainId({ config })
const options = readContractQueryOptions(config, {
...(parameters as any),
chainId: parameters.chainId ?? chainId,
})
return useQuery(options) as any
}