import { Box } from '@mui/material'; import type { FC } from 'react'; import { useRef } from 'react'; import { useChain, useDebouncedWatch, useTokenBalances, useTokenSearch, } from '../../hooks'; import { FormKeyHelper, useFieldValues } from '../../stores'; import type { TokenAmount } from '../../types'; import { TokenNotFound } from './TokenNotFound'; import { VirtualizedTokenList } from './VirtualizedTokenList'; import type { TokenListProps } from './types'; import { useTokenSelect } from './useTokenSelect'; export const TokenList: FC = ({ formType, height, onClick, }) => { const parentRef = useRef(null); const [selectedChainId] = useFieldValues(FormKeyHelper.getChainKey(formType)); const [tokenSearchFilter]: string[] = useDebouncedWatch( 320, 'tokenSearchFilter', ); const { chain, isLoading: isChainLoading } = useChain(selectedChainId); const { tokens: chainTokens, tokensWithBalance, isLoading: isTokensLoading, isBalanceLoading, featuredTokens, } = useTokenBalances(selectedChainId); let filteredTokens = (tokensWithBalance ?? chainTokens ?? []) as TokenAmount[]; const normalizedSearchFilter = tokenSearchFilter?.replaceAll('$', ''); const searchFilter = normalizedSearchFilter?.toUpperCase() ?? ''; filteredTokens = tokenSearchFilter ? filteredTokens.filter( (token) => token.name.toUpperCase().includes(searchFilter) || token.symbol.toUpperCase().includes(searchFilter) || token.address.toUpperCase().includes(searchFilter), ) : filteredTokens; const tokenSearchEnabled = !isTokensLoading && !filteredTokens.length && !!tokenSearchFilter && !!selectedChainId; const { token: searchedToken, isLoading: isSearchedTokenLoading } = useTokenSearch(selectedChainId, normalizedSearchFilter, tokenSearchEnabled); const isLoading = isTokensLoading || isChainLoading || (tokenSearchEnabled && isSearchedTokenLoading); const tokens = filteredTokens.length ? filteredTokens : searchedToken ? [searchedToken] : filteredTokens; const handleTokenClick = useTokenSelect(formType, onClick); return ( {!tokens.length && !isLoading ? ( ) : null} ); };