UNPKG

@wagmi/vue

Version:

Vue Composables for Ethereum

121 lines (111 loc) 3.44 kB
import { useQueryClient } from '@tanstack/vue-query' import type { Config, GetBlockNumberErrorType, ResolvedRegister, } from '@wagmi/core' import type { Compute, UnionCompute, UnionStrictOmit, } from '@wagmi/core/internal' import { type GetBlockNumberData, type GetBlockNumberOptions, type GetBlockNumberQueryFnData, type GetBlockNumberQueryKey, getBlockNumberQueryOptions, } from '@wagmi/core/query' import { computed } from 'vue' import type { ConfigParameter, QueryParameter } from '../types/properties.js' import type { DeepMaybeRef, DeepUnwrapRef } 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' import { type UseWatchBlockNumberParameters, useWatchBlockNumber, } from './useWatchBlockNumber.js' export type UseBlockNumberParameters< config extends Config = Config, chainId extends config['chains'][number]['id'] = config['chains'][number]['id'], selectData = GetBlockNumberData, > = Compute< DeepMaybeRef< GetBlockNumberOptions<config, chainId> & ConfigParameter<config> & QueryParameter< GetBlockNumberQueryFnData, GetBlockNumberErrorType, selectData, GetBlockNumberQueryKey<config, chainId> > & { watch?: | boolean | UnionCompute< UnionStrictOmit< DeepUnwrapRef<UseWatchBlockNumberParameters<config, chainId>>, 'chainId' | 'config' | 'onBlockNumber' | 'onError' > > | undefined } > > export type UseBlockNumberReturnType<selectData = GetBlockNumberData> = UseQueryReturnType<selectData, GetBlockNumberErrorType> /** https://wagmi.sh/vue/api/composables/useBlockNumber */ export function useBlockNumber< config extends Config = ResolvedRegister['config'], chainId extends config['chains'][number]['id'] = config['chains'][number]['id'], selectData = GetBlockNumberData, >( parameters_: UseBlockNumberParameters<config, chainId, selectData> = {}, ): UseBlockNumberReturnType<selectData> { const parameters = computed(() => deepUnref(parameters_)) const config = useConfig(parameters) const queryClient = useQueryClient() const configChainId = useChainId({ config }) const queryOptions = computed(() => { const { chainId = configChainId.value, query = {}, watch: _, ...rest } = parameters.value const options = getBlockNumberQueryOptions(config, { ...deepUnref(rest), chainId, }) return { ...query, ...options, } }) const watchBlockNumberArgs = computed(() => { const { config, chainId = configChainId.value, query, watch, } = parameters.value return { ...({ config, chainId, ...(typeof watch === 'object' ? watch : {}), } as UseWatchBlockNumberParameters), enabled: (query?.enabled ?? true) && (typeof watch === 'object' ? watch.enabled : watch), onBlockNumber(blockNumber) { queryClient.setQueryData(queryOptions.value.queryKey, blockNumber) }, } satisfies UseWatchBlockNumberParameters }) useWatchBlockNumber(watchBlockNumberArgs) return useQuery(queryOptions as any) as UseBlockNumberReturnType<selectData> }