import React from 'react'; import { Icon, Popup } from 'UI'; import styles from './itemMenu.module.css'; import OutsideClickDetectingDiv from 'Shared/OutsideClickDetectingDiv'; import cn from 'classnames'; export default class ItemMenu extends React.PureComponent { state = { displayed: false, }; handleEsc = (e) => e.key === 'Escape' && this.closeMenu() componentDidMount() { document.addEventListener("keydown", this.handleEsc, false); } componentWillUnmount() { document.removeEventListener("keydown", this.handleEsc, false); } onClick = callback => (e) => { e.stopPropagation(); callback(e); } toggleMenu = (e) => { this.setState({ displayed: !this.state.displayed }); } closeMenu = () => this.setState({ displayed: false }) render() { const { items, label = "", bold } = this.props; const { displayed } = this.state; const parentStyles = label ? 'rounded px-2 py-2 hover:bg-gray-light' : ''; return (