mango-v4-ui/hooks/useCoingecko.ts

50 lines
1.2 KiB
TypeScript
Raw Normal View History

2022-11-18 11:11:06 -08:00
import { useQuery } from '@tanstack/react-query'
import { Token } from 'types/jupiter'
import useJupiterMints from './useJupiterMints'
const fetchCoingecko = async (
mangoTokens: Token[]
): Promise<{ prices: any[]; symbol: string }[]> => {
const coingeckoIds = mangoTokens.map((token) => ({
id: token.extensions?.coingeckoId,
symbol: token.symbol,
}))
const promises: any = []
for (const token of coingeckoIds) {
if (token.id) {
promises.push(
fetch(
`https://api.coingecko.com/api/v3/coins/${token.id}/market_chart?vs_currency=usd&days=1`
).then((res) => res.json())
)
}
}
const data = await Promise.all(promises)
for (let i = 0; i < data.length; i++) {
data[i].symbol = coingeckoIds[i].symbol
}
return data || []
}
export const useCoingecko = () => {
const { mangoTokens } = useJupiterMints()
const res = useQuery<any[], Error>(
['coingecko-tokens'],
() => fetchCoingecko(mangoTokens!),
{
cacheTime: 1000 * 60 * 2,
staleTime: 1000 * 60 * 2,
retry: true,
enabled: !!mangoTokens,
}
)
return {
isLoading: res.isLoading,
data: res.data || [],
}
}