wagmi
Version:
React Hooks for Ethereum
50 lines (46 loc) • 1.69 kB
text/typescript
'use client'
import type {
Config,
GetTransactionErrorType,
ResolvedRegister,
} from '@wagmi/core'
import type { Compute, ConfigParameter } from '@wagmi/core/internal'
import {
type GetTransactionData,
type GetTransactionOptions,
getTransactionQueryOptions,
} from '@wagmi/core/query'
import { type UseQueryReturnType, useQuery } from '../utils/query.js'
import { useChainId } from './useChainId.js'
import { useConfig } from './useConfig.js'
export type UseTransactionParameters<
config extends Config = Config,
chainId extends
config['chains'][number]['id'] = config['chains'][number]['id'],
selectData = GetTransactionData<config, chainId>,
> = Compute<
GetTransactionOptions<config, chainId, selectData> & ConfigParameter<config>
>
export type UseTransactionReturnType<
config extends Config = Config,
chainId extends
config['chains'][number]['id'] = config['chains'][number]['id'],
selectData = GetTransactionData<config, chainId>,
> = UseQueryReturnType<selectData, GetTransactionErrorType>
/** https://wagmi.sh/react/api/hooks/useTransaction */
export function useTransaction<
config extends Config = ResolvedRegister['config'],
chainId extends
config['chains'][number]['id'] = config['chains'][number]['id'],
selectData = GetTransactionData<config, chainId>,
>(
parameters: UseTransactionParameters<config, chainId, selectData> = {},
): UseTransactionReturnType<config, chainId, selectData> {
const config = useConfig(parameters)
const chainId = useChainId({ config })
const options = getTransactionQueryOptions(config, {
...parameters,
chainId: parameters.chainId ?? chainId,
})
return useQuery(options) as any
}