mango-ui-v3/components/ButtonGroup.tsx

58 lines
1.5 KiB
TypeScript

import { FunctionComponent } from 'react'
interface ButtonGroupProps {
activeValue: string
className?: string
onChange: (x) => void
unit?: string
values: Array<any>
names?: Array<string>
}
const ButtonGroup: FunctionComponent<ButtonGroupProps> = ({
activeValue,
className,
unit,
values,
onChange,
names,
}) => {
return (
<div className="rounded-md bg-th-bkg-3">
<div className="relative flex">
{activeValue && values.includes(activeValue) ? (
<div
className={`default-transition absolute left-0 top-0 h-full transform rounded-md bg-th-bkg-4`}
style={{
transform: `translateX(${
values.findIndex((v) => v === activeValue) * 100
}%)`,
width: `${100 / values.length}%`,
}}
/>
) : null}
{values.map((v, i) => (
<button
className={`${className} default-transition relative w-1/2 cursor-pointer rounded-md px-2 py-1.5 text-center text-xs font-normal
${
v === activeValue
? `text-th-primary`
: `text-th-fgd-2 md:hover:text-th-primary`
}
`}
key={`${v}${i}`}
onClick={() => onChange(v)}
style={{
width: `${100 / values.length}%`,
}}
>
{names ? (unit ? names[i] + unit : names[i]) : unit ? v + unit : v}
</button>
))}
</div>
</div>
)
}
export default ButtonGroup