matrix-react-sdk
Version:
SDK for matrix.org using React
130 lines (107 loc) • 13.8 kB
JavaScript
"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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _call = require("matrix-js-sdk/src/webrtc/call");
var _react = _interopRequireDefault(require("react"));
var _CallHandler = _interopRequireWildcard(require("../../../CallHandler"));
var _CallView = _interopRequireDefault(require("./CallView"));
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _reResizable = require("re-resizable");
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class, _temp;
let CallViewForRoom = (
/*
* Wrapper for CallView that always display the call in a given room,
* or nothing if there is no call in that room.
*/
_dec = (0, _replaceableComponent.replaceableComponent)("views.voip.CallViewForRoom"), _dec(_class = (_temp = class CallViewForRoom extends _react.default.Component
/*:: <IProps, IState>*/
{
constructor(props
/*: IProps*/
) {
super(props);
(0, _defineProperty2.default)(this, "dispatcherRef", void 0);
(0, _defineProperty2.default)(this, "onAction", payload => {
switch (payload.action) {
case 'call_state':
{
this.updateCall();
break;
}
}
});
(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() {
this.dispatcherRef = _dispatcher.default.register(this.onAction);
_CallHandler.default.sharedInstance().addListener(_CallHandler.CallHandlerEvent.CallChangeRoom, this.updateCall);
}
componentWillUnmount() {
_dispatcher.default.unregister(this.dispatcherRef);
_CallHandler.default.sharedInstance().removeListener(_CallHandler.CallHandlerEvent.CallChangeRoom, this.updateCall);
}
getCall()
/*: MatrixCall*/
{
const call = _CallHandler.default.sharedInstance().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; // We subtract 8 as it the margin-bottom of the mx_CallViewForRoom_ResizeWrapper
const maxHeight = this.props.maxVideoHeight - 8;
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallViewForRoom"
}, /*#__PURE__*/_react.default.createElement(_reResizable.Resizable, {
minHeight: 380,
maxHeight: maxHeight,
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_CallViewForRoom_ResizeWrapper",
handleClasses: {
bottom: "mx_CallViewForRoom_ResizeHandle"
}
}, /*#__PURE__*/_react.default.createElement(_CallView.default, {
call: this.state.call,
pipMode: false
})));
}
}, _temp)) || _class);
exports.default = CallViewForRoom;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/voip/CallViewForRoom.tsx"],"names":["CallViewForRoom","React","Component","constructor","props","payload","action","updateCall","newCall","getCall","state","call","setState","resizeNotifier","startResizing","notifyTimelineHeightChanged","stopResizing","componentDidMount","dispatcherRef","dis","register","onAction","CallHandler","sharedInstance","addListener","CallHandlerEvent","CallChangeRoom","componentWillUnmount","unregister","removeListener","getCallForRoom","roomId","CallState","Ended","Ringing","includes","render","maxHeight","maxVideoHeight","top","right","bottom","left","topRight","bottomRight","bottomLeft","topLeft","onResizeStart","onResize","onResizeStop"],"mappings":"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","sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { CallState, MatrixCall } from 'matrix-js-sdk/src/webrtc/call';\nimport React from 'react';\nimport CallHandler, { CallHandlerEvent } from '../../../CallHandler';\nimport CallView from './CallView';\nimport dis from '../../../dispatcher/dispatcher';\nimport {Resizable} from \"re-resizable\";\nimport ResizeNotifier from \"../../../utils/ResizeNotifier\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\ninterface IProps {\n    // What room we should display the call for\n    roomId: string,\n\n    // maxHeight style attribute for the video panel\n    maxVideoHeight?: number;\n\n    resizeNotifier: ResizeNotifier,\n}\n\ninterface IState {\n    call: MatrixCall,\n}\n\n/*\n * Wrapper for CallView that always display the call in a given room,\n * or nothing if there is no call in that room.\n */\n@replaceableComponent(\"views.voip.CallViewForRoom\")\nexport default class CallViewForRoom extends React.Component<IProps, IState> {\n    private dispatcherRef: string;\n\n    constructor(props: IProps) {\n        super(props);\n        this.state = {\n            call: this.getCall(),\n        };\n    }\n\n    public componentDidMount() {\n        this.dispatcherRef = dis.register(this.onAction);\n        CallHandler.sharedInstance().addListener(CallHandlerEvent.CallChangeRoom, this.updateCall);\n    }\n\n    public componentWillUnmount() {\n        dis.unregister(this.dispatcherRef);\n        CallHandler.sharedInstance().removeListener(CallHandlerEvent.CallChangeRoom, this.updateCall);\n    }\n\n    private onAction = (payload) => {\n        switch (payload.action) {\n            case 'call_state': {\n                this.updateCall();\n                break;\n            }\n        }\n    };\n\n    private updateCall = () => {\n        const newCall = this.getCall();\n        if (newCall !== this.state.call) {\n            this.setState({call: newCall});\n        }\n    };\n\n    private getCall(): MatrixCall {\n        const call = CallHandler.sharedInstance().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 = () => {\n        this.props.resizeNotifier.startResizing();\n    };\n\n    private onResize = () => {\n        this.props.resizeNotifier.notifyTimelineHeightChanged();\n    };\n\n    private onResizeStop = () => {\n        this.props.resizeNotifier.stopResizing();\n    };\n\n    public render() {\n        if (!this.state.call) return null;\n        // We subtract 8 as it the margin-bottom of the mx_CallViewForRoom_ResizeWrapper\n        const maxHeight = this.props.maxVideoHeight - 8;\n\n        return (\n            <div className=\"mx_CallViewForRoom\">\n                <Resizable\n                    minHeight={380}\n                    maxHeight={maxHeight}\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_CallViewForRoom_ResizeWrapper\"\n                    handleClasses={{bottom: \"mx_CallViewForRoom_ResizeHandle\"}}\n                >\n                    <CallView\n                        call={this.state.call}\n                        pipMode={false}\n                    />\n                </Resizable>\n            </div>\n        );\n    }\n}\n"]}