2023-07-08 16:50:40 -07:00
|
|
|
import { useQuery } from '@tanstack/react-query'
|
|
|
|
import { fetchAccountPerformance } from 'utils/account'
|
|
|
|
import useMangoAccount from './useMangoAccount'
|
|
|
|
import { useMemo } from 'react'
|
|
|
|
import { PerformanceDataItem } from 'types'
|
2023-07-13 22:47:05 -07:00
|
|
|
import { DAILY_MILLISECONDS } from 'utils/constants'
|
2023-07-08 16:50:40 -07:00
|
|
|
|
|
|
|
export default function useAccountPerformanceData() {
|
|
|
|
const { mangoAccountAddress } = useMangoAccount()
|
|
|
|
|
|
|
|
const {
|
|
|
|
data: performanceData,
|
|
|
|
isLoading: loadingPerformanceData,
|
|
|
|
isFetching: fetchingPerformanceData,
|
|
|
|
} = useQuery(
|
|
|
|
['performance', mangoAccountAddress],
|
|
|
|
() => fetchAccountPerformance(mangoAccountAddress, 31),
|
|
|
|
{
|
|
|
|
cacheTime: 1000 * 60 * 10,
|
|
|
|
staleTime: 1000 * 60,
|
|
|
|
retry: 3,
|
|
|
|
refetchOnWindowFocus: false,
|
|
|
|
enabled: !!mangoAccountAddress,
|
2023-07-21 11:47:53 -07:00
|
|
|
},
|
2023-07-08 16:50:40 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
const rollingDailyData: PerformanceDataItem[] | [] = useMemo(() => {
|
|
|
|
if (!performanceData || !performanceData.length) return []
|
|
|
|
const nowDate = new Date()
|
|
|
|
return performanceData.filter((d) => {
|
|
|
|
const dataTime = new Date(d.time).getTime()
|
2023-07-13 22:47:05 -07:00
|
|
|
return dataTime >= nowDate.getTime() - DAILY_MILLISECONDS
|
2023-07-08 16:50:40 -07:00
|
|
|
})
|
|
|
|
}, [performanceData])
|
|
|
|
|
|
|
|
const performanceLoading = loadingPerformanceData || fetchingPerformanceData
|
|
|
|
|
|
|
|
return {
|
|
|
|
performanceData,
|
|
|
|
rollingDailyData,
|
|
|
|
loadingPerformanceData,
|
|
|
|
fetchingPerformanceData,
|
|
|
|
performanceLoading,
|
|
|
|
}
|
|
|
|
}
|