import Change from '@components/shared/Change' import DailyRange from '@components/shared/DailyRange' import { useTranslation } from 'next-i18next' import Image from 'next/legacy/image' import { useRouter } from 'next/router' import { useMemo, useState } from 'react' import FlipNumbers from 'react-flip-numbers' import { formatCurrencyValue } from 'utils/numbers' import Link from 'next/link' import SheenLoader from '@components/shared/SheenLoader' import Tooltip from '@components/shared/Tooltip' import useMangoGroup from 'hooks/useMangoGroup' import useJupiterMints from 'hooks/useJupiterMints' import useLocalStorageState from 'hooks/useLocalStorageState' import { ANIMATION_SETTINGS_KEY } from 'utils/constants' import { INITIAL_ANIMATION_SETTINGS } from '@components/settings/AnimationSettings' import ActionPanel from './ActionPanel' import ChartTabs from './ChartTabs' import CoingeckoStats from './CoingeckoStats' import { useQuery } from '@tanstack/react-query' import FormatNumericValue from '@components/shared/FormatNumericValue' import TopTokenAccounts from './TopTokenAccounts' import TokenParams from './TokenParams' import { formatTokenSymbol } from 'utils/tokens' const DEFAULT_COINGECKO_VALUES = { ath: 0, atl: 0, ath_change_percentage: 0, atl_change_percentage: 0, ath_date: 0, atl_date: 0, high_24h: { usd: 0 }, circulating_supply: 0, fully_diluted_valuation: 0, low_24h: { usd: 0 }, market_cap: 0, max_supply: 0, price_change_percentage_24h: 0, total_supply: 0, total_volume: 0, } type CryptoStatsResponse = { high_24h: Record low_24h: Record price_change_percentage_24h: number } export type CoingeckoDataType = { market_data: CryptoStatsResponse name: string } const fetchTokenInfo = async (tokenId: string | undefined) => { if (!tokenId) return const response = await fetch( `https://api.coingecko.com/api/v3/coins/${tokenId}?localization=false&tickers=false&developer_data=false&sparkline=false&community_data=false `, ) const data = await response.json() return data } const TokenPage = () => { const { t } = useTranslation(['common', 'token']) const [loading, setLoading] = useState(true) const router = useRouter() const { token } = router.query const { group } = useMangoGroup() const { mangoTokens } = useJupiterMints() const [animationSettings] = useLocalStorageState( ANIMATION_SETTINGS_KEY, INITIAL_ANIMATION_SETTINGS, ) const bankName = useMemo(() => { if (!token) return return token === 'wBTC' ? 'wBTC (Portal)' : token === 'ETH' ? 'ETH (Portal)' : token.toString() }, [token]) const bank = useMemo(() => { if (group && bankName) { const bank = group.banksMapByName.get(bankName) if (bank) { return bank[0] } else { setLoading(false) } } }, [group, bankName]) const logoURI = useMemo(() => { if (bank && mangoTokens.length) { return mangoTokens.find((t) => t.address === bank.mint.toString()) ?.logoURI } }, [bank, mangoTokens]) const coingeckoId = useMemo(() => { if (bank && mangoTokens.length) { return mangoTokens.find((t) => t.address === bank.mint.toString()) ?.extensions?.coingeckoId } }, [bank, mangoTokens]) const { data: coingeckoTokenInfo, isLoading: loadingCoingeckoInfo } = useQuery( ['coingecko-token-info', coingeckoId], () => fetchTokenInfo(coingeckoId), { cacheTime: 1000 * 60 * 15, staleTime: 1000 * 60 * 5, retry: 3, refetchOnWindowFocus: false, enabled: !!coingeckoId, }, ) const { high_24h, low_24h, price_change_percentage_24h } = coingeckoTokenInfo?.market_data ? coingeckoTokenInfo.market_data : DEFAULT_COINGECKO_VALUES return ( <> {bank && bankName ? ( <>
{coingeckoTokenInfo ? (

{coingeckoTokenInfo.name}{' '} {formatTokenSymbol(bank.name)}

) : (

{bank.name}

)}
{animationSettings['number-scroll'] ? ( ) : ( )}
{coingeckoTokenInfo?.market_data ? (
) : null}
{high_24h.usd && low_24h.usd ? ( ) : null}

{t('utilization')}:

{bank.uiDeposits() > 0 ? ( ) : ( '0.0' )} %
{coingeckoTokenInfo?.market_data ? ( ) : loadingCoingeckoInfo && coingeckoId ? (
) : (
🦎

No CoinGecko data...

)} ) : loading ? (
) : (

😔

{t('token:token-not-found')}

{t('token:token-not-found-desc', { token: token })}

{t('token:go-to-account')}
)} ) } export default TokenPage