import { tooltipMapping, useMarket, useStaticMarketData, } from '@vegaprotocol/markets'; import { Header, HeaderStat, HeaderTitle } from '../header'; import { addDecimalsFormatNumber, formatNumberPercentage, } from '@vegaprotocol/utils'; import { t } from '@vegaprotocol/i18n'; import { ExternalLink, Indicator } from '@vegaprotocol/ui-toolkit'; import { DocsLinks } from '@vegaprotocol/environment'; import { NetworkParams, useNetworkParams, } from '@vegaprotocol/network-parameters'; import { useCheckLiquidityStatus } from '@vegaprotocol/liquidity'; import { useParams } from 'react-router-dom'; export const LiquidityHeader = () => { const { marketId } = useParams(); const { data: market } = useMarket(marketId); const { data: marketData } = useStaticMarketData(marketId); const targetStake = marketData?.targetStake; const suppliedStake = marketData?.suppliedStake; const assetDecimalPlaces = market?.tradableInstrument.instrument.product.settlementAsset.decimals || 0; const symbol = market?.tradableInstrument.instrument.product.settlementAsset.symbol; const { params } = useNetworkParams([ NetworkParams.market_liquidity_stakeToCcyVolume, NetworkParams.market_liquidity_targetstake_triggering_ratio, ]); const triggeringRatio = params.market_liquidity_targetstake_triggering_ratio || '1'; const { percentage, status } = useCheckLiquidityStatus({ suppliedStake: suppliedStake || 0, targetStake: targetStake || 0, triggeringRatio, }); return (
{market.tradableInstrument.instrument.code && t( '%s liquidity provision', market.tradableInstrument.instrument.code )} ) } >
{targetStake ? `${addDecimalsFormatNumber( targetStake, assetDecimalPlaces ?? 0 )} ${symbol}` : '-'}
{suppliedStake ? `${addDecimalsFormatNumber( suppliedStake, assetDecimalPlaces ?? 0 )} ${symbol}` : '-'}
{formatNumberPercentage(percentage, 2)}
{marketId}
{DocsLinks ? ( {t('Providing liquidity')} ) : ( (null as React.ReactNode) )}
); };