File size: 1,465 Bytes
d092f57 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | import React, { FC, ReactNode, useEffect, useState } from "react"
import ControlButton from "../input/ControlButton"
import classNames from "classnames"
interface Props {
tooltip: string
open?: boolean
className?: string
menuChange?: (open: boolean) => void
interaction: (touch: boolean) => void
buttonContent: ReactNode
children?: ReactNode
}
const DropUp: FC<Props> = ({
tooltip,
open,
className,
menuChange,
interaction,
buttonContent,
children,
}) => {
const [menuOpen, setMenuOpen] = useState(false)
useEffect(() => {
if (typeof open !== "boolean") return
if (menuOpen !== open) {
setMenuOpen(open)
if (menuChange) {
menuChange(open)
}
}
}, [open, menuChange, menuOpen])
return (
<div className={"relative"}>
{menuOpen && (
<div
className={classNames(
"absolute bottom-[60px] rounded bg-dark-900",
"transition-height transition-width",
className
)}
>
{children}
</div>
)}
<ControlButton
tooltip={(menuOpen ? "Close " : "Open ") + tooltip}
className={menuOpen ? "bg-dark-800" : ""}
onClick={() => {
if (menuChange) {
menuChange(!menuOpen)
}
setMenuOpen(!menuOpen)
}}
interaction={interaction}
>
{buttonContent}
</ControlButton>
</div>
)
}
export default DropUp
|