wagmi
Version:
React Hooks for Ethereum
59 lines (50 loc) • 1.65 kB
text/typescript
'use client'
import type {
Config,
GetEnsAvatarErrorType,
ResolvedRegister,
} from '@wagmi/core'
import type { Compute } from '@wagmi/core/internal'
import {
type GetEnsAvatarData,
type GetEnsAvatarOptions,
type GetEnsAvatarQueryFnData,
type GetEnsAvatarQueryKey,
getEnsAvatarQueryOptions,
} from '@wagmi/core/query'
import type { ConfigParameter, QueryParameter } from '../types/properties.js'
import { type UseQueryReturnType, useQuery } from '../utils/query.js'
import { useChainId } from './useChainId.js'
import { useConfig } from './useConfig.js'
export type UseEnsAvatarParameters<
config extends Config = Config,
selectData = GetEnsAvatarData,
> = Compute<
GetEnsAvatarOptions<config> &
ConfigParameter<config> &
QueryParameter<
GetEnsAvatarQueryFnData,
GetEnsAvatarErrorType,
selectData,
GetEnsAvatarQueryKey<config>
>
>
export type UseEnsAvatarReturnType<selectData = GetEnsAvatarData> =
UseQueryReturnType<selectData, GetEnsAvatarErrorType>
/** https://wagmi.sh/react/api/hooks/useEnsAvatar */
export function useEnsAvatar<
config extends Config = ResolvedRegister['config'],
selectData = GetEnsAvatarData,
>(
parameters: UseEnsAvatarParameters<config, selectData> = {},
): UseEnsAvatarReturnType<selectData> {
const { name, query = {} } = parameters
const config = useConfig(parameters)
const chainId = useChainId({ config })
const options = getEnsAvatarQueryOptions(config, {
...parameters,
chainId: parameters.chainId ?? chainId,
})
const enabled = Boolean(name && (query.enabled ?? true))
return useQuery({ ...query, ...options, enabled })
}