import React from "react"; import PropTypes from "prop-types"; import { defineMessages, injectIntl } from "react-intl"; import Menu from "@material-ui/core/Menu"; import MenuItem from "@material-ui/core/MenuItem"; import { Divider } from "@material-ui/core"; import Icon from "/imports/ui/components/icon/component"; import Button from "/imports/ui/components/button/component"; import { ENTER, SPACE } from "/imports/utils/keyCodes"; import { styles } from "./styles"; const intlMessages = defineMessages({ close: { id: 'app.dropdown.close', description: 'Close button label', }, }); //Used to switch to mobile view const MAX_WIDTH = 640; class BBBMenu extends React.Component { constructor(props) { super(props); this.state = { anchorEl: null, }; this.opts = props.opts; this.autoFocus = false; this.handleClick = this.handleClick.bind(this); this.handleClose = this.handleClose.bind(this); } handleClick(event) { this.setState({ anchorEl: event.currentTarget }); }; handleClose(event) { const { onCloseCallback } = this.props; this.setState({ anchorEl: null }, onCloseCallback()); if (event) { event.persist(); if (event.type === 'click') { setTimeout(() => { document.activeElement.blur(); }, 0); } } }; makeMenuItems() { const { actions, selectedEmoji } = this.props; return actions?.map(a => { const { dataTest, label, onClick, key, disabled } = a; const itemClasses = [styles.menuitem, a?.className]; if (key?.toLowerCase()?.includes(selectedEmoji?.toLowerCase())) itemClasses.push(styles.emojiSelected); return [ a.dividerTop && , { onClick(); const close = !key.includes('setstatus') && !key.includes('back'); // prevent menu close for sub menu actions if (close) this.handleClose(event); }}>
{a.icon ? : null}
{label}
{a.iconRight ? : null}
, a.divider && ]; }); } render() { const { anchorEl } = this.state; const { trigger, intl, wide, classes } = this.props; const actionsItems = this.makeMenuItems(); const menuClasses = classes || []; menuClasses.push(styles.menu); if (wide) menuClasses.push(styles.wide); return ( <>
{ e.persist(); this.opts.autoFocus = !(['mouse', 'touch'].includes(e.nativeEvent.pointerType)); this.handleClick(e); }} onKeyPress={(e) => { e.persist(); if (e.which !== ENTER) return null; this.handleClick(e); }} accessKey={this.props?.accessKey} > {trigger}
{actionsItems} {anchorEl && window.innerWidth < MAX_WIDTH && ); } } export default injectIntl(BBBMenu); BBBMenu.defaultProps = { opts: { id: "default-dropdown-menu", autoFocus: false, keepMounted: true, transitionDuration: 0, elevation: 3, getContentAnchorEl: null, fullwidth: "true", anchorOrigin: { vertical: 'top', horizontal: 'right' }, transformorigin: { vertical: 'top', horizontal: 'right' }, }, onCloseCallback: () => { }, wide: false, }; BBBMenu.propTypes = { intl: PropTypes.shape({ formatMessage: PropTypes.func.isRequired, }).isRequired, trigger: PropTypes.element.isRequired, actions: PropTypes.arrayOf(PropTypes.shape({ key: PropTypes.string.isRequired, label: PropTypes.string.isRequired, onClick: PropTypes.func, icon: PropTypes.string, iconRight: PropTypes.string, disabled: PropTypes.bool, divider: PropTypes.bool, dividerTop: PropTypes.bool, accessKey: PropTypes.string, })).isRequired, onCloseCallback: PropTypes.func, wide: PropTypes.bool, };