@openocean.finance/widget
Version:
Openocean Widget for cross-chain bridging and swapping. It will drive your multi-chain strategy and attract new users from everywhere.
57 lines (50 loc) • 1.55 kB
text/typescript
import {
ChainId,
getGasRecommendation,
} from '@openocean.finance/widget-sdk'
import { useQuery } from '@tanstack/react-query'
import { useAvailableChains } from './useAvailableChains.js'
const refetchInterval = 60_000
export const useGasRecommendation = (
toChainId?: ChainId,
fromChain?: ChainId,
fromToken?: string
) => {
const { chains } = useAvailableChains()
const fromIsNear = fromChain === ChainId.NEAR
const checkRecommendationLiFuel =
Boolean(toChainId) &&
Boolean(fromChain) &&
!fromIsNear &&
Boolean(fromToken) &&
Boolean(chains?.length)
const checkRecommendationMaxButton =
Boolean(toChainId) && !fromChain && !fromToken && Boolean(chains?.length)
return useQuery({
queryKey: ['gas-recommendation', toChainId, fromChain, fromToken],
queryFn: async ({
queryKey: [_, toChainId, fromChain, fromToken],
signal,
}) => {
// from 是 Near 链时,当前不支持 Li.Fuel / gas 预估,直接跳过查询
if (fromChain === ChainId.NEAR) {
return null
}
if (!chains?.some((chain) => chain.id === toChainId)) {
return null
}
const gasRecommendation = await getGasRecommendation(
{
chainId: toChainId as ChainId,
fromChain: fromChain as ChainId,
fromToken: fromToken as string,
},
{ signal }
)
return gasRecommendation
},
enabled: checkRecommendationLiFuel || checkRecommendationMaxButton,
refetchInterval,
staleTime: refetchInterval,
})
}