import type { Config, GetEnsAvatarErrorType, ResolvedRegister, } from '@wagmi/core' import type { Compute, ConfigParameter } from '@wagmi/core/internal' import { type GetEnsAvatarData, type GetEnsAvatarOptions, getEnsAvatarQueryOptions, } from '@wagmi/core/query' import { computed } from 'vue' import type { DeepMaybeRef } from '../types/ref.js' import { deepUnref } from '../utils/cloneDeep.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< DeepMaybeRef< GetEnsAvatarOptions & ConfigParameter > > export type UseEnsAvatarReturnType = UseQueryReturnType /** https://wagmi.sh/vue/api/composables/useEnsAvatar */ export function useEnsAvatar< config extends Config = ResolvedRegister['config'], selectData = GetEnsAvatarData, >( parameters: UseEnsAvatarParameters = {}, ): UseEnsAvatarReturnType { const params = computed(() => deepUnref(parameters)) const config = useConfig(params) const chainId = useChainId({ config }) const options = computed(() => getEnsAvatarQueryOptions(config as any, { ...params.value, chainId: params.value.chainId ?? chainId.value, }), ) return useQuery(options as any) as any }