diff --git a/centrifuge-app/src/components/Charts/PriceChart.tsx b/centrifuge-app/src/components/Charts/PriceChart.tsx index 65b1d10513..1ccf0a62d7 100644 --- a/centrifuge-app/src/components/Charts/PriceChart.tsx +++ b/centrifuge-app/src/components/Charts/PriceChart.tsx @@ -8,13 +8,14 @@ import { CustomizedTooltip } from './Tooltip' export type FilterOptions = 'YTD' | '30days' | '90days' type PriceChartProps = { - data: { day: Date; price: number }[] + data: { day: Date; price: number; apy: number }[] currency: string filter?: FilterOptions setFilter?: React.Dispatch> + isPrice: boolean } -export const PriceChart = ({ data, currency, filter, setFilter }: PriceChartProps) => { +export const PriceChart = ({ data, currency, filter, setFilter, isPrice }: PriceChartProps) => { const theme = useTheme() const currentPrice = data.at(-1)?.price @@ -84,26 +85,40 @@ export const PriceChart = ({ data, currency, filter, setFilter }: PriceChartProp tickLine={false} allowDuplicatedCategory={false} /> - { - return tick.toFixed(6) - }} - domain={['dataMin - 0.001', 'dataMax + 0.001']} - interval="preserveStartEnd" - /> + {isPrice ? ( + { + return tick.toFixed(6) + }} + domain={['dataMin - 0.001', 'dataMax + 0.001']} + interval="preserveStartEnd" + /> + ) : ( + { + return tick.toFixed(6) + }} + domain={['dataMin - 0.001', 'dataMax + 0.001']} + interval="preserveStartEnd" + /> + )} } /> diff --git a/centrifuge-app/src/components/InvestRedeem/InvestRedeemDrawer.tsx b/centrifuge-app/src/components/InvestRedeem/InvestRedeemDrawer.tsx index 6711df0f07..18e5828ee1 100644 --- a/centrifuge-app/src/components/InvestRedeem/InvestRedeemDrawer.tsx +++ b/centrifuge-app/src/components/InvestRedeem/InvestRedeemDrawer.tsx @@ -1,4 +1,5 @@ -import { Drawer, Stack, Text } from '@centrifuge/fabric' +import { Perquintill } from '@centrifuge/centrifuge-js' +import { Box, Drawer, Stack, Tabs, TabsItem, Text } from '@centrifuge/fabric' import Decimal from 'decimal.js-light' import * as React from 'react' import { useDailyPoolStates, usePool } from '../../utils/usePools' @@ -13,6 +14,7 @@ type TrancheState = { type DailyPoolStateProps = { timestamp: string tranches: { [trancheId: string]: TrancheState } + apy?: Perquintill | undefined } export function InvestRedeemDrawer({ @@ -29,6 +31,7 @@ export function InvestRedeemDrawer({ defaultView?: 'invest' | 'redeem' }) { const [filter, setFilter] = React.useState('30days') + const [index, setIndex] = React.useState(0) const dateFrom = React.useMemo(() => { if (filter === 'YTD') { @@ -64,15 +67,26 @@ export function InvestRedeemDrawer({ - - Performance - + + + Performance + + setIndex(index)}> + + Price + + + APY + + + @@ -86,23 +100,36 @@ const TokenPriceChart = React.memo(function TokenPriceChart({ dailyPoolStates, filter, setFilter, + index, }: { poolId: string trancheId: string dailyPoolStates: DailyPoolStateProps[] - filter: FilterOptions | undefined + filter: FilterOptions setFilter: any + index: number }) { const pool = usePool(poolId) + const apy = { + '30days': 'yield30DaysAnnualized', + '90days': 'yield90DaysAnnualized', + YTD: 'yieldYTD', + } + const data = React.useMemo(() => { const tokenData = dailyPoolStates?.map((state: DailyPoolStateProps) => { - return { price: state.tranches[trancheId].price?.toFloat() || 0, day: new Date(state.timestamp) } + return { + price: state.tranches[trancheId].price?.toFloat() || 0, + day: new Date(state.timestamp), + apy: (state.tranches[trancheId] as any)[apy[filter]]?.toPercent().toNumber(), + } }) || [] if (tokenData.length > 0) { tokenData.push({ day: new Date(), + apy: null, price: pool?.tranches .find((tranche) => tranche.id === trancheId) @@ -111,7 +138,7 @@ const TokenPriceChart = React.memo(function TokenPriceChart({ }) } return tokenData - }, [dailyPoolStates, pool?.tranches, trancheId]) + }, [dailyPoolStates, pool?.tranches, trancheId, filter]) if (!data.length) return @@ -121,6 +148,7 @@ const TokenPriceChart = React.memo(function TokenPriceChart({ currency={pool.tranches.find((tranche) => tranche.id === trancheId)?.currency.displayName || ''} filter={filter} setFilter={setFilter} + isPrice={index === 0} /> ) })