matrix-react-sdk
Version:
SDK for matrix.org using React
241 lines (238 loc) • 42.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _LegacyCallContextMenu = _interopRequireDefault(require("../../context_menus/LegacyCallContextMenu"));
var _DialpadContextMenu = _interopRequireDefault(require("../../context_menus/DialpadContextMenu"));
var _ContextMenu = require("../../../structures/ContextMenu");
var _languageHandler = require("../../../../languageHandler");
var _DeviceContextMenu = _interopRequireDefault(require("../../context_menus/DeviceContextMenu"));
var _MediaDeviceHandler = require("../../../../MediaDeviceHandler");
var _AccessibleButton = _interopRequireDefault(require("../../elements/AccessibleButton"));
const _excluded = ["children", "state", "className", "onLabel", "offLabel", "forceHide", "onHover"],
_excluded2 = ["state", "deviceKinds"];
/*
Copyright 2024 New Vector Ltd.
Copyright 2021 Šimon Brandner <simon.bra.ag@gmail.com>
Copyright 2019-2021 The Matrix.org Foundation C.I.C.
Copyright 2015, 2016 OpenMarket Ltd
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
// Height of the header duplicated from CSS because we need to subtract it from our max
// height to get the max height of the video
const CONTEXT_MENU_VPADDING = 8; // How far the context menu sits above the button (px)
const CONTROLS_HIDE_DELAY = 2000;
const LegacyCallViewToggleButton = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) => {
let {
children,
state: isOn,
className,
onLabel,
offLabel,
forceHide,
onHover
} = _ref,
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
const classes = (0, _classnames.default)("mx_LegacyCallViewButtons_button", className, {
mx_LegacyCallViewButtons_button_on: isOn,
mx_LegacyCallViewButtons_button_off: !isOn
});
const title = forceHide ? undefined : isOn ? onLabel : offLabel;
return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, (0, _extends2.default)({
ref: ref,
className: classes,
title: title,
placement: "top",
onTooltipOpenChange: onHover
}, props), children);
});
const LegacyCallViewDropdownButton = _ref2 => {
let {
state,
deviceKinds
} = _ref2,
props = (0, _objectWithoutProperties2.default)(_ref2, _excluded2);
const [menuDisplayed, buttonRef, openMenu, closeMenu] = (0, _ContextMenu.useContextMenu)();
const [hoveringDropdown, setHoveringDropdown] = (0, _react.useState)(false);
const classes = (0, _classnames.default)("mx_LegacyCallViewButtons_button", "mx_LegacyCallViewButtons_dropdownButton", {
mx_LegacyCallViewButtons_dropdownButton_collapsed: !menuDisplayed
});
const onClick = event => {
event.stopPropagation();
openMenu();
};
return /*#__PURE__*/_react.default.createElement(LegacyCallViewToggleButton, (0, _extends2.default)({
ref: buttonRef,
forceHide: menuDisplayed || hoveringDropdown,
state: state
}, props), /*#__PURE__*/_react.default.createElement(LegacyCallViewToggleButton, {
className: classes,
onClick: onClick,
onHover: hovering => setHoveringDropdown(hovering),
state: state
}), menuDisplayed && buttonRef.current && /*#__PURE__*/_react.default.createElement(_DeviceContextMenu.default, (0, _extends2.default)({}, (0, _ContextMenu.alwaysAboveRightOf)(buttonRef.current.getBoundingClientRect()), {
onFinished: closeMenu,
deviceKinds: deviceKinds
})));
};
class LegacyCallViewButtons extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "dialpadButton", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2.default)(this, "contextMenuButton", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2.default)(this, "controlsHideTimer", null);
(0, _defineProperty2.default)(this, "onControlsHideTimer", () => {
if (this.state.hoveringControls || this.state.showDialpad || this.state.showMoreMenu) return;
this.controlsHideTimer = null;
this.setState({
visible: false
});
});
(0, _defineProperty2.default)(this, "onMouseEnter", () => {
this.setState({
hoveringControls: true
});
});
(0, _defineProperty2.default)(this, "onMouseLeave", () => {
this.setState({
hoveringControls: false
});
});
(0, _defineProperty2.default)(this, "onDialpadClick", () => {
if (!this.state.showDialpad) {
this.setState({
showDialpad: true
});
this.showControls();
} else {
this.setState({
showDialpad: false
});
}
});
(0, _defineProperty2.default)(this, "onMoreClick", () => {
this.setState({
showMoreMenu: true
});
this.showControls();
});
(0, _defineProperty2.default)(this, "closeDialpad", () => {
this.setState({
showDialpad: false
});
});
(0, _defineProperty2.default)(this, "closeContextMenu", () => {
this.setState({
showMoreMenu: false
});
});
this.state = {
showDialpad: false,
hoveringControls: false,
showMoreMenu: false,
visible: true
};
}
componentDidMount() {
this.showControls();
}
showControls() {
if (this.state.showMoreMenu || this.state.showDialpad) return;
if (!this.state.visible) {
this.setState({
visible: true
});
}
if (this.controlsHideTimer !== null) {
clearTimeout(this.controlsHideTimer);
}
this.controlsHideTimer = window.setTimeout(this.onControlsHideTimer, CONTROLS_HIDE_DELAY);
}
render() {
const callControlsClasses = (0, _classnames.default)("mx_LegacyCallViewButtons", {
mx_LegacyCallViewButtons_hidden: !this.state.visible
});
let dialPad;
if (this.state.showDialpad && this.dialpadButton.current) {
dialPad = /*#__PURE__*/_react.default.createElement(_DialpadContextMenu.default, (0, _extends2.default)({}, (0, _ContextMenu.alwaysMenuProps)(this.dialpadButton.current.getBoundingClientRect(), _ContextMenu.ChevronFace.None, CONTEXT_MENU_VPADDING), {
// We mount the context menus as a child typically in order to include the
// context menus when fullscreening the call content.
// However, this does not work as well when the call is embedded in a
// picture-in-picture frame. Thus, only mount as child when we are *not* in PiP.
mountAsChild: !this.props.pipMode,
onFinished: this.closeDialpad,
call: this.props.call
}));
}
let contextMenu;
if (this.state.showMoreMenu && this.contextMenuButton.current) {
contextMenu = /*#__PURE__*/_react.default.createElement(_LegacyCallContextMenu.default, (0, _extends2.default)({}, (0, _ContextMenu.alwaysMenuProps)(this.contextMenuButton.current.getBoundingClientRect(), _ContextMenu.ChevronFace.None, CONTEXT_MENU_VPADDING), {
mountAsChild: !this.props.pipMode,
onFinished: this.closeContextMenu,
call: this.props.call
}));
}
return /*#__PURE__*/_react.default.createElement("div", {
className: callControlsClasses,
onMouseEnter: this.onMouseEnter,
onMouseLeave: this.onMouseLeave
}, dialPad, contextMenu, this.props.buttonsVisibility.dialpad && /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenuTooltipButton, {
className: "mx_LegacyCallViewButtons_button mx_LegacyCallViewButtons_dialpad",
ref: this.dialpadButton,
onClick: this.onDialpadClick,
isExpanded: this.state.showDialpad,
title: (0, _languageHandler._t)("voip|dialpad"),
placement: "top"
}), /*#__PURE__*/_react.default.createElement(LegacyCallViewDropdownButton, {
state: !this.props.buttonsState.micMuted,
className: "mx_LegacyCallViewButtons_button_mic",
onLabel: (0, _languageHandler._t)("voip|disable_microphone"),
offLabel: (0, _languageHandler._t)("voip|enable_microphone"),
onClick: this.props.handlers.onMicMuteClick,
deviceKinds: [_MediaDeviceHandler.MediaDeviceKindEnum.AudioInput, _MediaDeviceHandler.MediaDeviceKindEnum.AudioOutput]
}), this.props.buttonsVisibility.vidMute && /*#__PURE__*/_react.default.createElement(LegacyCallViewDropdownButton, {
state: !this.props.buttonsState.vidMuted,
className: "mx_LegacyCallViewButtons_button_vid",
onLabel: (0, _languageHandler._t)("voip|disable_camera"),
offLabel: (0, _languageHandler._t)("voip|enable_camera"),
onClick: this.props.handlers.onVidMuteClick,
deviceKinds: [_MediaDeviceHandler.MediaDeviceKindEnum.VideoInput]
}), this.props.buttonsVisibility.screensharing && /*#__PURE__*/_react.default.createElement(LegacyCallViewToggleButton, {
state: this.props.buttonsState.screensharing,
className: "mx_LegacyCallViewButtons_button_screensharing",
onLabel: (0, _languageHandler._t)("voip|stop_screenshare"),
offLabel: (0, _languageHandler._t)("voip|start_screenshare"),
onClick: this.props.handlers.onScreenshareClick
}), this.props.buttonsVisibility.sidebar && /*#__PURE__*/_react.default.createElement(LegacyCallViewToggleButton, {
state: this.props.buttonsState.sidebarShown,
className: "mx_LegacyCallViewButtons_button_sidebar",
onLabel: (0, _languageHandler._t)("voip|hide_sidebar_button"),
offLabel: (0, _languageHandler._t)("voip|show_sidebar_button"),
onClick: this.props.handlers.onToggleSidebarClick
}), this.props.buttonsVisibility.contextMenu && /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenuTooltipButton, {
className: "mx_LegacyCallViewButtons_button mx_LegacyCallViewButtons_button_more",
onClick: this.onMoreClick,
ref: this.contextMenuButton,
isExpanded: this.state.showMoreMenu,
title: (0, _languageHandler._t)("voip|more_button"),
placement: "top"
}), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_LegacyCallViewButtons_button mx_LegacyCallViewButtons_button_hangup",
onClick: this.props.handlers.onHangupClick,
title: (0, _languageHandler._t)("voip|hangup"),
placement: "top"
}));
}
}
exports.default = LegacyCallViewButtons;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_LegacyCallContextMenu","_DialpadContextMenu","_ContextMenu","_languageHandler","_DeviceContextMenu","_MediaDeviceHandler","_AccessibleButton","_excluded","_excluded2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","CONTEXT_MENU_VPADDING","CONTROLS_HIDE_DELAY","LegacyCallViewToggleButton","forwardRef","_ref","ref","children","state","isOn","className","onLabel","offLabel","forceHide","onHover","props","_objectWithoutProperties2","classes","classNames","mx_LegacyCallViewButtons_button_on","mx_LegacyCallViewButtons_button_off","title","undefined","createElement","_extends2","placement","onTooltipOpenChange","LegacyCallViewDropdownButton","_ref2","deviceKinds","menuDisplayed","buttonRef","openMenu","closeMenu","useContextMenu","hoveringDropdown","setHoveringDropdown","useState","mx_LegacyCallViewButtons_dropdownButton_collapsed","onClick","event","stopPropagation","hovering","current","alwaysAboveRightOf","getBoundingClientRect","onFinished","LegacyCallViewButtons","React","Component","constructor","_defineProperty2","createRef","hoveringControls","showDialpad","showMoreMenu","controlsHideTimer","setState","visible","showControls","componentDidMount","clearTimeout","window","setTimeout","onControlsHideTimer","render","callControlsClasses","mx_LegacyCallViewButtons_hidden","dialPad","dialpadButton","alwaysMenuProps","ChevronFace","None","mountAsChild","pipMode","closeDialpad","contextMenu","contextMenuButton","closeContextMenu","onMouseEnter","onMouseLeave","buttonsVisibility","dialpad","ContextMenuTooltipButton","onDialpadClick","isExpanded","_t","buttonsState","micMuted","handlers","onMicMuteClick","MediaDeviceKindEnum","AudioInput","AudioOutput","vidMute","vidMuted","onVidMuteClick","VideoInput","screensharing","onScreenshareClick","sidebar","sidebarShown","onToggleSidebarClick","onMoreClick","onHangupClick","exports"],"sources":["../../../../../src/components/views/voip/LegacyCallView/LegacyCallViewButtons.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 Šimon Brandner <simon.bra.ag@gmail.com>\nCopyright 2019-2021 The Matrix.org Foundation C.I.C.\nCopyright 2015, 2016 OpenMarket Ltd\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React, { createRef, useState, forwardRef } from \"react\";\nimport classNames from \"classnames\";\nimport { MatrixCall } from \"matrix-js-sdk/src/webrtc/call\";\n\nimport LegacyCallContextMenu from \"../../context_menus/LegacyCallContextMenu\";\nimport DialpadContextMenu from \"../../context_menus/DialpadContextMenu\";\nimport {\n    alwaysMenuProps,\n    alwaysAboveRightOf,\n    ChevronFace,\n    ContextMenuTooltipButton,\n    useContextMenu,\n} from \"../../../structures/ContextMenu\";\nimport { _t } from \"../../../../languageHandler\";\nimport DeviceContextMenu from \"../../context_menus/DeviceContextMenu\";\nimport { MediaDeviceKindEnum } from \"../../../../MediaDeviceHandler\";\nimport AccessibleButton, { ButtonEvent, ButtonProps as AccessibleButtonProps } from \"../../elements/AccessibleButton\";\n\n// Height of the header duplicated from CSS because we need to subtract it from our max\n// height to get the max height of the video\nconst CONTEXT_MENU_VPADDING = 8; // How far the context menu sits above the button (px)\n\nconst CONTROLS_HIDE_DELAY = 2000;\n\ntype ButtonProps = Omit<AccessibleButtonProps<\"div\">, \"title\" | \"element\"> & {\n    state: boolean;\n    onLabel?: string;\n    offLabel?: string;\n    forceHide?: boolean;\n    onHover?: (hovering: boolean) => void;\n};\n\nconst LegacyCallViewToggleButton = forwardRef<HTMLElement, ButtonProps>(\n    ({ children, state: isOn, className, onLabel, offLabel, forceHide, onHover, ...props }, ref) => {\n        const classes = classNames(\"mx_LegacyCallViewButtons_button\", className, {\n            mx_LegacyCallViewButtons_button_on: isOn,\n            mx_LegacyCallViewButtons_button_off: !isOn,\n        });\n\n        const title = forceHide ? undefined : isOn ? onLabel : offLabel;\n\n        return (\n            <AccessibleButton\n                ref={ref}\n                className={classes}\n                title={title}\n                placement=\"top\"\n                onTooltipOpenChange={onHover}\n                {...props}\n            >\n                {children}\n            </AccessibleButton>\n        );\n    },\n);\n\ninterface IDropdownButtonProps extends ButtonProps {\n    deviceKinds: MediaDeviceKindEnum[];\n}\n\nconst LegacyCallViewDropdownButton: React.FC<IDropdownButtonProps> = ({ state, deviceKinds, ...props }) => {\n    const [menuDisplayed, buttonRef, openMenu, closeMenu] = useContextMenu();\n    const [hoveringDropdown, setHoveringDropdown] = useState(false);\n\n    const classes = classNames(\"mx_LegacyCallViewButtons_button\", \"mx_LegacyCallViewButtons_dropdownButton\", {\n        mx_LegacyCallViewButtons_dropdownButton_collapsed: !menuDisplayed,\n    });\n\n    const onClick = (event: ButtonEvent): void => {\n        event.stopPropagation();\n        openMenu();\n    };\n\n    return (\n        <LegacyCallViewToggleButton\n            ref={buttonRef}\n            forceHide={menuDisplayed || hoveringDropdown}\n            state={state}\n            {...props}\n        >\n            <LegacyCallViewToggleButton\n                className={classes}\n                onClick={onClick}\n                onHover={(hovering) => setHoveringDropdown(hovering)}\n                state={state}\n            />\n            {menuDisplayed && buttonRef.current && (\n                <DeviceContextMenu\n                    {...alwaysAboveRightOf(buttonRef.current.getBoundingClientRect())}\n                    onFinished={closeMenu}\n                    deviceKinds={deviceKinds}\n                />\n            )}\n        </LegacyCallViewToggleButton>\n    );\n};\n\ninterface IProps {\n    call: MatrixCall;\n    pipMode?: boolean;\n    handlers: {\n        onHangupClick: () => void;\n        onScreenshareClick: () => void;\n        onToggleSidebarClick: () => void;\n        onMicMuteClick: () => void;\n        onVidMuteClick: () => void;\n    };\n    buttonsState: {\n        micMuted: boolean;\n        vidMuted: boolean;\n        sidebarShown: boolean;\n        screensharing: boolean;\n    };\n    buttonsVisibility: {\n        screensharing: boolean;\n        vidMute: boolean;\n        sidebar: boolean;\n        dialpad: boolean;\n        contextMenu: boolean;\n    };\n}\n\ninterface IState {\n    visible: boolean;\n    showDialpad: boolean;\n    hoveringControls: boolean;\n    showMoreMenu: boolean;\n}\n\nexport default class LegacyCallViewButtons extends React.Component<IProps, IState> {\n    private dialpadButton = createRef<HTMLDivElement>();\n    private contextMenuButton = createRef<HTMLDivElement>();\n    private controlsHideTimer: number | null = null;\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            showDialpad: false,\n            hoveringControls: false,\n            showMoreMenu: false,\n            visible: true,\n        };\n    }\n\n    public componentDidMount(): void {\n        this.showControls();\n    }\n\n    public showControls(): void {\n        if (this.state.showMoreMenu || this.state.showDialpad) return;\n\n        if (!this.state.visible) {\n            this.setState({\n                visible: true,\n            });\n        }\n        if (this.controlsHideTimer !== null) {\n            clearTimeout(this.controlsHideTimer);\n        }\n        this.controlsHideTimer = window.setTimeout(this.onControlsHideTimer, CONTROLS_HIDE_DELAY);\n    }\n\n    private onControlsHideTimer = (): void => {\n        if (this.state.hoveringControls || this.state.showDialpad || this.state.showMoreMenu) return;\n        this.controlsHideTimer = null;\n        this.setState({ visible: false });\n    };\n\n    private onMouseEnter = (): void => {\n        this.setState({ hoveringControls: true });\n    };\n\n    private onMouseLeave = (): void => {\n        this.setState({ hoveringControls: false });\n    };\n\n    private onDialpadClick = (): void => {\n        if (!this.state.showDialpad) {\n            this.setState({ showDialpad: true });\n            this.showControls();\n        } else {\n            this.setState({ showDialpad: false });\n        }\n    };\n\n    private onMoreClick = (): void => {\n        this.setState({ showMoreMenu: true });\n        this.showControls();\n    };\n\n    private closeDialpad = (): void => {\n        this.setState({ showDialpad: false });\n    };\n\n    private closeContextMenu = (): void => {\n        this.setState({ showMoreMenu: false });\n    };\n\n    public render(): React.ReactNode {\n        const callControlsClasses = classNames(\"mx_LegacyCallViewButtons\", {\n            mx_LegacyCallViewButtons_hidden: !this.state.visible,\n        });\n\n        let dialPad;\n        if (this.state.showDialpad && this.dialpadButton.current) {\n            dialPad = (\n                <DialpadContextMenu\n                    {...alwaysMenuProps(\n                        this.dialpadButton.current.getBoundingClientRect(),\n                        ChevronFace.None,\n                        CONTEXT_MENU_VPADDING,\n                    )}\n                    // We mount the context menus as a child typically in order to include the\n                    // context menus when fullscreening the call content.\n                    // However, this does not work as well when the call is embedded in a\n                    // picture-in-picture frame. Thus, only mount as child when we are *not* in PiP.\n                    mountAsChild={!this.props.pipMode}\n                    onFinished={this.closeDialpad}\n                    call={this.props.call}\n                />\n            );\n        }\n\n        let contextMenu;\n        if (this.state.showMoreMenu && this.contextMenuButton.current) {\n            contextMenu = (\n                <LegacyCallContextMenu\n                    {...alwaysMenuProps(\n                        this.contextMenuButton.current.getBoundingClientRect(),\n                        ChevronFace.None,\n                        CONTEXT_MENU_VPADDING,\n                    )}\n                    mountAsChild={!this.props.pipMode}\n                    onFinished={this.closeContextMenu}\n                    call={this.props.call}\n                />\n            );\n        }\n\n        return (\n            <div className={callControlsClasses} onMouseEnter={this.onMouseEnter} onMouseLeave={this.onMouseLeave}>\n                {dialPad}\n                {contextMenu}\n\n                {this.props.buttonsVisibility.dialpad && (\n                    <ContextMenuTooltipButton\n                        className=\"mx_LegacyCallViewButtons_button mx_LegacyCallViewButtons_dialpad\"\n                        ref={this.dialpadButton}\n                        onClick={this.onDialpadClick}\n                        isExpanded={this.state.showDialpad}\n                        title={_t(\"voip|dialpad\")}\n                        placement=\"top\"\n                    />\n                )}\n                <LegacyCallViewDropdownButton\n                    state={!this.props.buttonsState.micMuted}\n                    className=\"mx_LegacyCallViewButtons_button_mic\"\n                    onLabel={_t(\"voip|disable_microphone\")}\n                    offLabel={_t(\"voip|enable_microphone\")}\n                    onClick={this.props.handlers.onMicMuteClick}\n                    deviceKinds={[MediaDeviceKindEnum.AudioInput, MediaDeviceKindEnum.AudioOutput]}\n                />\n                {this.props.buttonsVisibility.vidMute && (\n                    <LegacyCallViewDropdownButton\n                        state={!this.props.buttonsState.vidMuted}\n                        className=\"mx_LegacyCallViewButtons_button_vid\"\n                        onLabel={_t(\"voip|disable_camera\")}\n                        offLabel={_t(\"voip|enable_camera\")}\n                        onClick={this.props.handlers.onVidMuteClick}\n                        deviceKinds={[MediaDeviceKindEnum.VideoInput]}\n                    />\n                )}\n                {this.props.buttonsVisibility.screensharing && (\n                    <LegacyCallViewToggleButton\n                        state={this.props.buttonsState.screensharing}\n                        className=\"mx_LegacyCallViewButtons_button_screensharing\"\n                        onLabel={_t(\"voip|stop_screenshare\")}\n                        offLabel={_t(\"voip|start_screenshare\")}\n                        onClick={this.props.handlers.onScreenshareClick}\n                    />\n                )}\n                {this.props.buttonsVisibility.sidebar && (\n                    <LegacyCallViewToggleButton\n                        state={this.props.buttonsState.sidebarShown}\n                        className=\"mx_LegacyCallViewButtons_button_sidebar\"\n                        onLabel={_t(\"voip|hide_sidebar_button\")}\n                        offLabel={_t(\"voip|show_sidebar_button\")}\n                        onClick={this.props.handlers.onToggleSidebarClick}\n                    />\n                )}\n                {this.props.buttonsVisibility.contextMenu && (\n                    <ContextMenuTooltipButton\n                        className=\"mx_LegacyCallViewButtons_button mx_LegacyCallViewButtons_button_more\"\n                        onClick={this.onMoreClick}\n                        ref={this.contextMenuButton}\n                        isExpanded={this.state.showMoreMenu}\n                        title={_t(\"voip|more_button\")}\n                        placement=\"top\"\n                    />\n                )}\n                <AccessibleButton\n                    className=\"mx_LegacyCallViewButtons_button mx_LegacyCallViewButtons_button_hangup\"\n                    onClick={this.props.handlers.onHangupClick}\n                    title={_t(\"voip|hangup\")}\n                    placement=\"top\"\n                />\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}