import React, { PureComponent } from 'react'; import { defineMessages, injectIntl } from 'react-intl'; import BBBMenu from "/imports/ui/components/common/menu/component"; import CreateBreakoutRoomContainer from '/imports/ui/components/actions-bar/create-breakout-room/container'; import Trigger from "/imports/ui/components/common/control-header/right/component"; const intlMessages = defineMessages({ options: { id: 'app.breakout.dropdown.options', description: 'Breakout options label', }, manageDuration: { id: 'app.breakout.dropdown.manageDuration', description: 'Manage duration label', }, manageUsers: { id: 'app.breakout.dropdown.manageUsers', description: 'Manage users label', }, destroy: { id: 'app.breakout.dropdown.destroyAll', description: 'Destroy breakouts label', }, }); class BreakoutDropdown extends PureComponent { constructor(props) { super(props); this.state = { isCreateBreakoutRoomModalOpen: false, }; this.setCreateBreakoutRoomModalIsOpen = this.setCreateBreakoutRoomModalIsOpen.bind(this); } getAvailableActions() { const { intl, openBreakoutTimeManager, endAllBreakouts, isMeteorConnected, amIModerator, } = this.props; this.menuItems = []; this.menuItems.push( { key: 'breakoutTimeManager', dataTest: 'openBreakoutTimeManager', label: intl.formatMessage(intlMessages.manageDuration), onClick: () => { openBreakoutTimeManager(); } } ); this.menuItems.push( { key: 'updateBreakoutUsers', dataTest: 'openUpdateBreakoutUsersModal', label: intl.formatMessage(intlMessages.manageUsers), onClick: () => { this.setCreateBreakoutRoomModalIsOpen(true); } } ); if (amIModerator) { this.menuItems.push( { key: 'endAllBreakouts', dataTest: 'endAllBreakouts', label: intl.formatMessage(intlMessages.destroy), disabled: !isMeteorConnected, onClick: () => { endAllBreakouts(); } } ); } return this.menuItems; } setCreateBreakoutRoomModalIsOpen(value) { this.setState({ isCreateBreakoutRoomModalOpen: value, }); } render() { const { intl, isRTL, } = this.props; const { isCreateBreakoutRoomModalOpen } = this.state; return ( <> null} /> } opts={{ id: "breakoutroom-dropdown-menu", keepMounted: true, transitionDuration: 0, elevation: 3, getcontentanchorel: null, fullwidth: "true", anchorOrigin: { vertical: 'bottom', horizontal: isRTL ? 'right' : 'left' }, transformOrigin: { vertical: 'top', horizontal: isRTL ? 'right' : 'left' }, }} actions={this.getAvailableActions()} /> {isCreateBreakoutRoomModalOpen ? this.setCreateBreakoutRoomModalIsOpen(false), priority: "low", setIsOpen: this.setCreateBreakoutRoomModalIsOpen, isOpen: isCreateBreakoutRoomModalOpen }} /> : null} ); } } export default injectIntl(BreakoutDropdown);