1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/dashboard/client/components/menu/menu-picker.tsx
Jari Kolehmainen 1d0815abd2
Lens app source code (#119)
Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com>
2020-03-15 09:52:02 +02:00

43 lines
1.2 KiB
TypeScript

import './menu-picker.scss'
import React, { useRef, useState } from "react";
import { cssNames } from "../../utils";
import { Menu, MenuProps } from "./menu";
import { Icon } from "../icon";
import { Button } from "../button";
import uniqueId from "lodash/uniqueId";
interface Props extends Partial<MenuProps> {
title: React.ReactNode;
waiting?: boolean;
}
export function MenuPicker(props: Props) {
const id = useRef(uniqueId("menu_picker_")).current;
const { className, title, waiting, children, ...menuProps } = props;
const [isOpen, setOpen] = useState(false);
const toggle = () => setOpen(!isOpen);
return (
<div className={cssNames("MenuPicker", className, { waiting })}>
<Button primary id={id}>
{title}
<Icon material="arrow_drop_down"/>
</Button>
<Menu
htmlFor={id}
isOpen={isOpen} open={toggle} close={toggle}
closeOnClickItem={false}
{...menuProps}
>
<div className="menu-header flex gaps">
<span className="box grow">{title}</span>
<Icon small material="close" onClick={toggle}/>
</div>
{children}
</Menu>
</div>
)
}