import React, { useState } from 'react'; import { defineMessages } from 'react-intl'; import PropTypes from 'prop-types'; import BBBMenu from '/imports/ui/components/common/menu/component'; import UserReactionService from '/imports/ui/components/user-reaction/service'; import { convertRemToPixels } from '/imports/utils/dom-utils'; import data from '@emoji-mart/data'; import withShortcutHelper from '/imports/ui/components/shortcut-help/service'; import { init } from 'emoji-mart'; import { SET_RAISE_HAND } from '/imports/ui/core/graphql/mutations/userMutations'; import { useMutation } from '@apollo/client'; import Styled from './styles'; const REACTIONS = Meteor.settings.public.userReaction.reactions; const ReactionsButton = (props) => { const { intl, actionsBarRef, userId, raiseHand, isMobile, shortcuts, currentUserReaction, autoCloseReactionsBar, } = props; // initialize emoji-mart data, need for the new version init({ data }); const [setRaiseHand] = useMutation(SET_RAISE_HAND); const [showEmojiPicker, setShowEmojiPicker] = useState(false); const intlMessages = defineMessages({ reactionsLabel: { id: 'app.actionsBar.reactions.reactionsButtonLabel', description: 'reactions Label', }, raiseHandLabel: { id: 'app.actionsBar.reactions.raiseHand', description: 'raise Hand Label', }, notRaiseHandLabel: { id: 'app.actionsBar.reactions.lowHand', description: 'not Raise Hand Label', }, }); const handleClose = () => { setShowEmojiPicker(false); setTimeout(() => { document.activeElement.blur(); }, 0); }; const handleReactionSelect = (reaction) => { const newReaction = currentUserReaction === reaction ? 'none' : reaction; UserReactionService.setUserReaction(newReaction); }; const handleRaiseHandButtonClick = () => { setRaiseHand({ variables: { userId, raiseHand: !raiseHand, }, }); }; const RaiseHandButtonLabel = () => { if (isMobile) return null; return raiseHand ? intl.formatMessage(intlMessages.notRaiseHandLabel) : intl.formatMessage(intlMessages.raiseHandLabel); }; const customStyles = { top: '-1rem', borderRadius: '1.7rem', }; const actionCustomStyles = { paddingLeft: 0, paddingRight: 0, paddingTop: isMobile ? '0' : '0.5rem', paddingBottom: isMobile ? '0' : '0.5rem', }; const emojiProps = { size: convertRemToPixels(1.5), padding: '4px', }; const handReaction = { id: 'hand', native: '✋', }; let actions = []; REACTIONS.forEach(({ id, native }) => { actions.push({ label: , key: id, onClick: () => handleReactionSelect(native), customStyles: actionCustomStyles, }); }); actions.push({ label: {RaiseHandButtonLabel()}, key: 'hand', onClick: () => handleRaiseHandButtonClick(), customStyles: {...actionCustomStyles, width: 'auto'}, }); const icon = !raiseHand && currentUserReaction === 'none' ? 'hand' : null; const currentUserReactionEmoji = REACTIONS.find(({ native }) => native === currentUserReaction); let customIcon = null; if (raiseHand) { customIcon = ; } else { if (!icon) { customIcon = ; } } return ( {}} onClick={() => setShowEmojiPicker(true)} color={showEmojiPicker || customIcon ? 'primary' : 'default'} hideLabel circle size="lg" /> )} actions={actions} onCloseCallback={() => handleClose()} customAnchorEl={!isMobile ? actionsBarRef.current : null} customStyles={customStyles} open={showEmojiPicker} hasRoundedCorners overrideMobileStyles isHorizontal={!isMobile} isMobile={isMobile} roundButtons={true} keepOpen={!autoCloseReactionsBar} opts={{ id: 'reactions-dropdown-menu', keepMounted: true, transitionDuration: 0, elevation: 3, getcontentanchorel: null, anchorOrigin: { vertical: 'top', horizontal: 'center' }, transformOrigin: { vertical: 'bottom', horizontal: 'center' }, }} /> ); }; const propTypes = { intl: PropTypes.shape({ formatMessage: PropTypes.func.isRequired, }).isRequired, userId: PropTypes.string.isRequired, emoji: PropTypes.string.isRequired, sidebarContentPanel: PropTypes.string.isRequired, layoutContextDispatch: PropTypes.func.isRequired, }; ReactionsButton.propTypes = propTypes; export default withShortcutHelper(ReactionsButton, ['raiseHand']);