asi-calculator/components/Prices.tsx

162 lines
5.0 KiB
TypeScript
Raw Normal View History

2024-03-29 19:54:14 +01:00
'use client'
import useSWR from 'swr'
2024-03-29 22:54:07 +01:00
import { useDebounce } from 'use-debounce'
2024-03-29 19:54:14 +01:00
import styles from './Prices.module.css'
import { Result } from './Result'
import {
tokens,
ratioOceanToAsi,
ratioAgixToAsi,
ratioFetToAsi
} from '@/constants'
2024-03-29 22:54:07 +01:00
import { useState } from 'react'
import { FormAmount } from './FormAmount'
2024-03-30 01:32:46 +01:00
import { fetcher, formatNumber } from '@/utils'
import { Content } from '@/components/Content'
2024-03-29 19:54:14 +01:00
export function Prices() {
2024-03-29 22:54:07 +01:00
const [amountSwap, setAmountSwap] = useState(100)
const [debouncedAmountSwap] = useDebounce(amountSwap, 500)
2024-03-30 18:22:30 +01:00
const [amountBuy, setAmountBuy] = useState(100)
const [debouncedAmountBuy] = useDebounce(amountBuy, 500)
2024-03-29 22:54:07 +01:00
2024-03-29 19:54:14 +01:00
const { data: dataPrices } = useSWR(
2024-03-30 01:32:46 +01:00
`/api/prices/?tokens=${tokens.toString()}`,
2024-03-29 19:54:14 +01:00
fetcher
)
2024-03-30 02:03:43 +01:00
2024-03-29 19:54:14 +01:00
const { data: dataSwapOceanToAgix } = useSWR(
2024-03-30 16:49:14 +01:00
`/api/quote/?tokenIn=${tokens[0]}&tokenOut=${tokens[2]}&amountIn=${debouncedAmountSwap}`,
2024-03-29 19:54:14 +01:00
fetcher
)
const { data: dataSwapOceanToFet } = useSWR(
2024-03-30 16:49:14 +01:00
`/api/quote/?tokenIn=${tokens[0]}&tokenOut=${tokens[1]}&amountIn=${debouncedAmountSwap}`,
2024-03-29 19:54:14 +01:00
fetcher
)
const priceOcean = dataPrices?.[tokens[0]]?.usd || 0
const priceFet = dataPrices?.[tokens[1]]?.usd || 0
const priceAgix = dataPrices?.[tokens[2]]?.usd || 0
const priceAsi = priceFet
return (
<>
2024-03-29 22:54:07 +01:00
<div className={styles.grid}>
<div className={styles.results}>
<h3>
2024-03-30 01:32:46 +01:00
Swapping{' '}
<FormAmount amount={amountSwap} setAmount={setAmountSwap} /> OCEAN (
2024-03-30 18:22:30 +01:00
{formatNumber(debouncedAmountSwap * priceOcean, 'USD')}) right now
gets you:
2024-03-29 22:54:07 +01:00
</h3>
2024-03-29 19:54:14 +01:00
2024-03-29 22:54:07 +01:00
<Result
2024-03-30 02:03:43 +01:00
tokenSymbol="OCEAN"
tokenAddress="0x967da4048cd07ab37855c090aaf366e4ce1b9f48"
2024-03-29 22:54:07 +01:00
amount={debouncedAmountSwap}
amountAsi={debouncedAmountSwap * ratioOceanToAsi}
amountFiat={debouncedAmountSwap * ratioOceanToAsi * priceAsi}
/>
2024-03-29 19:54:14 +01:00
2024-03-29 22:54:07 +01:00
<Result
2024-03-30 02:03:43 +01:00
tokenSymbol="AGIX"
tokenAddress="0x5b7533812759b45c2b44c19e320ba2cd2681b542"
2024-03-29 22:54:07 +01:00
amount={
2024-03-30 16:49:14 +01:00
dataSwapOceanToAgix?.amountOut /
Number(`1e${dataSwapOceanToAgix?.decimals}`) || 0
2024-03-29 22:54:07 +01:00
}
amountAsi={
2024-03-30 16:49:14 +01:00
(dataSwapOceanToAgix?.amountOut /
Number(`1e${dataSwapOceanToAgix?.decimals}`) || 0) *
2024-03-29 22:54:07 +01:00
ratioAgixToAsi
}
amountFiat={
2024-03-30 16:49:14 +01:00
(dataSwapOceanToAgix?.amountOut /
Number(`1e${dataSwapOceanToAgix?.decimals}`) || 0) *
2024-03-29 22:54:07 +01:00
ratioAgixToAsi *
priceAsi
}
/>
2024-03-29 19:54:14 +01:00
2024-03-29 22:54:07 +01:00
<Result
2024-03-30 02:03:43 +01:00
tokenSymbol="FET"
tokenAddress="0xaea46a60368a7bd060eec7df8cba43b7ef41ad85"
2024-03-29 22:54:07 +01:00
amount={
2024-03-30 16:49:14 +01:00
dataSwapOceanToFet?.amountOut /
Number(`1e${dataSwapOceanToFet?.decimals}`) || 0
2024-03-29 22:54:07 +01:00
}
amountAsi={
2024-03-30 16:49:14 +01:00
(dataSwapOceanToFet?.amountOut /
Number(`1e${dataSwapOceanToFet?.decimals}`) || 0) *
2024-03-29 22:54:07 +01:00
ratioFetToAsi
}
amountFiat={
2024-03-30 16:49:14 +01:00
(dataSwapOceanToFet?.amountOut /
Number(`1e${dataSwapOceanToFet?.decimals}`) || 0) * priceAsi
2024-03-29 22:54:07 +01:00
}
/>
</div>
2024-03-30 02:20:15 +01:00
<div className={styles.results}>
2024-03-30 18:22:30 +01:00
<h3>
Buying with $
<FormAmount amount={amountBuy} setAmount={setAmountBuy} /> right now
gets you:
</h3>
2024-03-30 02:20:15 +01:00
<Result
tokenSymbol="OCEAN"
tokenAddress="0x967da4048cd07ab37855c090aaf366e4ce1b9f48"
2024-03-30 18:22:30 +01:00
amount={priceOcean ? debouncedAmountBuy / priceOcean : 0}
2024-03-30 02:20:15 +01:00
amountAsi={
2024-03-30 18:22:30 +01:00
priceOcean
? (debouncedAmountBuy / priceOcean) * ratioOceanToAsi
: 0
2024-03-30 02:20:15 +01:00
}
amountFiat={
priceOcean
2024-03-30 18:22:30 +01:00
? (debouncedAmountBuy / priceOcean) * ratioOceanToAsi * priceAsi
2024-03-30 02:20:15 +01:00
: 0
}
/>
<Result
tokenSymbol="AGIX"
tokenAddress="0x5b7533812759b45c2b44c19e320ba2cd2681b542"
2024-03-30 18:22:30 +01:00
amount={priceAgix ? debouncedAmountBuy / priceAgix : 0}
2024-03-30 02:20:15 +01:00
amountAsi={
2024-03-30 18:22:30 +01:00
priceAgix ? (debouncedAmountBuy / priceAgix) * ratioAgixToAsi : 0
2024-03-30 02:20:15 +01:00
}
amountFiat={
priceAgix
2024-03-30 18:22:30 +01:00
? (debouncedAmountBuy / priceAgix) * ratioAgixToAsi * priceAsi
2024-03-30 02:20:15 +01:00
: 0
}
/>
<Result
tokenSymbol="FET"
tokenAddress="0xaea46a60368a7bd060eec7df8cba43b7ef41ad85"
2024-03-30 18:22:30 +01:00
amount={priceFet ? debouncedAmountBuy / priceFet : 0}
2024-03-30 02:20:15 +01:00
amountAsi={
2024-03-30 18:22:30 +01:00
priceFet ? (debouncedAmountBuy / priceFet) * ratioFetToAsi : 0
2024-03-30 02:20:15 +01:00
}
amountFiat={
priceFet
2024-03-30 18:22:30 +01:00
? (debouncedAmountBuy / priceFet) * ratioFetToAsi * priceAsi
2024-03-30 02:20:15 +01:00
: 0
}
/>
</div>
2024-03-29 19:54:14 +01:00
</div>
2024-03-30 18:45:12 +01:00
<Content
prices={{
ocean: priceOcean,
agix: priceAgix,
asi: priceAsi,
fet: priceFet
}}
/>
2024-03-29 19:54:14 +01:00
</>
)
}