wagmi
Version:
React Hooks for Ethereum
33 lines (26 loc) • 916 B
text/typescript
'use client'
import {
type Config,
type GetChainsReturnType,
type ResolvedRegister,
getChains,
} from '@wagmi/core'
import { watchChains } from '@wagmi/core/internal'
import { useSyncExternalStore } from 'react'
import type { ConfigParameter } from '../types/properties.js'
import { useConfig } from './useConfig.js'
export type UseChainsParameters<config extends Config = Config> =
ConfigParameter<config>
export type UseChainsReturnType<config extends Config = Config> =
GetChainsReturnType<config>
/** https://wagmi.sh/react/api/hooks/useChains */
export function useChains<config extends Config = ResolvedRegister['config']>(
parameters: UseChainsParameters<config> = {},
): UseChainsReturnType<config> {
const config = useConfig(parameters)
return useSyncExternalStore(
(onChange) => watchChains(config, { onChange }),
() => getChains(config),
() => getChains(config),
)
}