mango-v4-ui/components/trade/GroupSize.tsx

85 lines
2.4 KiB
TypeScript
Raw Normal View History

2023-04-24 03:17:01 -07:00
import React, { useCallback, useMemo } from 'react'
2022-09-18 05:53:28 -07:00
import { Listbox } from '@headlessui/react'
import { ChevronDownIcon } from '@heroicons/react/20/solid'
2023-04-24 03:17:01 -07:00
import Decimal from 'decimal.js'
2022-09-18 05:53:28 -07:00
const GroupSize = ({
tickSize,
value,
onChange,
className,
}: {
tickSize: number
value: number
onChange: (x: number) => void
className?: string
}) => {
2023-04-24 03:17:01 -07:00
const formatSize = useCallback(
(multiplier: number) => {
return new Decimal(tickSize).mul(multiplier).toNumber()
},
2023-07-21 11:47:53 -07:00
[tickSize],
2023-04-24 03:17:01 -07:00
)
2022-09-18 05:53:28 -07:00
const sizes = useMemo(
() => [
tickSize,
2023-04-24 03:17:01 -07:00
formatSize(5),
formatSize(10),
formatSize(50),
formatSize(100),
2023-07-25 04:51:04 -07:00
formatSize(500),
formatSize(1000),
2022-09-18 05:53:28 -07:00
],
2023-07-21 11:47:53 -07:00
[tickSize],
2022-09-18 05:53:28 -07:00
)
return (
<div className={`relative ${className}`}>
<Listbox value={value} onChange={onChange}>
{({ open }) => (
<>
<Listbox.Button
2023-04-19 18:12:45 -07:00
className={`flex h-6 items-center rounded bg-th-bkg-1 py-1 pl-1.5 font-normal text-th-fgd-2 hover:text-th-active focus:border-th-bkg-4 focus:bg-th-bkg-3 focus:outline-none`}
2022-09-18 05:53:28 -07:00
>
<div
2022-09-20 03:36:33 -07:00
className={`flex items-center justify-between font-mono text-xs leading-none`}
2022-09-18 05:53:28 -07:00
>
2022-09-20 03:36:33 -07:00
<span>{value}</span>
2022-09-18 05:53:28 -07:00
<ChevronDownIcon
2023-04-19 18:12:45 -07:00
className={`ml-0.5 h-5 w-5 text-th-fgd-3 ${
2022-09-18 05:53:28 -07:00
open ? 'rotate-180 transform' : 'rotate-360 transform'
}`}
/>
</div>
</Listbox.Button>
{open ? (
<Listbox.Options
static
2022-10-06 03:12:08 -07:00
className={`thin-scroll absolute right-0 top-7 z-20 w-20 space-y-2 overflow-auto rounded bg-th-bkg-2 p-2 text-th-fgd-2 outline-none`}
2022-09-18 05:53:28 -07:00
>
{sizes.map((size) => (
<Listbox.Option key={size} value={size}>
{({ selected }) => (
<div
2023-04-19 18:12:45 -07:00
className={`text-right font-mono text-xs text-th-fgd-2 hover:cursor-pointer hover:text-th-active ${
2022-11-30 19:32:32 -08:00
selected && `text-th-active`
2022-09-18 05:53:28 -07:00
}`}
>
{size}
</div>
)}
</Listbox.Option>
))}
</Listbox.Options>
) : null}
</>
)}
</Listbox>
</div>
)
}
export default React.memo(GroupSize)