UNPKG

wagmi

Version:

React Hooks for Ethereum

33 lines (26 loc) 893 B
'use client' import { type Config, type GetChainIdReturnType, type ResolvedRegister, getChainId, watchChainId, } from '@wagmi/core' import { useSyncExternalStore } from 'react' import type { ConfigParameter } from '../types/properties.js' import { useConfig } from './useConfig.js' export type UseChainIdParameters<config extends Config = Config> = ConfigParameter<config> export type UseChainIdReturnType<config extends Config = Config> = GetChainIdReturnType<config> /** https://wagmi.sh/react/api/hooks/useChainId */ export function useChainId<config extends Config = ResolvedRegister['config']>( parameters: UseChainIdParameters<config> = {}, ): UseChainIdReturnType<config> { const config = useConfig(parameters) return useSyncExternalStore( (onChange) => watchChainId(config, { onChange }), () => getChainId(config), () => getChainId(config), ) }