2023-09-20 09:11:03 +00:00
|
|
|
import { fromNanoSeconds } from '@vegaprotocol/utils';
|
|
|
|
|
|
|
|
import compact from 'lodash/compact';
|
|
|
|
import sortBy from 'lodash/sortBy';
|
|
|
|
import 'pennant/dist/style.css';
|
|
|
|
import { useFundingPeriodsQuery } from '@vegaprotocol/markets';
|
|
|
|
import { LineChart } from 'pennant';
|
|
|
|
import { useMemo } from 'react';
|
|
|
|
import { t } from '@vegaprotocol/i18n';
|
|
|
|
import { useThemeSwitcher } from '@vegaprotocol/react-helpers';
|
|
|
|
import { Splash } from '@vegaprotocol/ui-toolkit';
|
2023-10-20 13:08:19 +00:00
|
|
|
|
|
|
|
const calculateStartDate = (range: string): string | undefined => {
|
|
|
|
const now = new Date();
|
|
|
|
switch (range) {
|
|
|
|
case DateRange.RANGE_1D:
|
|
|
|
return new Date(now.setDate(now.getDate() - 1)).toISOString();
|
|
|
|
case DateRange.RANGE_7D:
|
|
|
|
return new Date(now.setDate(now.getDate() - 7)).toISOString();
|
|
|
|
case DateRange.RANGE_1M:
|
|
|
|
return new Date(now.setMonth(now.getMonth() - 1)).toISOString();
|
|
|
|
case DateRange.RANGE_3M:
|
|
|
|
return new Date(now.setMonth(now.getMonth() - 3)).toISOString();
|
|
|
|
case DateRange.RANGE_1Y:
|
|
|
|
return new Date(now.setFullYear(now.getFullYear() - 1)).toISOString();
|
|
|
|
case DateRange.RANGE_YTD:
|
|
|
|
return new Date(now.setMonth(0)).toISOString();
|
|
|
|
default:
|
|
|
|
return undefined;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const DateRange = {
|
|
|
|
RANGE_1D: '1D',
|
|
|
|
RANGE_7D: '7D',
|
|
|
|
RANGE_1M: '1M',
|
|
|
|
RANGE_3M: '3M',
|
|
|
|
RANGE_1Y: '1Y',
|
|
|
|
RANGE_YTD: 'YTD',
|
|
|
|
RANGE_ALL: 'All',
|
|
|
|
};
|
2023-09-20 09:11:03 +00:00
|
|
|
|
|
|
|
export const FundingContainer = ({ marketId }: { marketId: string }) => {
|
|
|
|
const { theme } = useThemeSwitcher();
|
|
|
|
const variables = useMemo(
|
|
|
|
() => ({
|
|
|
|
marketId: marketId || '',
|
|
|
|
dateRange: { start: calculateStartDate(DateRange.RANGE_7D) },
|
|
|
|
}),
|
|
|
|
[marketId]
|
|
|
|
);
|
|
|
|
const { data } = useFundingPeriodsQuery({
|
|
|
|
variables,
|
|
|
|
skip: !marketId,
|
|
|
|
});
|
|
|
|
const values: { cols: [string, string]; rows: [Date, number][] } | null =
|
|
|
|
useMemo(() => {
|
|
|
|
if (!data?.fundingPeriods.edges.length) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
const rows = compact(data?.fundingPeriods.edges)
|
|
|
|
.filter((edge) => edge.node.endTime)
|
|
|
|
.reduce((acc, edge) => {
|
|
|
|
if (edge.node.endTime) {
|
|
|
|
acc?.push({
|
|
|
|
endTime: fromNanoSeconds(edge.node.endTime),
|
2023-09-22 08:39:56 +00:00
|
|
|
fundingRate: Number(edge.node.fundingRate) * 100,
|
2023-09-20 09:11:03 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
return acc;
|
|
|
|
}, [] as { endTime: Date; fundingRate: number }[]);
|
|
|
|
return {
|
|
|
|
cols: ['Date', t('Funding rate')],
|
|
|
|
rows: sortBy(rows, 'endTime').map((d) => [d.endTime, d.fundingRate]),
|
|
|
|
};
|
|
|
|
}, [data?.fundingPeriods.edges]);
|
|
|
|
if (!data || !values?.rows.length) {
|
|
|
|
return <Splash> {t('No funding history data')}</Splash>;
|
|
|
|
}
|
2023-09-22 08:39:56 +00:00
|
|
|
return (
|
|
|
|
<LineChart
|
|
|
|
data={values}
|
|
|
|
theme={theme}
|
|
|
|
priceFormat={(fundingRate) => `${fundingRate.toFixed(4)}%`}
|
|
|
|
/>
|
|
|
|
);
|
2023-09-20 09:11:03 +00:00
|
|
|
};
|