wagmi
Version:
React Hooks for Ethereum
66 lines (57 loc) • 1.63 kB
text/typescript
'use client'
import { useMutation } from '@tanstack/react-query'
import type { WatchAssetErrorType } from '@wagmi/core'
import type { Compute } from '@wagmi/core/internal'
import {
type WatchAssetData,
type WatchAssetMutate,
type WatchAssetMutateAsync,
type WatchAssetVariables,
watchAssetMutationOptions,
} from '@wagmi/core/query'
import type { ConfigParameter } from '../types/properties.js'
import type {
UseMutationParameters,
UseMutationReturnType,
} from '../utils/query.js'
import { useConfig } from './useConfig.js'
export type UseWatchAssetParameters<context = unknown> = Compute<
ConfigParameter & {
mutation?:
| UseMutationParameters<
WatchAssetData,
WatchAssetErrorType,
WatchAssetVariables,
context
>
| undefined
}
>
export type UseWatchAssetReturnType<context = unknown> = Compute<
UseMutationReturnType<
WatchAssetData,
WatchAssetErrorType,
WatchAssetVariables,
context
> & {
watchAsset: WatchAssetMutate<context>
watchAssetAsync: WatchAssetMutateAsync<context>
}
>
/** https://wagmi.sh/react/api/hooks/useWatchAsset */
export function useWatchAsset<context = unknown>(
parameters: UseWatchAssetParameters<context> = {},
): UseWatchAssetReturnType<context> {
const { mutation } = parameters
const config = useConfig(parameters)
const mutationOptions = watchAssetMutationOptions(config)
const { mutate, mutateAsync, ...result } = useMutation({
...mutation,
...mutationOptions,
})
return {
...result,
watchAsset: mutate,
watchAssetAsync: mutateAsync,
}
}