mango-v4-ui/components/swap/SwapSlider.tsx

48 lines
1019 B
TypeScript

import useMangoAccount from 'hooks/useMangoAccount'
import { useCallback } from 'react'
import LeverageSlider from '../shared/LeverageSlider'
import { useTokenMax } from './useTokenMax'
const SwapSlider = ({
amount,
onChange,
useMargin,
step,
}: {
amount: number
onChange: (x: string) => void
useMargin: boolean
step: number
}) => {
const { mangoAccount } = useMangoAccount()
const { amount: tokenMax, amountWithBorrow } = useTokenMax(useMargin)
const handleChange = useCallback((x: string) => {
onChange(x)
}, [])
return (
<>
{!mangoAccount ? (
<LeverageSlider
amount={amount}
leverageMax={100}
onChange={onChange}
step={step}
/>
) : (
<LeverageSlider
amount={amount}
leverageMax={
useMargin ? amountWithBorrow.toNumber() : tokenMax.toNumber()
}
onChange={handleChange}
step={step}
/>
)}
</>
)
}
export default SwapSlider