wagmi
Version:
React Hooks for Ethereum
36 lines (32 loc) • 1.22 kB
text/typescript
'use client'
import type { Config, GetBalanceErrorType, ResolvedRegister } from '@wagmi/core'
import type { Compute, ConfigParameter } from '@wagmi/core/internal'
import {
type GetBalanceData,
type GetBalanceOptions,
getBalanceQueryOptions,
} from '@wagmi/core/query'
import { type UseQueryReturnType, useQuery } from '../utils/query.js'
import { useChainId } from './useChainId.js'
import { useConfig } from './useConfig.js'
export type UseBalanceParameters<
config extends Config = Config,
selectData = GetBalanceData,
> = Compute<GetBalanceOptions<config, selectData> & ConfigParameter<config>>
export type UseBalanceReturnType<selectData = GetBalanceData> =
UseQueryReturnType<selectData, GetBalanceErrorType>
/** https://wagmi.sh/react/api/hooks/useBalance */
export function useBalance<
config extends Config = ResolvedRegister['config'],
selectData = GetBalanceData,
>(
parameters: UseBalanceParameters<config, selectData> = {},
): UseBalanceReturnType<selectData> {
const config = useConfig(parameters)
const chainId = useChainId({ config })
const options = getBalanceQueryOptions(config, {
...parameters,
chainId: parameters.chainId ?? chainId,
})
return useQuery(options)
}