64 lines
1.8 KiB
TypeScript
64 lines
1.8 KiB
TypeScript
import { useQuery } from '@tanstack/react-query'
|
|
import { MANGO_DATA_API_URL } from 'utils/constants'
|
|
import { ActivityFeed, EmptyObject } from 'types'
|
|
import dayjs from 'dayjs'
|
|
import useStakeAccounts from './useStakeAccounts'
|
|
|
|
const fetchHistory = async (
|
|
mangoAccountPk: string,
|
|
): Promise<Array<ActivityFeed> | EmptyObject | null> => {
|
|
const response = await fetch(
|
|
`${MANGO_DATA_API_URL}/stats/activity-feed?mango-account=${mangoAccountPk}&offset=0&limit=1000`,
|
|
)
|
|
const parsedResponse: Array<ActivityFeed> = await response.json()
|
|
|
|
if (Array.isArray(parsedResponse)) {
|
|
const activity = parsedResponse
|
|
.map((i) => {
|
|
return {
|
|
...i,
|
|
}
|
|
})
|
|
.sort(
|
|
(a, b) =>
|
|
dayjs(b.block_datetime).unix() - dayjs(a.block_datetime).unix(),
|
|
)
|
|
|
|
// only add to current feed if data request is offset and the mango account hasn't changed
|
|
// const combinedFeed =
|
|
// offset !== 0 ? loadedFeed.concat(latestFeed) : latestFeed
|
|
|
|
return activity
|
|
} else return null
|
|
}
|
|
|
|
export default function useAccountHistory() {
|
|
const { stakeAccounts } = useStakeAccounts()
|
|
|
|
const response = useQuery<Array<ActivityFeed[] | null> | EmptyObject | null>(
|
|
['history'],
|
|
() =>
|
|
stakeAccounts?.length
|
|
? Promise.all(
|
|
stakeAccounts.map((acc) => fetchHistory(acc.publicKey.toString())),
|
|
)
|
|
: // ? fetchHistory(mangoAccount.publicKey.toString())
|
|
null,
|
|
{
|
|
cacheTime: 1000 * 60 * 5,
|
|
staleTime: 1000 * 60,
|
|
retry: 3,
|
|
refetchOnWindowFocus: true,
|
|
enabled: !!stakeAccounts,
|
|
},
|
|
)
|
|
|
|
return {
|
|
history:
|
|
response?.data && Array.isArray(response.data)
|
|
? response.data.flat().filter((n) => n)
|
|
: [],
|
|
isLoading: response.isLoading || response.isFetching,
|
|
}
|
|
}
|