diff --git a/src/components/structures/ContextMenu.js b/src/components/structures/ContextMenu.js index 455deb4708..bda19432a8 100644 --- a/src/components/structures/ContextMenu.js +++ b/src/components/structures/ContextMenu.js @@ -70,10 +70,13 @@ export class ContextMenu extends React.Component { // on resize callback windowResize: PropTypes.func, + + catchTab: PropTypes.bool, // whether to close the ContextMenu on TAB (default=true) }; static defaultProps = { hasBackground: true, + catchTab: true, }; constructor() { @@ -187,6 +190,11 @@ export class ContextMenu extends React.Component { switch (ev.key) { case Key.TAB: + if (!this.props.catchTab) { + handled = false; + break; + } + // fallthrough case Key.ESCAPE: this.props.onFinished(); break; diff --git a/src/components/views/messages/MessageActionBar.js b/src/components/views/messages/MessageActionBar.js index 5a12717762..81e806cf62 100644 --- a/src/components/views/messages/MessageActionBar.js +++ b/src/components/views/messages/MessageActionBar.js @@ -78,14 +78,17 @@ const OptionsButton = ({mxEvent, getTile, getReplyThread, permalinkCreator, onFo ; }; -const ReactButton = ({mxEvent, reactions}) => { +const ReactButton = ({mxEvent, reactions, onFocusChange}) => { const [menuDisplayed, button, openMenu, closeMenu] = useContextMenu(); + useEffect(() => { + onFocusChange(menuDisplayed); + }, [onFocusChange, menuDisplayed]); let contextMenu; if (menuDisplayed) { const buttonRect = button.current.getBoundingClientRect(); const ReactionPicker = sdk.getComponent('emojipicker.ReactionPicker'); - contextMenu = + contextMenu = ; } @@ -162,7 +165,9 @@ export default class MessageActionBar extends React.PureComponent { if (isContentActionable(this.props.mxEvent)) { if (this.context.room.canReact) { - reactButton = ; + reactButton = ( + + ); } if (this.context.room.canReply) { replyButton =