2024-10-13 00:40:14 +02:00
|
|
|
import clsx from "clsx";
|
|
|
|
import { memo, useState } from "react";
|
|
|
|
import { Button } from "./button";
|
2024-10-27 21:22:06 +01:00
|
|
|
import { FlyoutMenu } from "./flyoutmenu";
|
2024-10-28 05:34:20 +01:00
|
|
|
import "./menubutton.less";
|
2024-10-13 00:40:14 +02:00
|
|
|
|
|
|
|
const MenuButtonComponent = ({ items, className, text, title }: MenuButtonProps) => {
|
|
|
|
const [isOpen, setIsOpen] = useState(false);
|
|
|
|
return (
|
|
|
|
<div className={clsx("menubutton", className)}>
|
2024-10-27 21:22:06 +01:00
|
|
|
<FlyoutMenu items={items} onOpenChange={setIsOpen}>
|
2024-10-13 00:40:14 +02:00
|
|
|
<Button
|
|
|
|
className="grey border-radius-3 vertical-padding-2 horizontal-padding-2"
|
|
|
|
style={{ borderColor: isOpen ? "var(--accent-color)" : "transparent" }}
|
|
|
|
title={title}
|
|
|
|
>
|
2024-10-25 08:24:54 +02:00
|
|
|
<div>{text}</div>
|
|
|
|
<i className="fa-sharp fa-solid fa-angle-down"></i>
|
2024-10-13 00:40:14 +02:00
|
|
|
</Button>
|
2024-10-27 21:22:06 +01:00
|
|
|
</FlyoutMenu>
|
2024-10-13 00:40:14 +02:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export const MenuButton = memo(MenuButtonComponent) as typeof MenuButtonComponent;
|