matrix-react-sdk
Version:
SDK for matrix.org using React
97 lines (94 loc) • 15.2 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 _call = require("matrix-js-sdk/src/webrtc/call");
var _react = _interopRequireDefault(require("react"));
var _reResizable = require("re-resizable");
var _LegacyCallHandler = _interopRequireWildcard(require("../../../LegacyCallHandler"));
var _LegacyCallView = _interopRequireDefault(require("./LegacyCallView"));
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; }
/*
Copyright 2024 New Vector Ltd.
Copyright 2020-2022 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
/*
* Wrapper for LegacyCallView that always display the call in a given room,
* or nothing if there is no call in that room.
*/
class LegacyCallViewForRoom extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "updateCall", () => {
const newCall = this.getCall();
if (newCall !== this.state.call) {
this.setState({
call: newCall
});
}
});
(0, _defineProperty2.default)(this, "onResizeStart", () => {
this.props.resizeNotifier.startResizing();
});
(0, _defineProperty2.default)(this, "onResize", () => {
this.props.resizeNotifier.notifyTimelineHeightChanged();
});
(0, _defineProperty2.default)(this, "onResizeStop", () => {
this.props.resizeNotifier.stopResizing();
});
this.state = {
call: this.getCall()
};
}
componentDidMount() {
_LegacyCallHandler.default.instance.addListener(_LegacyCallHandler.LegacyCallHandlerEvent.CallState, this.updateCall);
_LegacyCallHandler.default.instance.addListener(_LegacyCallHandler.LegacyCallHandlerEvent.CallChangeRoom, this.updateCall);
}
componentWillUnmount() {
_LegacyCallHandler.default.instance.removeListener(_LegacyCallHandler.LegacyCallHandlerEvent.CallState, this.updateCall);
_LegacyCallHandler.default.instance.removeListener(_LegacyCallHandler.LegacyCallHandlerEvent.CallChangeRoom, this.updateCall);
}
getCall() {
const call = _LegacyCallHandler.default.instance.getCallForRoom(this.props.roomId);
if (call && [_call.CallState.Ended, _call.CallState.Ringing].includes(call.state)) return null;
return call;
}
render() {
if (!this.state.call) return null;
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_LegacyCallViewForRoom"
}, /*#__PURE__*/_react.default.createElement(_reResizable.Resizable, {
minHeight: 380,
maxHeight: "80vh",
enable: {
top: false,
right: false,
bottom: true,
left: false,
topRight: false,
bottomRight: false,
bottomLeft: false,
topLeft: false
},
onResizeStart: this.onResizeStart,
onResize: this.onResize,
onResizeStop: this.onResizeStop,
className: "mx_LegacyCallViewForRoom_ResizeWrapper",
handleClasses: {
bottom: "mx_LegacyCallViewForRoom_ResizeHandle"
}
}, /*#__PURE__*/_react.default.createElement(_LegacyCallView.default, {
call: this.state.call,
pipMode: false,
showApps: this.props.showApps
})));
}
}
exports.default = LegacyCallViewForRoom;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_call","require","_react","_interopRequireDefault","_reResizable","_LegacyCallHandler","_interopRequireWildcard","_LegacyCallView","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","LegacyCallViewForRoom","React","Component","constructor","props","_defineProperty2","newCall","getCall","state","setState","resizeNotifier","startResizing","notifyTimelineHeightChanged","stopResizing","componentDidMount","LegacyCallHandler","instance","addListener","LegacyCallHandlerEvent","CallState","updateCall","CallChangeRoom","componentWillUnmount","removeListener","getCallForRoom","roomId","Ended","Ringing","includes","render","createElement","className","Resizable","minHeight","maxHeight","enable","top","right","bottom","left","topRight","bottomRight","bottomLeft","topLeft","onResizeStart","onResize","onResizeStop","handleClasses","pipMode","showApps","exports"],"sources":["../../../../src/components/views/voip/LegacyCallViewForRoom.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020-2022 The Matrix.org Foundation C.I.C.\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 { CallState, MatrixCall } from \"matrix-js-sdk/src/webrtc/call\";\nimport React from \"react\";\nimport { Resizable } from \"re-resizable\";\n\nimport LegacyCallHandler, { LegacyCallHandlerEvent } from \"../../../LegacyCallHandler\";\nimport LegacyCallView from \"./LegacyCallView\";\nimport ResizeNotifier from \"../../../utils/ResizeNotifier\";\n\ninterface IProps {\n    // What room we should display the call for\n    roomId: string;\n\n    resizeNotifier: ResizeNotifier;\n\n    showApps?: boolean;\n}\n\ninterface IState {\n    call: MatrixCall | null;\n}\n\n/*\n * Wrapper for LegacyCallView that always display the call in a given room,\n * or nothing if there is no call in that room.\n */\nexport default class LegacyCallViewForRoom extends React.Component<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n        this.state = {\n            call: this.getCall(),\n        };\n    }\n\n    public componentDidMount(): void {\n        LegacyCallHandler.instance.addListener(LegacyCallHandlerEvent.CallState, this.updateCall);\n        LegacyCallHandler.instance.addListener(LegacyCallHandlerEvent.CallChangeRoom, this.updateCall);\n    }\n\n    public componentWillUnmount(): void {\n        LegacyCallHandler.instance.removeListener(LegacyCallHandlerEvent.CallState, this.updateCall);\n        LegacyCallHandler.instance.removeListener(LegacyCallHandlerEvent.CallChangeRoom, this.updateCall);\n    }\n\n    private updateCall = (): void => {\n        const newCall = this.getCall();\n        if (newCall !== this.state.call) {\n            this.setState({ call: newCall });\n        }\n    };\n\n    private getCall(): MatrixCall | null {\n        const call = LegacyCallHandler.instance.getCallForRoom(this.props.roomId);\n\n        if (call && [CallState.Ended, CallState.Ringing].includes(call.state)) return null;\n        return call;\n    }\n\n    private onResizeStart = (): void => {\n        this.props.resizeNotifier.startResizing();\n    };\n\n    private onResize = (): void => {\n        this.props.resizeNotifier.notifyTimelineHeightChanged();\n    };\n\n    private onResizeStop = (): void => {\n        this.props.resizeNotifier.stopResizing();\n    };\n\n    public render(): React.ReactNode {\n        if (!this.state.call) return null;\n\n        return (\n            <div className=\"mx_LegacyCallViewForRoom\">\n                <Resizable\n                    minHeight={380}\n                    maxHeight=\"80vh\"\n                    enable={{\n                        top: false,\n                        right: false,\n                        bottom: true,\n                        left: false,\n                        topRight: false,\n                        bottomRight: false,\n                        bottomLeft: false,\n                        topLeft: false,\n                    }}\n                    onResizeStart={this.onResizeStart}\n                    onResize={this.onResize}\n                    onResizeStop={this.onResizeStop}\n                    className=\"mx_LegacyCallViewForRoom_ResizeWrapper\"\n                    handleClasses={{ bottom: \"mx_LegacyCallViewForRoom_ResizeHandle\" }}\n                >\n                    <LegacyCallView call={this.state.call} pipMode={false} showApps={this.props.showApps} />\n                </Resizable>\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}