2024-03-31 16:48:31 +02:00
|
|
|
'use client'
|
|
|
|
|
2024-04-16 13:04:00 +02:00
|
|
|
import {
|
|
|
|
FormAmount,
|
|
|
|
FormMarket,
|
2024-07-26 14:16:59 +02:00
|
|
|
type Market,
|
2024-04-16 13:04:00 +02:00
|
|
|
usePersistentState
|
|
|
|
} from '@/features/strategies'
|
2024-04-01 14:42:08 +02:00
|
|
|
import stylesShared from '@/features/strategies/styles/shared.module.css'
|
2024-07-26 14:16:59 +02:00
|
|
|
import type { TokenSymbol } from '@/types'
|
|
|
|
import { useDebounce } from 'use-debounce'
|
|
|
|
import { SwapResults } from './Results'
|
2024-03-31 16:48:31 +02:00
|
|
|
|
|
|
|
export function Swap() {
|
2024-04-16 13:04:00 +02:00
|
|
|
const [amount, setAmount] = usePersistentState('swapAmount', 100)
|
2024-03-31 16:48:31 +02:00
|
|
|
const [debouncedAmount] = useDebounce(amount, 500)
|
2024-04-16 13:04:00 +02:00
|
|
|
const [tokenSymbol, setTokenSymbol] = usePersistentState<TokenSymbol>(
|
|
|
|
'swapTokenSymbol',
|
|
|
|
'OCEAN'
|
|
|
|
)
|
|
|
|
const [market, setMarket] = usePersistentState<Market>('swapMarket', 'all')
|
2024-03-31 16:48:31 +02:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div className={stylesShared.results}>
|
|
|
|
<h3 className={stylesShared.title}>
|
|
|
|
Holding or swapping{' '}
|
|
|
|
<FormAmount
|
|
|
|
amount={amount}
|
2024-03-31 23:50:43 +02:00
|
|
|
token={tokenSymbol}
|
2024-03-31 16:48:31 +02:00
|
|
|
setAmount={setAmount}
|
2024-03-31 23:50:43 +02:00
|
|
|
setToken={setTokenSymbol}
|
2024-03-31 16:48:31 +02:00
|
|
|
/>{' '}
|
2024-04-01 14:42:08 +02:00
|
|
|
on <FormMarket market={market} setMarket={setMarket} /> right now gets
|
|
|
|
you:
|
2024-03-31 16:48:31 +02:00
|
|
|
</h3>
|
|
|
|
|
2024-04-01 14:42:08 +02:00
|
|
|
<SwapResults
|
|
|
|
tokenSymbol={tokenSymbol}
|
|
|
|
amount={debouncedAmount}
|
|
|
|
market={market}
|
|
|
|
/>
|
2024-03-31 16:48:31 +02:00
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|