48 lines
1.4 KiB
TypeScript
48 lines
1.4 KiB
TypeScript
import { useQuery } from '@tanstack/react-query'
|
|
import { fetchAccountPerformance } from 'utils/account'
|
|
import useMangoAccount from './useMangoAccount'
|
|
import { useMemo } from 'react'
|
|
import { PerformanceDataItem } from 'types'
|
|
import { DAILY_MILLISECONDS } from 'utils/constants'
|
|
|
|
export default function useAccountPerformanceData(unownedPk?: string) {
|
|
const { mangoAccountAddress } = useMangoAccount()
|
|
|
|
const accountPkToFetch = unownedPk ? unownedPk : mangoAccountAddress
|
|
|
|
const {
|
|
data: performanceData,
|
|
isFetching: fetchingPerformanceData,
|
|
isInitialLoading: loadingPerformanceData,
|
|
} = useQuery(
|
|
['performance', accountPkToFetch],
|
|
() => fetchAccountPerformance(accountPkToFetch, 31),
|
|
{
|
|
cacheTime: 1000 * 60 * 10,
|
|
staleTime: 1000 * 60,
|
|
retry: 3,
|
|
refetchOnWindowFocus: false,
|
|
enabled: !!accountPkToFetch,
|
|
},
|
|
)
|
|
|
|
const rollingDailyData: PerformanceDataItem[] | [] = useMemo(() => {
|
|
if (!performanceData || !performanceData.length) return []
|
|
const nowDate = new Date()
|
|
return performanceData.filter((d) => {
|
|
const dataTime = new Date(d.time).getTime()
|
|
return dataTime >= nowDate.getTime() - DAILY_MILLISECONDS
|
|
})
|
|
}, [performanceData])
|
|
|
|
const performanceLoading = loadingPerformanceData || fetchingPerformanceData
|
|
|
|
return {
|
|
performanceData,
|
|
rollingDailyData,
|
|
loadingPerformanceData,
|
|
fetchingPerformanceData,
|
|
performanceLoading,
|
|
}
|
|
}
|