mirror of
https://github.com/kremalicious/asi-calculator.git
synced 2025-01-05 11:25:08 +01:00
92 lines
2.2 KiB
TypeScript
92 lines
2.2 KiB
TypeScript
'use client'
|
|
|
|
import { TokenSymbol } from '@/types'
|
|
import { getTokenAddressBySymbol, fetcher } from '@/lib/utils'
|
|
import useSWR from 'swr'
|
|
|
|
const options = {
|
|
keepPreviousData: true // so loading UI can kick in properly
|
|
}
|
|
|
|
export function useQuote(
|
|
tokenSymbol: TokenSymbol,
|
|
amount: number,
|
|
shouldFetch: boolean
|
|
) {
|
|
// -> AGIX
|
|
const {
|
|
data: dataSwapToAgix,
|
|
isValidating: isValidatingToAgix,
|
|
isLoading: isLoadingToAgix
|
|
} = useSWR(
|
|
shouldFetch
|
|
? `/api/quote/?tokenIn=${getTokenAddressBySymbol(
|
|
tokenSymbol
|
|
)}&tokenOut=${getTokenAddressBySymbol('AGIX')}&amountIn=${amount}`
|
|
: null,
|
|
fetcher,
|
|
options
|
|
)
|
|
|
|
// -> FET
|
|
const {
|
|
data: dataSwapToFet,
|
|
isValidating: isValidatingToFet,
|
|
isLoading: isLoadingToFet
|
|
} = useSWR(
|
|
shouldFetch
|
|
? `/api/quote/?tokenIn=${getTokenAddressBySymbol(
|
|
tokenSymbol
|
|
)}&tokenOut=${getTokenAddressBySymbol('FET')}&amountIn=${amount}`
|
|
: null,
|
|
fetcher,
|
|
options
|
|
)
|
|
|
|
// -> OCEAN
|
|
const {
|
|
data: dataSwapToOcean,
|
|
isValidating: isValidatingToOcean,
|
|
isLoading: isLoadingToOcean
|
|
} = useSWR(
|
|
shouldFetch
|
|
? `/api/quote/?tokenIn=${getTokenAddressBySymbol(
|
|
tokenSymbol
|
|
)}&tokenOut=${getTokenAddressBySymbol('OCEAN')}&amountIn=${amount}`
|
|
: null,
|
|
fetcher,
|
|
options
|
|
)
|
|
|
|
const amountToOcean =
|
|
dataSwapToOcean?.amountOut / Number(`1e${dataSwapToOcean?.decimals}`)
|
|
const amountToAgix =
|
|
dataSwapToAgix?.amountOut / Number(`1e${dataSwapToAgix?.decimals}`)
|
|
const amountToFet =
|
|
dataSwapToFet?.amountOut / Number(`1e${dataSwapToFet?.decimals}`)
|
|
|
|
return shouldFetch
|
|
? {
|
|
amountToOcean,
|
|
amountToAgix,
|
|
amountToFet,
|
|
isValidatingToAgix,
|
|
isLoadingToAgix,
|
|
isValidatingToFet,
|
|
isLoadingToFet,
|
|
isValidatingToOcean,
|
|
isLoadingToOcean
|
|
}
|
|
: {
|
|
amountToOcean: undefined,
|
|
amountToAgix: undefined,
|
|
amountToFet: undefined,
|
|
isValidatingToAgix: false,
|
|
isLoadingToAgix: false,
|
|
isValidatingToFet: false,
|
|
isLoadingToFet: false,
|
|
isValidatingToOcean: false,
|
|
isLoadingToOcean: false
|
|
}
|
|
}
|