UNPKG

@lifi/widget

Version:

LI.FI Widget for cross-chain bridging and swapping. It will drive your multi-chain strategy and attract new users from everywhere.

49 lines (45 loc) 1.5 kB
import { type ChainId, type TokensResponse, getToken } from '@lifi/sdk' import { useQuery, useQueryClient } from '@tanstack/react-query' import { useWidgetConfig } from '../providers/WidgetProvider/WidgetProvider.js' import type { TokenAmount } from '../types/token.js' import { getQueryKey } from '../utils/queries.js' export const useTokenSearch = ( chainId?: number, tokenQuery?: string, enabled?: boolean ) => { const queryClient = useQueryClient() const { keyPrefix } = useWidgetConfig() const { data, isLoading } = useQuery({ queryKey: [getQueryKey('token-search', keyPrefix), chainId, tokenQuery], queryFn: async ({ queryKey: [, chainId, tokenQuery], signal }) => { const token = await getToken(chainId as ChainId, tokenQuery as string, { signal, }) if (token) { queryClient.setQueriesData<TokensResponse>( { queryKey: [getQueryKey('tokens', keyPrefix)] }, (data) => { if ( data && !data.tokens[chainId as number]?.some( (t) => t.address === token.address ) ) { const clonedData = { ...data } clonedData.tokens[chainId as number]?.push(token as TokenAmount) return clonedData } } ) } return token as TokenAmount }, enabled: Boolean(chainId && tokenQuery && enabled), retry: false, }) return { token: data, isLoading, } }