asi-calculator/features/strategies/components/Buy.tsx

76 lines
2.4 KiB
TypeScript
Raw Normal View History

2024-03-30 19:11:24 +01:00
'use client'
import {
ratioAgixToAsi,
ratioCudosToAsi,
ratioFetToAsi,
ratioOceanToAsi
} from '@/constants'
2024-04-01 14:42:08 +02:00
import { usePrices } from '@/features/prices'
import { FormAmount, Result, usePersistentState } from '@/features/strategies'
2024-04-01 14:42:08 +02:00
import stylesShared from '@/features/strategies/styles/shared.module.css'
import { getTokenBySymbol } from '@/lib'
import { useDebounce } from 'use-debounce'
2024-03-30 19:11:24 +01:00
export function Buy() {
2024-04-01 02:15:51 +02:00
const { prices, isValidating, isLoading } = usePrices()
const [amount, setAmount] = usePersistentState('buyAmount', 100)
2024-03-30 20:50:51 +01:00
const [debouncedAmount] = useDebounce(amount, 500)
2024-03-30 19:11:24 +01:00
return (
2024-03-30 20:50:51 +01:00
<div className={stylesShared.results}>
<h3 className={stylesShared.title}>
Buying with{' '}
<FormAmount amount={amount} setAmount={setAmount} token="usd" isFiat />{' '}
right now gets you:
2024-03-30 19:11:24 +01:00
</h3>
<Result
2024-03-31 16:58:26 +02:00
token={getTokenBySymbol('OCEAN')}
2024-09-21 03:06:44 +02:00
amount={debouncedAmount / prices.ocean?.usd}
amountAsi={(debouncedAmount / prices.ocean?.usd) * ratioOceanToAsi}
2024-03-30 19:11:24 +01:00
amountFiat={
2024-09-21 03:06:44 +02:00
(debouncedAmount / prices.ocean?.usd) *
ratioOceanToAsi *
2024-09-21 03:06:44 +02:00
prices.asi?.usd
2024-03-30 19:11:24 +01:00
}
2024-03-31 05:32:11 +02:00
isValidating={isValidating}
2024-04-01 02:15:51 +02:00
isLoading={isLoading}
2024-03-30 19:11:24 +01:00
/>
<Result
2024-03-31 16:58:26 +02:00
token={getTokenBySymbol('AGIX')}
2024-09-21 03:06:44 +02:00
amount={debouncedAmount / prices.agix?.usd}
amountAsi={(debouncedAmount / prices.agix?.usd) * ratioAgixToAsi}
2024-03-30 19:11:24 +01:00
amountFiat={
2024-09-21 03:06:44 +02:00
(debouncedAmount / prices.agix?.usd) *
ratioAgixToAsi *
prices.asi?.usd
2024-03-30 19:11:24 +01:00
}
2024-03-31 05:32:11 +02:00
isValidating={isValidating}
2024-04-01 02:15:51 +02:00
isLoading={isLoading}
2024-03-30 19:11:24 +01:00
/>
<Result
token={getTokenBySymbol('CUDOS')}
2024-09-21 03:06:44 +02:00
amount={debouncedAmount / prices.cudos?.usd}
amountAsi={(debouncedAmount / prices.cudos?.usd) * ratioCudosToAsi}
amountFiat={
2024-09-21 03:06:44 +02:00
(debouncedAmount / prices.cudos?.usd) *
ratioCudosToAsi *
2024-09-21 03:06:44 +02:00
prices.asi?.usd
}
isValidating={isValidating}
isLoading={isLoading}
/>
2024-03-30 19:11:24 +01:00
<Result
2024-03-31 16:58:26 +02:00
token={getTokenBySymbol('FET')}
2024-09-21 03:06:44 +02:00
amount={debouncedAmount / prices.fet?.usd}
amountAsi={(debouncedAmount / prices.fet?.usd) * ratioFetToAsi}
amountFiat={
2024-09-21 03:06:44 +02:00
(debouncedAmount / prices.fet?.usd) * ratioFetToAsi * prices.asi?.usd
}
2024-03-31 05:32:11 +02:00
isValidating={isValidating}
2024-04-01 02:15:51 +02:00
isLoading={isLoading}
2024-03-30 19:11:24 +01:00
/>
</div>
)
}