2023-07-24 08:37:18 +00:00
|
|
|
import {
|
2023-09-20 09:11:03 +00:00
|
|
|
getAsset,
|
2023-11-17 20:01:18 +00:00
|
|
|
useTooltipMapping,
|
2023-07-24 08:37:18 +00:00
|
|
|
useMarket,
|
|
|
|
useStaticMarketData,
|
|
|
|
} from '@vegaprotocol/markets';
|
|
|
|
import { Header, HeaderStat, HeaderTitle } from '../header';
|
|
|
|
import {
|
|
|
|
addDecimalsFormatNumber,
|
|
|
|
formatNumberPercentage,
|
|
|
|
} from '@vegaprotocol/utils';
|
2023-10-31 01:16:49 +00:00
|
|
|
import {
|
|
|
|
CopyWithTooltip,
|
|
|
|
ExternalLink,
|
|
|
|
Indicator,
|
|
|
|
VegaIcon,
|
|
|
|
VegaIconNames,
|
|
|
|
truncateMiddle,
|
|
|
|
} from '@vegaprotocol/ui-toolkit';
|
2023-07-24 08:37:18 +00:00
|
|
|
import { DocsLinks } from '@vegaprotocol/environment';
|
2023-10-31 01:16:49 +00:00
|
|
|
import {
|
|
|
|
useCheckLiquidityStatus,
|
|
|
|
usePaidFeesQuery,
|
|
|
|
} from '@vegaprotocol/liquidity';
|
2023-07-24 08:37:18 +00:00
|
|
|
import { useParams } from 'react-router-dom';
|
2023-11-16 03:10:39 +00:00
|
|
|
import { useT } from '../../lib/use-t';
|
2023-07-24 08:37:18 +00:00
|
|
|
|
|
|
|
export const LiquidityHeader = () => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-11-17 20:01:18 +00:00
|
|
|
const tooltipMapping = useTooltipMapping();
|
2023-07-24 08:37:18 +00:00
|
|
|
const { marketId } = useParams();
|
|
|
|
const { data: market } = useMarket(marketId);
|
|
|
|
const { data: marketData } = useStaticMarketData(marketId);
|
2023-10-31 01:16:49 +00:00
|
|
|
const { data: feesPaidRes } = usePaidFeesQuery({
|
|
|
|
variables: { marketId: marketId || '' },
|
|
|
|
});
|
2023-07-24 08:37:18 +00:00
|
|
|
const targetStake = marketData?.targetStake;
|
|
|
|
const suppliedStake = marketData?.suppliedStake;
|
2023-09-20 09:11:03 +00:00
|
|
|
|
|
|
|
const asset = market && getAsset(market);
|
|
|
|
|
|
|
|
const assetDecimalPlaces = asset?.decimals || 0;
|
|
|
|
const symbol = asset?.symbol;
|
2023-07-24 08:37:18 +00:00
|
|
|
|
|
|
|
const triggeringRatio =
|
2023-10-02 15:00:55 +00:00
|
|
|
market?.liquidityMonitoringParameters.triggeringRatio || '1';
|
2023-07-24 08:37:18 +00:00
|
|
|
|
|
|
|
const { percentage, status } = useCheckLiquidityStatus({
|
|
|
|
suppliedStake: suppliedStake || 0,
|
|
|
|
targetStake: targetStake || 0,
|
|
|
|
triggeringRatio,
|
|
|
|
});
|
|
|
|
|
2023-10-31 01:16:49 +00:00
|
|
|
const feesObject = feesPaidRes?.paidLiquidityFees?.edges?.find(
|
|
|
|
(e) => e?.node.marketId === marketId
|
|
|
|
);
|
|
|
|
|
2023-07-24 08:37:18 +00:00
|
|
|
return (
|
|
|
|
<Header
|
|
|
|
title={
|
|
|
|
market?.tradableInstrument.instrument.code &&
|
|
|
|
marketId && (
|
|
|
|
<HeaderTitle>
|
|
|
|
{market.tradableInstrument.instrument.code &&
|
2023-11-16 03:10:39 +00:00
|
|
|
t('{{instrumentCode}} liquidity provision', {
|
|
|
|
instrumentCode: market.tradableInstrument.instrument.code,
|
|
|
|
})}
|
2023-07-24 08:37:18 +00:00
|
|
|
</HeaderTitle>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
>
|
|
|
|
<HeaderStat
|
|
|
|
heading={t('Target stake')}
|
|
|
|
description={tooltipMapping['targetStake']}
|
|
|
|
testId="target-stake"
|
|
|
|
>
|
|
|
|
<div>
|
|
|
|
{targetStake
|
|
|
|
? `${addDecimalsFormatNumber(
|
|
|
|
targetStake,
|
|
|
|
assetDecimalPlaces ?? 0
|
|
|
|
)} ${symbol}`
|
|
|
|
: '-'}
|
|
|
|
</div>
|
|
|
|
</HeaderStat>
|
|
|
|
<HeaderStat
|
|
|
|
heading={t('Supplied stake')}
|
|
|
|
description={tooltipMapping['suppliedStake']}
|
|
|
|
testId="supplied-stake"
|
|
|
|
>
|
|
|
|
<div>
|
|
|
|
{suppliedStake
|
|
|
|
? `${addDecimalsFormatNumber(
|
|
|
|
suppliedStake,
|
|
|
|
assetDecimalPlaces ?? 0
|
|
|
|
)} ${symbol}`
|
|
|
|
: '-'}
|
|
|
|
</div>
|
|
|
|
</HeaderStat>
|
|
|
|
<HeaderStat heading={t('Liquidity supplied')} testId="liquidity-supplied">
|
|
|
|
<Indicator variant={status} /> {formatNumberPercentage(percentage, 2)}
|
|
|
|
</HeaderStat>
|
2023-10-31 01:16:49 +00:00
|
|
|
<HeaderStat
|
|
|
|
heading={t('Fees paid')}
|
|
|
|
description={t(
|
2023-11-16 03:10:39 +00:00
|
|
|
'The amount of fees paid to liquidity providers across the whole market during the last epoch {{epoch}}.',
|
|
|
|
{ epoch: feesObject?.node.epoch.toString() || '-' }
|
2023-10-31 01:16:49 +00:00
|
|
|
)}
|
|
|
|
testId="fees-paid"
|
|
|
|
>
|
|
|
|
<div>
|
|
|
|
{feesObject?.node.totalFeesPaid
|
|
|
|
? `${addDecimalsFormatNumber(
|
|
|
|
feesObject?.node.totalFeesPaid,
|
|
|
|
assetDecimalPlaces ?? 0
|
|
|
|
)} ${symbol}`
|
|
|
|
: '-'}
|
|
|
|
</div>
|
2023-07-24 08:37:18 +00:00
|
|
|
</HeaderStat>
|
2023-10-31 01:16:49 +00:00
|
|
|
{marketId && (
|
|
|
|
<HeaderStat heading={t('Market ID')} testId="liquidity-market-id">
|
|
|
|
<div className="break-word">
|
|
|
|
<CopyWithTooltip text={marketId}>
|
|
|
|
<button
|
|
|
|
data-testid="copy-eth-oracle-address"
|
2023-11-17 20:01:18 +00:00
|
|
|
className="text-right uppercase"
|
2023-10-31 01:16:49 +00:00
|
|
|
>
|
|
|
|
<span className="flex gap-1">
|
|
|
|
{truncateMiddle(marketId)}
|
|
|
|
<VegaIcon name={VegaIconNames.COPY} size={16} />
|
|
|
|
</span>
|
|
|
|
</button>
|
|
|
|
</CopyWithTooltip>
|
|
|
|
</div>
|
|
|
|
</HeaderStat>
|
|
|
|
)}
|
2023-07-24 08:37:18 +00:00
|
|
|
<HeaderStat heading={t('Learn more')} testId="liquidity-learn-more">
|
|
|
|
{DocsLinks ? (
|
|
|
|
<ExternalLink href={DocsLinks.LIQUIDITY}>
|
|
|
|
{t('Providing liquidity')}
|
|
|
|
</ExternalLink>
|
|
|
|
) : (
|
|
|
|
(null as React.ReactNode)
|
|
|
|
)}
|
|
|
|
</HeaderStat>
|
|
|
|
</Header>
|
|
|
|
);
|
|
|
|
};
|