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

114 lines
2.5 KiB
TypeScript
Raw Normal View History

import { ChangeEvent, useEffect, useRef, useState } from 'react'
2022-08-20 11:17:57 -07:00
import mangoStore from '../../store/mangoStore'
2022-08-26 10:17:31 -07:00
import { useTokenMax } from './useTokenMax'
2022-07-12 19:02:36 -07:00
2022-07-12 20:58:13 -07:00
const LeverageSlider = ({
2022-08-17 18:21:16 -07:00
amount,
2022-08-15 15:18:23 -07:00
leverageMax,
onChange,
}: {
amount: number
2022-08-15 15:18:23 -07:00
leverageMax: number
onChange: (x: string) => any
2022-08-15 15:18:23 -07:00
}) => {
const [value, setValue] = useState(0)
const inputEl = useRef<HTMLInputElement>(null)
const inputTokenInfo = mangoStore((s) => s.swap.inputTokenInfo)
useEffect(() => {
if (inputEl.current) {
const target = inputEl.current
const min = parseFloat(target.min)
const max = leverageMax
target.style.backgroundSize =
max - min === 0
? '0% 100%'
: ((value - min) * 100) / (max - min) + '% 100%'
}
2022-08-17 18:21:16 -07:00
}, [leverageMax, value])
useEffect(() => {
if (amount) {
onChange(amount.toString())
setValue(amount)
}
}, [amount])
2022-08-15 15:18:23 -07:00
const handleSliderChange = (e: ChangeEvent<HTMLInputElement>) => {
2022-08-16 20:42:16 -07:00
let target = e.target
const min = parseFloat(target.min)
const max = parseFloat(target.max)
const val = parseFloat(target.value)
target.style.backgroundSize = ((val - min) * 100) / (max - min) + '% 100%'
2022-08-17 14:36:38 -07:00
2022-08-15 15:18:23 -07:00
onChange(e.target.value)
setValue(parseFloat(e.target.value))
2022-08-15 15:18:23 -07:00
}
return (
<>
<label htmlFor="default-range" className="block text-sm"></label>
<input
ref={inputEl}
2022-08-15 15:18:23 -07:00
id="default-range"
type="range"
min="0"
max={leverageMax}
step={inputTokenInfo ? 1 / 10 ** inputTokenInfo?.decimals : 6}
2022-08-16 20:42:16 -07:00
className="w-full"
2022-08-15 15:18:23 -07:00
onChange={handleSliderChange}
2022-08-17 21:25:30 -07:00
value={value}
2022-08-15 15:18:23 -07:00
></input>
</>
)
}
export const SwapLeverageSlider = ({
2022-08-17 18:21:16 -07:00
amount,
2022-07-12 20:58:13 -07:00
onChange,
}: {
amount: number
onChange: (x: string) => void
}) => {
const mangoAccount = mangoStore((s) => s.mangoAccount.current)
const { amountWithBorrow } = useTokenMax()
2022-07-12 19:02:36 -07:00
2022-08-15 15:18:23 -07:00
return (
<>
{!mangoAccount ? (
<LeverageSlider amount={amount} leverageMax={100} onChange={onChange} />
) : (
<LeverageSlider
amount={amount}
leverageMax={amountWithBorrow}
onChange={onChange}
/>
)}
2022-08-15 15:18:23 -07:00
</>
)
}
2022-07-12 19:02:36 -07:00
2022-08-15 15:18:23 -07:00
export const BorrowLeverageSlider = ({
amount,
2022-08-15 15:18:23 -07:00
tokenMax,
onChange,
}: {
amount: number
2022-08-15 15:18:23 -07:00
tokenMax: number
onChange: (x: string) => any
2022-08-15 15:18:23 -07:00
}) => {
2022-07-12 19:02:36 -07:00
return (
<>
<LeverageSlider
amount={amount}
leverageMax={tokenMax}
onChange={onChange}
/>
2022-07-12 19:02:36 -07:00
</>
)
}
export default LeverageSlider