UNPKG

wagmi

Version:

React Hooks for Ethereum

98 lines (88 loc) 2.79 kB
'use client' import { useQueryClient } from '@tanstack/react-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 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' 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< GetBlockNumberOptions<config, chainId> & ConfigParameter<config> & QueryParameter< GetBlockNumberQueryFnData, GetBlockNumberErrorType, selectData, GetBlockNumberQueryKey<config, chainId> > & { watch?: | boolean | UnionCompute< UnionStrictOmit< UseWatchBlockNumberParameters<config, chainId>, 'chainId' | 'config' | 'onBlockNumber' | 'onError' > > | undefined } > export type UseBlockNumberReturnType<selectData = GetBlockNumberData> = UseQueryReturnType<selectData, GetBlockNumberErrorType> /** https://wagmi.sh/react/api/hooks/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 { query = {}, watch } = parameters const config = useConfig(parameters) const queryClient = useQueryClient() const configChainId = useChainId({ config }) const chainId = parameters.chainId ?? configChainId const options = getBlockNumberQueryOptions(config, { ...parameters, chainId, }) useWatchBlockNumber({ ...({ config: parameters.config, chainId: parameters.chainId, ...(typeof watch === 'object' ? watch : {}), } as UseWatchBlockNumberParameters), enabled: Boolean( (query.enabled ?? true) && (typeof watch === 'object' ? watch.enabled : watch), ), onBlockNumber(blockNumber) { queryClient.setQueryData(options.queryKey, blockNumber) }, }) return useQuery({ ...query, ...options }) }