import { ModalProps } from '../../types/modal' import Modal from '../shared/Modal' import mangoStore from '@store/mangoStore' import { useTranslation } from 'next-i18next' import { useEffect, useMemo } from 'react' import useMangoAccount from 'hooks/useMangoAccount' import dayjs from 'dayjs' import Change from '@components/shared/Change' import SheenLoader from '@components/shared/SheenLoader' import { NoSymbolIcon } from '@heroicons/react/20/solid' import { PerformanceDataItem } from 'types' interface PnlChange { time: string pnlChange: number } interface PnlHistoryModalProps { pnlChangeToday: number } type ModalCombinedProps = PnlHistoryModalProps & ModalProps const PnlHistoryModal = ({ isOpen, onClose, pnlChangeToday, }: ModalCombinedProps) => { const { t } = useTranslation('account') const { mangoAccountAddress } = useMangoAccount() const actions = mangoStore.getState().actions const loading = mangoStore((s) => s.mangoAccount.performance.loading) const performanceData = mangoStore((s) => s.mangoAccount.performance.data) useEffect(() => { if (mangoAccountAddress) { actions.fetchAccountPerformance(mangoAccountAddress, 31) } }, [actions, mangoAccountAddress]) const dailyValues: PnlChange[] = useMemo(() => { if (!performanceData.length) return [] const dailyPnl = performanceData.filter((d: PerformanceDataItem) => { const startTime = new Date().getTime() - 30 * 86400000 const dataDate = new Date(d.time) const dataTime = dataDate.getTime() return dataTime >= startTime && dataDate.getHours() === 0 }) return dailyPnl.length ? dailyPnl .map((d: PerformanceDataItem, index: number) => { if (index < dailyPnl.length - 1) { const change = dailyPnl[index + 1].pnl - d.pnl return { time: d.time, pnlChange: change, } } else { return { time: performanceData[performanceData.length - 1].time, pnlChange: pnlChangeToday, } } }) .reverse() : [] }, [performanceData]) const pnlThisWeek = useMemo(() => { if (dailyValues.length) { const saturdayIndex = dailyValues.findIndex((d) => { const day = new Date(d.time).getDay() return day === 6 }) if (saturdayIndex !== -1) { return dailyValues .slice(0, saturdayIndex) .reduce((a, c) => a + c.pnlChange, 0) } else { return dailyValues.reduce((a, c) => a + c.pnlChange, 0) } } return 0 }, [dailyValues]) const getLastSunday = (d: Date) => { return d.setDate(d.getDate() - d.getDay()) } return (

{t('pnl-history')}

{loading ? (
{[...Array(4)].map((x, i) => (
))}
) : dailyValues?.length ? ( <>
{dailyValues.map((v) => (

{dayjs(v.time).format('YYYY-MM-DD')}

))}

{t('week-starting', { week: dayjs(getLastSunday(new Date())).format('MM-DD'), })}

) : (

{t('no-pnl-history')}

)}
) } export default PnlHistoryModal