@wagmi/vue
Version:
Vue Composables for Ethereum
64 lines (55 loc) • 1.8 kB
text/typescript
import {
type Config,
type ResolvedRegister,
type WatchBlockNumberParameters,
watchBlockNumber,
} from '@wagmi/core'
import type { UnionCompute, UnionExactPartial } from '@wagmi/core/internal'
import { computed, watchEffect } from 'vue'
import type { ConfigParameter, EnabledParameter } from '../types/properties.js'
import type { DeepMaybeRef } from '../types/ref.js'
import { deepUnref } from '../utils/cloneDeep.js'
import { useChainId } from './useChainId.js'
import { useConfig } from './useConfig.js'
export type UseWatchBlockNumberParameters<
config extends Config = Config,
chainId extends
config['chains'][number]['id'] = config['chains'][number]['id'],
> = DeepMaybeRef<
UnionCompute<
UnionExactPartial<WatchBlockNumberParameters<config, chainId>> &
ConfigParameter<config> &
EnabledParameter
>
>
export type UseWatchBlockNumberReturnType = void
/** https://wagmi.sh/vue/api/composables/useWatchBlockNumber */
export function useWatchBlockNumber<
config extends Config = ResolvedRegister['config'],
chainId extends
config['chains'][number]['id'] = config['chains'][number]['id'],
>(
parameters_: UseWatchBlockNumberParameters<config, chainId> = {} as any,
): UseWatchBlockNumberReturnType {
const parameters = computed(() => deepUnref(parameters_))
const config = useConfig(parameters)
const configChainId = useChainId({ config })
watchEffect((onCleanup) => {
const {
chainId = configChainId.value,
enabled = true,
onBlockNumber,
config: _,
...rest
} = parameters.value
if (!enabled) return
if (!onBlockNumber) return
const unwatch = watchBlockNumber(config, {
...(rest as any),
chainId,
onBlockNumber,
emitOnBegin: true,
})
onCleanup(unwatch)
})
}