UNPKG

matrix-react-sdk

Version:
695 lines (603 loc) 92.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _CallHandler = _interopRequireDefault(require("../../../CallHandler")); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _languageHandler = require("../../../languageHandler"); var _VideoFeed = _interopRequireDefault(require("./VideoFeed")); var _RoomAvatar = _interopRequireDefault(require("../avatars/RoomAvatar")); var _call = require("matrix-js-sdk/src/webrtc/call"); var _classnames = _interopRequireDefault(require("classnames")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _Keyboard = require("../../../Keyboard"); var _ContextMenu = require("../../structures/ContextMenu"); var _CallContextMenu = _interopRequireDefault(require("../context_menus/CallContextMenu")); var _Avatar = require("../../../Avatar"); var _DialpadContextMenu = _interopRequireDefault(require("../context_menus/DialpadContextMenu")); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _temp; function getFullScreenElement() { return document.fullscreenElement || // moz omitted because firefox supports this unprefixed now (webkit here for safari) document.webkitFullscreenElement || document.msFullscreenElement; } function requestFullscreen(element /*: Element*/ ) { const method = element.requestFullscreen || // moz omitted since firefox supports unprefixed now element.webkitRequestFullScreen || element.msRequestFullscreen; if (method) method.call(element); } function exitFullscreen() { const exitMethod = document.exitFullscreen || document.webkitExitFullscreen || document.msExitFullscreen; if (exitMethod) exitMethod.call(document); } const CONTROLS_HIDE_DELAY = 1000; // 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) let CallView = (_dec = (0, _replaceableComponent.replaceableComponent)("views.voip.CallView"), _dec(_class = (_temp = class CallView extends _react.default.Component /*:: <IProps, IState>*/ { constructor(props /*: IProps*/ ) { super(props); (0, _defineProperty2.default)(this, "dispatcherRef", void 0); (0, _defineProperty2.default)(this, "contentRef", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2.default)(this, "controlsHideTimer", null); (0, _defineProperty2.default)(this, "dialpadButton", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2.default)(this, "contextMenuButton", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2.default)(this, "onAction", payload => { switch (payload.action) { case 'video_fullscreen': { if (!this.contentRef.current) { return; } if (payload.fullscreen) { requestFullscreen(this.contentRef.current); } else if (getFullScreenElement()) { exitFullscreen(); } break; } } }); (0, _defineProperty2.default)(this, "onCallState", state => { this.setState({ callState: state }); }); (0, _defineProperty2.default)(this, "onFeedsChanged", (newFeeds /*: Array<CallFeed>*/ ) => { this.setState({ feeds: newFeeds }); }); (0, _defineProperty2.default)(this, "onCallLocalHoldUnhold", () => { this.setState({ isLocalOnHold: this.props.call.isLocalOnHold() }); }); (0, _defineProperty2.default)(this, "onCallRemoteHoldUnhold", () => { this.setState({ isRemoteOnHold: this.props.call.isRemoteOnHold(), // update both here because isLocalOnHold changes when we hold the call too isLocalOnHold: this.props.call.isLocalOnHold() }); }); (0, _defineProperty2.default)(this, "onFullscreenClick", () => { _dispatcher.default.dispatch({ action: 'video_fullscreen', fullscreen: true }); }); (0, _defineProperty2.default)(this, "onExpandClick", () => { const userFacingRoomId = _CallHandler.default.sharedInstance().roomIdForCall(this.props.call); _dispatcher.default.dispatch({ action: 'view_room', room_id: userFacingRoomId }); }); (0, _defineProperty2.default)(this, "onControlsHideTimer", () => { this.controlsHideTimer = null; this.setState({ controlsVisible: false }); }); (0, _defineProperty2.default)(this, "onMouseMove", () => { this.showControls(); }); (0, _defineProperty2.default)(this, "onDialpadClick", () => { if (!this.state.showDialpad) { if (this.controlsHideTimer) { clearTimeout(this.controlsHideTimer); this.controlsHideTimer = null; } this.setState({ showDialpad: true, controlsVisible: true }); } else { if (this.controlsHideTimer !== null) { clearTimeout(this.controlsHideTimer); } this.controlsHideTimer = window.setTimeout(this.onControlsHideTimer, CONTROLS_HIDE_DELAY); this.setState({ showDialpad: false }); } }); (0, _defineProperty2.default)(this, "onMicMuteClick", () => { const newVal = !this.state.micMuted; this.props.call.setMicrophoneMuted(newVal); this.setState({ micMuted: newVal }); }); (0, _defineProperty2.default)(this, "onVidMuteClick", () => { const newVal = !this.state.vidMuted; this.props.call.setLocalVideoMuted(newVal); this.setState({ vidMuted: newVal }); }); (0, _defineProperty2.default)(this, "onMoreClick", () => { if (this.controlsHideTimer) { clearTimeout(this.controlsHideTimer); this.controlsHideTimer = null; } this.setState({ showMoreMenu: true, controlsVisible: true }); }); (0, _defineProperty2.default)(this, "closeDialpad", () => { this.setState({ showDialpad: false }); this.controlsHideTimer = window.setTimeout(this.onControlsHideTimer, CONTROLS_HIDE_DELAY); }); (0, _defineProperty2.default)(this, "closeContextMenu", () => { this.setState({ showMoreMenu: false }); this.controlsHideTimer = window.setTimeout(this.onControlsHideTimer, CONTROLS_HIDE_DELAY); }); (0, _defineProperty2.default)(this, "onNativeKeyDown", ev => { let handled = false; const ctrlCmdOnly = (0, _Keyboard.isOnlyCtrlOrCmdKeyEvent)(ev); switch (ev.key) { case _Keyboard.Key.D: if (ctrlCmdOnly) { this.onMicMuteClick(); // show the controls to give feedback this.showControls(); handled = true; } break; case _Keyboard.Key.E: if (ctrlCmdOnly) { this.onVidMuteClick(); // show the controls to give feedback this.showControls(); handled = true; } break; } if (handled) { ev.stopPropagation(); ev.preventDefault(); } }); (0, _defineProperty2.default)(this, "onRoomAvatarClick", () => { const userFacingRoomId = _CallHandler.default.sharedInstance().roomIdForCall(this.props.call); _dispatcher.default.dispatch({ action: 'view_room', room_id: userFacingRoomId }); }); (0, _defineProperty2.default)(this, "onSecondaryRoomAvatarClick", () => { const userFacingRoomId = _CallHandler.default.sharedInstance().roomIdForCall(this.props.secondaryCall); _dispatcher.default.dispatch({ action: 'view_room', room_id: userFacingRoomId }); }); (0, _defineProperty2.default)(this, "onCallResumeClick", () => { const userFacingRoomId = _CallHandler.default.sharedInstance().roomIdForCall(this.props.call); _CallHandler.default.sharedInstance().setActiveCallRoomId(userFacingRoomId); }); (0, _defineProperty2.default)(this, "onTransferClick", () => { const transfereeCall = _CallHandler.default.sharedInstance().getTransfereeForCallId(this.props.call.callId); this.props.call.transferToCall(transfereeCall); }); this.state = { isLocalOnHold: this.props.call.isLocalOnHold(), isRemoteOnHold: this.props.call.isRemoteOnHold(), micMuted: this.props.call.isMicrophoneMuted(), vidMuted: this.props.call.isLocalVideoMuted(), callState: this.props.call.state, controlsVisible: true, showMoreMenu: false, showDialpad: false, feeds: this.props.call.getFeeds() }; this.updateCallListeners(null, this.props.call); } componentDidMount() { this.dispatcherRef = _dispatcher.default.register(this.onAction); document.addEventListener('keydown', this.onNativeKeyDown); } componentWillUnmount() { if (getFullScreenElement()) { exitFullscreen(); } document.removeEventListener("keydown", this.onNativeKeyDown); this.updateCallListeners(this.props.call, null); _dispatcher.default.unregister(this.dispatcherRef); } componentDidUpdate(prevProps) { if (this.props.call === prevProps.call) return; this.setState({ isLocalOnHold: this.props.call.isLocalOnHold(), isRemoteOnHold: this.props.call.isRemoteOnHold(), micMuted: this.props.call.isMicrophoneMuted(), vidMuted: this.props.call.isLocalVideoMuted(), callState: this.props.call.state }); this.updateCallListeners(null, this.props.call); } updateCallListeners(oldCall /*: MatrixCall*/ , newCall /*: MatrixCall*/ ) { if (oldCall === newCall) return; if (oldCall) { oldCall.removeListener(_call.CallEvent.State, this.onCallState); oldCall.removeListener(_call.CallEvent.LocalHoldUnhold, this.onCallLocalHoldUnhold); oldCall.removeListener(_call.CallEvent.RemoteHoldUnhold, this.onCallRemoteHoldUnhold); oldCall.removeListener(_call.CallEvent.FeedsChanged, this.onFeedsChanged); } if (newCall) { newCall.on(_call.CallEvent.State, this.onCallState); newCall.on(_call.CallEvent.LocalHoldUnhold, this.onCallLocalHoldUnhold); newCall.on(_call.CallEvent.RemoteHoldUnhold, this.onCallRemoteHoldUnhold); newCall.on(_call.CallEvent.FeedsChanged, this.onFeedsChanged); } } showControls() { if (this.state.showMoreMenu || this.state.showDialpad) return; if (!this.state.controlsVisible) { this.setState({ controlsVisible: true }); } if (this.controlsHideTimer !== null) { clearTimeout(this.controlsHideTimer); } this.controlsHideTimer = window.setTimeout(this.onControlsHideTimer, CONTROLS_HIDE_DELAY); } render() { const client = _MatrixClientPeg.MatrixClientPeg.get(); const callRoomId = _CallHandler.default.sharedInstance().roomIdForCall(this.props.call); const secondaryCallRoomId = _CallHandler.default.sharedInstance().roomIdForCall(this.props.secondaryCall); const callRoom = client.getRoom(callRoomId); const secCallRoom = this.props.secondaryCall ? client.getRoom(secondaryCallRoomId) : null; let dialPad; let contextMenu; if (this.state.showDialpad) { dialPad = /*#__PURE__*/_react.default.createElement(_DialpadContextMenu.default, (0, _extends2.default)({}, (0, _ContextMenu.alwaysAboveRightOf)(this.dialpadButton.current.getBoundingClientRect(), _ContextMenu.ChevronFace.None, CONTEXT_MENU_VPADDING), { onFinished: this.closeDialpad, call: this.props.call })); } if (this.state.showMoreMenu) { contextMenu = /*#__PURE__*/_react.default.createElement(_CallContextMenu.default, (0, _extends2.default)({}, (0, _ContextMenu.alwaysAboveLeftOf)(this.contextMenuButton.current.getBoundingClientRect(), _ContextMenu.ChevronFace.None, CONTEXT_MENU_VPADDING), { onFinished: this.closeContextMenu, call: this.props.call })); } const micClasses = (0, _classnames.default)({ mx_CallView_callControls_button: true, mx_CallView_callControls_button_micOn: !this.state.micMuted, mx_CallView_callControls_button_micOff: this.state.micMuted }); const vidClasses = (0, _classnames.default)({ mx_CallView_callControls_button: true, mx_CallView_callControls_button_vidOn: !this.state.vidMuted, mx_CallView_callControls_button_vidOff: this.state.vidMuted }); // Put the other states of the mic/video icons in the document to make sure they're cached // (otherwise the icon disappears briefly when toggled) const micCacheClasses = (0, _classnames.default)({ mx_CallView_callControls_button: true, mx_CallView_callControls_button_micOn: this.state.micMuted, mx_CallView_callControls_button_micOff: !this.state.micMuted, mx_CallView_callControls_button_invisible: true }); const vidCacheClasses = (0, _classnames.default)({ mx_CallView_callControls_button: true, mx_CallView_callControls_button_vidOn: this.state.micMuted, mx_CallView_callControls_button_vidOff: !this.state.micMuted, mx_CallView_callControls_button_invisible: true }); const callControlsClasses = (0, _classnames.default)({ mx_CallView_callControls: true, mx_CallView_callControls_hidden: !this.state.controlsVisible }); const vidMuteButton = this.props.call.type === _call.CallType.Video ? /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: vidClasses, onClick: this.onVidMuteClick }) : null; // The dial pad & 'more' button actions are only relevant in a connected call // When not connected, we have to put something there to make the flexbox alignment correct const dialpadButton = this.state.callState === _call.CallState.Connected ? /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenuButton, { className: "mx_CallView_callControls_button mx_CallView_callControls_dialpad", inputRef: this.dialpadButton, onClick: this.onDialpadClick, isExpanded: this.state.showDialpad }) : /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_callControls_button mx_CallView_callControls_button_dialpad_hidden" }); const contextMenuButton = this.state.callState === _call.CallState.Connected ? /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenuButton, { className: "mx_CallView_callControls_button mx_CallView_callControls_button_more", onClick: this.onMoreClick, inputRef: this.contextMenuButton, isExpanded: this.state.showMoreMenu }) : /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_callControls_button mx_CallView_callControls_button_more_hidden" }); // in the near future, the dial pad button will go on the left. For now, it's the nothing button // because something needs to have margin-right: auto to make the alignment correct. const callControls = /*#__PURE__*/_react.default.createElement("div", { className: callControlsClasses }, dialpadButton, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: micClasses, onClick: this.onMicMuteClick }), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_CallView_callControls_button mx_CallView_callControls_button_hangup", onClick: () => { _dispatcher.default.dispatch({ action: 'hangup', room_id: callRoomId }); } }), vidMuteButton, /*#__PURE__*/_react.default.createElement("div", { className: micCacheClasses }), /*#__PURE__*/_react.default.createElement("div", { className: vidCacheClasses }), contextMenuButton); const avatarSize = this.props.pipMode ? 76 : 160; // The 'content' for the call, ie. the videos for a video call and profile picture // for voice calls (fills the bg) let contentView /*: React.ReactNode*/ ; const transfereeCall = _CallHandler.default.sharedInstance().getTransfereeForCallId(this.props.call.callId); const isOnHold = this.state.isLocalOnHold || this.state.isRemoteOnHold; let holdTransferContent; if (transfereeCall) { const transferTargetRoom = _MatrixClientPeg.MatrixClientPeg.get().getRoom(_CallHandler.default.sharedInstance().roomIdForCall(this.props.call)); const transferTargetName = transferTargetRoom ? transferTargetRoom.name : (0, _languageHandler._t)("unknown person"); const transfereeRoom = _MatrixClientPeg.MatrixClientPeg.get().getRoom(_CallHandler.default.sharedInstance().roomIdForCall(transfereeCall)); const transfereeName = transfereeRoom ? transfereeRoom.name : (0, _languageHandler._t)("unknown person"); holdTransferContent = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_holdTransferContent" }, (0, _languageHandler._t)("Consulting with %(transferTarget)s. <a>Transfer to %(transferee)s</a>", { transferTarget: transferTargetName, transferee: transfereeName }, { a: sub => /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "link", onClick: this.onTransferClick }, sub) })); } else if (isOnHold) { let onHoldText = null; if (this.state.isRemoteOnHold) { const holdString = _CallHandler.default.sharedInstance().hasAnyUnheldCall() ? (0, _languageHandler._td)("You held the call <a>Switch</a>") : (0, _languageHandler._td)("You held the call <a>Resume</a>"); onHoldText = (0, _languageHandler._t)(holdString, {}, { a: sub => /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "link", onClick: this.onCallResumeClick }, sub) }); } else if (this.state.isLocalOnHold) { onHoldText = (0, _languageHandler._t)("%(peerName)s held the call", { peerName: this.props.call.getOpponentMember().name }); } holdTransferContent = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_holdTransferContent" }, onHoldText); } // This is a bit messy. I can't see a reason to have two onHold/transfer screens if (isOnHold || transfereeCall) { if (this.props.call.type === _call.CallType.Video) { const containerClasses = (0, _classnames.default)({ mx_CallView_content: true, mx_CallView_video: true, mx_CallView_video_hold: isOnHold }); let onHoldBackground = null; const backgroundStyle /*: CSSProperties*/ = {}; const backgroundAvatarUrl = (0, _Avatar.avatarUrlForMember)( // is it worth getting the size of the div to pass here? this.props.call.getOpponentMember(), 1024, 1024, 'crop'); backgroundStyle.backgroundImage = 'url(' + backgroundAvatarUrl + ')'; onHoldBackground = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_video_holdBackground", style: backgroundStyle }); contentView = /*#__PURE__*/_react.default.createElement("div", { className: containerClasses, ref: this.contentRef, onMouseMove: this.onMouseMove }, onHoldBackground, holdTransferContent, callControls); } else { const classes = (0, _classnames.default)({ mx_CallView_content: true, mx_CallView_voice: true, mx_CallView_voice_hold: isOnHold }); contentView = /*#__PURE__*/_react.default.createElement("div", { className: classes, onMouseMove: this.onMouseMove }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_voice_avatarsContainer" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_voice_avatarContainer", style: { width: avatarSize, height: avatarSize } }, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, { room: callRoom, height: avatarSize, width: avatarSize }))), holdTransferContent, callControls); } } else if (this.props.call.noIncomingFeeds()) { // Here we're reusing the css classes from voice on hold, because // I am lazy. If this gets merged, the CallView might be subject // to change anyway - I might take an axe to this file in order to // try to get other things working const classes = (0, _classnames.default)({ mx_CallView_content: true, mx_CallView_voice: true }); const feeds = this.props.call.getLocalFeeds().map((feed, i) => { // Here we check to hide local audio feeds to achieve the same UI/UX // as before. But once again this might be subject to change if (feed.isVideoMuted()) return; return /*#__PURE__*/_react.default.createElement(_VideoFeed.default, { key: i, feed: feed, call: this.props.call, pipMode: this.props.pipMode, onResize: this.props.onResize }); }); // Saying "Connecting" here isn't really true, but the best thing // I can come up with, but this might be subject to change as well contentView = /*#__PURE__*/_react.default.createElement("div", { className: classes, onMouseMove: this.onMouseMove }, feeds, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_voice_avatarsContainer" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_voice_avatarContainer", style: { width: avatarSize, height: avatarSize } }, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, { room: callRoom, height: avatarSize, width: avatarSize }))), /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_holdTransferContent" }, (0, _languageHandler._t)("Connecting")), callControls); } else { const containerClasses = (0, _classnames.default)({ mx_CallView_content: true, mx_CallView_video: true }); // TODO: Later the CallView should probably be reworked to support // any number of feeds but now we can always expect there to be two // feeds. This is because the js-sdk ignores any new incoming streams const feeds = this.state.feeds.map((feed, i) => { // Here we check to hide local audio feeds to achieve the same UI/UX // as before. But once again this might be subject to change if (feed.isVideoMuted() && feed.isLocal()) return; return /*#__PURE__*/_react.default.createElement(_VideoFeed.default, { key: i, feed: feed, call: this.props.call, pipMode: this.props.pipMode, onResize: this.props.onResize }); }); contentView = /*#__PURE__*/_react.default.createElement("div", { className: containerClasses, ref: this.contentRef, onMouseMove: this.onMouseMove }, feeds, callControls); } const callTypeText = this.props.call.type === _call.CallType.Video ? (0, _languageHandler._t)("Video Call") : (0, _languageHandler._t)("Voice Call"); let myClassName; let fullScreenButton; if (this.props.call.type === _call.CallType.Video && !this.props.pipMode) { fullScreenButton = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header_button mx_CallView_header_button_fullscreen", onClick: this.onFullscreenClick, title: (0, _languageHandler._t)("Fill Screen") }); } let expandButton; if (this.props.pipMode) { expandButton = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header_button mx_CallView_header_button_expand", onClick: this.onExpandClick, title: (0, _languageHandler._t)("Return to call") }); } const headerControls = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header_controls" }, fullScreenButton, expandButton); let header /*: React.ReactNode*/ ; if (!this.props.pipMode) { header = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header_phoneIcon" }), /*#__PURE__*/_react.default.createElement("span", { className: "mx_CallView_header_callType" }, callTypeText), headerControls); myClassName = 'mx_CallView_large'; } else { let secondaryCallInfo; if (this.props.secondaryCall) { secondaryCallInfo = /*#__PURE__*/_react.default.createElement("span", { className: "mx_CallView_header_secondaryCallInfo" }, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { element: "span", onClick: this.onSecondaryRoomAvatarClick }, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, { room: secCallRoom, height: 16, width: 16 }), /*#__PURE__*/_react.default.createElement("span", { className: "mx_CallView_secondaryCall_roomName" }, (0, _languageHandler._t)("%(name)s on hold", { name: secCallRoom.name })))); } header = /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header" }, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onRoomAvatarClick }, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, { room: callRoom, height: 32, width: 32 })), /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header_callInfo" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header_roomName" }, callRoom.name), /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView_header_callTypeSmall" }, callTypeText, secondaryCallInfo)), headerControls); myClassName = 'mx_CallView_pip'; } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_CallView " + myClassName }, header, contentView, dialPad, contextMenu); } }, _temp)) || _class); exports.default = CallView; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/voip/CallView.tsx"],"names":["getFullScreenElement","document","fullscreenElement","webkitFullscreenElement","msFullscreenElement","requestFullscreen","element","method","webkitRequestFullScreen","msRequestFullscreen","call","exitFullscreen","exitMethod","webkitExitFullscreen","msExitFullscreen","CONTROLS_HIDE_DELAY","CONTEXT_MENU_VPADDING","CallView","React","Component","constructor","props","payload","action","contentRef","current","fullscreen","state","setState","callState","newFeeds","feeds","isLocalOnHold","isRemoteOnHold","dis","dispatch","userFacingRoomId","CallHandler","sharedInstance","roomIdForCall","room_id","controlsHideTimer","controlsVisible","showControls","showDialpad","clearTimeout","window","setTimeout","onControlsHideTimer","newVal","micMuted","setMicrophoneMuted","vidMuted","setLocalVideoMuted","showMoreMenu","ev","handled","ctrlCmdOnly","key","Key","D","onMicMuteClick","E","onVidMuteClick","stopPropagation","preventDefault","secondaryCall","setActiveCallRoomId","transfereeCall","getTransfereeForCallId","callId","transferToCall","isMicrophoneMuted","isLocalVideoMuted","getFeeds","updateCallListeners","componentDidMount","dispatcherRef","register","onAction","addEventListener","onNativeKeyDown","componentWillUnmount","removeEventListener","unregister","componentDidUpdate","prevProps","oldCall","newCall","removeListener","CallEvent","State","onCallState","LocalHoldUnhold","onCallLocalHoldUnhold","RemoteHoldUnhold","onCallRemoteHoldUnhold","FeedsChanged","onFeedsChanged","on","render","client","MatrixClientPeg","get","callRoomId","secondaryCallRoomId","callRoom","getRoom","secCallRoom","dialPad","contextMenu","dialpadButton","getBoundingClientRect","ChevronFace","None","closeDialpad","contextMenuButton","closeContextMenu","micClasses","mx_CallView_callControls_button","mx_CallView_callControls_button_micOn","mx_CallView_callControls_button_micOff","vidClasses","mx_CallView_callControls_button_vidOn","mx_CallView_callControls_button_vidOff","micCacheClasses","mx_CallView_callControls_button_invisible","vidCacheClasses","callControlsClasses","mx_CallView_callControls","mx_CallView_callControls_hidden","vidMuteButton","type","CallType","Video","CallState","Connected","onDialpadClick","onMoreClick","callControls","avatarSize","pipMode","contentView","isOnHold","holdTransferContent","transferTargetRoom","transferTargetName","name","transfereeRoom","transfereeName","transferTarget","transferee","a","sub","onTransferClick","onHoldText","holdString","hasAnyUnheldCall","onCallResumeClick","peerName","getOpponentMember","containerClasses","mx_CallView_content","mx_CallView_video","mx_CallView_video_hold","onHoldBackground","backgroundStyle","backgroundAvatarUrl","backgroundImage","onMouseMove","classes","mx_CallView_voice","mx_CallView_voice_hold","width","height","noIncomingFeeds","getLocalFeeds","map","feed","i","isVideoMuted","onResize","isLocal","callTypeText","myClassName","fullScreenButton","onFullscreenClick","expandButton","onExpandClick","headerControls","header","secondaryCallInfo","onSecondaryRoomAvatarClick","onRoomAvatarClick"],"mappings":"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