import React from 'react'; import { Icon, Popover, Tooltip } from 'UI'; import styles from './itemMenu.module.css'; import cn from 'classnames'; interface Item { icon?: string; text: string; onClick: (args: any) => void; hidden?: boolean; disabled?: boolean; tooltipTitle?: string; } interface Props { bold?: boolean; flat?: boolean; items: Item[]; label?: React.ReactNode; sm?: boolean; onToggle?: (args: any) => void; } export default class ItemMenu extends React.PureComponent { menuBtnRef: HTMLDivElement = null; state = { displayed: false, }; handleEsc = (e: KeyboardEvent) => e.key === 'Escape' && this.closeMenu(); componentDidMount() { document.addEventListener('keydown', this.handleEsc, false); } componentWillUnmount() { document.removeEventListener('keydown', this.handleEsc, false); } onClick = (callback: Function) => (e: React.MouseEvent) => { e.stopPropagation(); callback(e); }; toggleMenu = () => { const shouldDisplay = !this.state.displayed; this.setState({ displayed: shouldDisplay }); this.props.onToggle?.(shouldDisplay); }; closeMenu = () => { this.setState({ displayed: false }); this.props.onToggle?.(false); }; render() { const { items, label = '', bold, sm } = this.props; const { displayed } = this.state; const parentStyles = label ? 'rounded px-2 py-2 hover:bg-gray-light' : ''; return ( (
{items .filter(({ hidden }) => !hidden) .map(({ onClick, text, icon, disabled = false, tooltipTitle = '' }) => (
{}} className={disabled ? 'cursor-not-allowed' : ''} role="menuitem" >
{icon && (
{/* @ts-ignore */}
)}
{text}
))}
)} >
{label && ( {label} )} {this.props.flat ? null : (
{ this.menuBtnRef = ref; }} className={cn('rounded-full flex items-center justify-center', { 'bg-gray-light': displayed, 'w-10 h-10': !label && !sm, 'w-8 h-8': sm, })} role="button" >
)}
); } }