matrix-react-sdk
Version:
SDK for matrix.org using React
98 lines (95 loc) • 15.1 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.CallView = void 0;
var _react = _interopRequireWildcard(require("react"));
var _Call = require("../../../models/Call");
var _useCall = require("../../../hooks/useCall");
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _AppTile = _interopRequireDefault(require("../elements/AppTile"));
var _CallStore = require("../../../stores/CallStore");
var _SDKContext = require("../../../contexts/SDKContext");
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 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.
*/
const JoinCallView = ({
room,
resizing,
call,
skipLobby,
role
}) => {
const cli = (0, _react.useContext)(_MatrixClientContext.default);
(0, _react.useEffect)(() => {
// We'll take this opportunity to tidy up our room state
call.clean();
}, [call]);
(0, _react.useEffect)(() => {
// Always update the widget data so that we don't ignore "skipLobby" accidentally.
call.widget.data ??= {};
call.widget.data.skipLobby = skipLobby;
}, [call.widget, skipLobby]);
(0, _react.useEffect)(() => {
if (call.connectionState === _Call.ConnectionState.Disconnected) {
// immediately start the call
// (this will start the lobby view in the widget and connect to all required widget events)
call.start();
}
return () => {
// If we are connected the widget is sticky and we do not want to destroy the call.
if (!call.connected) call.destroy();
};
}, [call]);
const disconnectAllOtherCalls = (0, _react.useCallback)(async () => {
// The stickyPromise has to resolve before the widget actually becomes sticky.
// We only let the widget become sticky after disconnecting all other active calls.
const calls = [..._CallStore.CallStore.instance.connectedCalls].filter(call => _SDKContext.SdkContextClass.instance.roomViewStore.getRoomId() !== call.roomId);
await Promise.all(calls.map(async call => await call.disconnect()));
}, []);
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CallView"
}, /*#__PURE__*/_react.default.createElement(_AppTile.default, {
app: call.widget,
room: room,
userId: cli.credentials.userId,
creatorUserId: call.widget.creatorUserId,
waitForIframeLoad: call.widget.waitForIframeLoad,
showMenubar: false,
pointerEvents: resizing ? "none" : undefined,
stickyPromise: disconnectAllOtherCalls
}));
};
const CallView = ({
room,
resizing,
waitForCall,
skipLobby,
role
}) => {
const call = (0, _useCall.useCall)(room.roomId);
(0, _react.useEffect)(() => {
if (call === null && !waitForCall) {
_Call.ElementCall.create(room, skipLobby);
}
}, [call, room, skipLobby, waitForCall]);
if (call === null) {
return null;
} else {
return /*#__PURE__*/_react.default.createElement(JoinCallView, {
room: room,
resizing: resizing,
call: call,
skipLobby: skipLobby,
role: role
});
}
};
exports.CallView = CallView;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Call","_useCall","_MatrixClientContext","_interopRequireDefault","_AppTile","_CallStore","_SDKContext","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","JoinCallView","room","resizing","skipLobby","role","cli","useContext","MatrixClientContext","useEffect","clean","widget","data","connectionState","ConnectionState","Disconnected","start","connected","destroy","disconnectAllOtherCalls","useCallback","calls","CallStore","instance","connectedCalls","filter","SdkContextClass","roomViewStore","getRoomId","roomId","Promise","all","map","disconnect","createElement","className","app","userId","credentials","creatorUserId","waitForIframeLoad","showMenubar","pointerEvents","undefined","stickyPromise","CallView","waitForCall","useCall","ElementCall","create","exports"],"sources":["../../../../src/components/views/voip/CallView.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 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 React, { FC, useContext, useEffect, AriaRole, useCallback } from \"react\";\n\nimport type { Room } from \"matrix-js-sdk/src/matrix\";\nimport { Call, ConnectionState, ElementCall } from \"../../../models/Call\";\nimport { useCall } from \"../../../hooks/useCall\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport AppTile from \"../elements/AppTile\";\nimport { CallStore } from \"../../../stores/CallStore\";\nimport { SdkContextClass } from \"../../../contexts/SDKContext\";\n\ninterface JoinCallViewProps {\n    room: Room;\n    resizing: boolean;\n    call: Call;\n    skipLobby?: boolean;\n    role?: AriaRole;\n}\n\nconst JoinCallView: FC<JoinCallViewProps> = ({ room, resizing, call, skipLobby, role }) => {\n    const cli = useContext(MatrixClientContext);\n\n    useEffect(() => {\n        // We'll take this opportunity to tidy up our room state\n        call.clean();\n    }, [call]);\n\n    useEffect(() => {\n        // Always update the widget data so that we don't ignore \"skipLobby\" accidentally.\n        call.widget.data ??= {};\n        call.widget.data.skipLobby = skipLobby;\n    }, [call.widget, skipLobby]);\n\n    useEffect(() => {\n        if (call.connectionState === ConnectionState.Disconnected) {\n            // immediately start the call\n            // (this will start the lobby view in the widget and connect to all required widget events)\n            call.start();\n        }\n        return (): void => {\n            // If we are connected the widget is sticky and we do not want to destroy the call.\n            if (!call.connected) call.destroy();\n        };\n    }, [call]);\n    const disconnectAllOtherCalls: () => Promise<void> = useCallback(async () => {\n        // The stickyPromise has to resolve before the widget actually becomes sticky.\n        // We only let the widget become sticky after disconnecting all other active calls.\n        const calls = [...CallStore.instance.connectedCalls].filter(\n            (call) => SdkContextClass.instance.roomViewStore.getRoomId() !== call.roomId,\n        );\n        await Promise.all(calls.map(async (call) => await call.disconnect()));\n    }, []);\n    return (\n        <div className=\"mx_CallView\">\n            <AppTile\n                app={call.widget}\n                room={room}\n                userId={cli.credentials.userId!}\n                creatorUserId={call.widget.creatorUserId}\n                waitForIframeLoad={call.widget.waitForIframeLoad}\n                showMenubar={false}\n                pointerEvents={resizing ? \"none\" : undefined}\n                stickyPromise={disconnectAllOtherCalls}\n            />\n        </div>\n    );\n};\n\ninterface CallViewProps {\n    room: Room;\n    resizing: boolean;\n    /**\n     * If true, the view will be blank until a call appears. Otherwise, the join\n     * button will create a call if there isn't already one.\n     */\n    waitForCall: boolean;\n    skipLobby?: boolean;\n    role?: AriaRole;\n}\n\nexport const CallView: FC<CallViewProps> = ({ room, resizing, waitForCall, skipLobby, role }) => {\n    const call = useCall(room.roomId);\n\n    useEffect(() => {\n        if (call === null && !waitForCall) {\n            ElementCall.create(room, skipLobby);\n        }\n    }, [call, room, skipLobby, waitForCall]);\n    if (call === null) {\n        return null;\n    } else {\n        return <JoinCallView room={room} resizing={resizing} call={call} skipLobby={skipLobby} role={role} />;\n    }\n};\n"],"mappings":";;;;;;;AAQA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AAGA,IAAAC,KAAA,GAAAD,OAAA;AACA,IAAAE,QAAA,GAAAF,OAAA;AACA,IAAAG,oBAAA,GAAAC,sBAAA,CAAAJ,OAAA;AACA,IAAAK,QAAA,GAAAD,sBAAA,CAAAJ,OAAA;AACA,IAAAM,UAAA,GAAAN,OAAA;AACA,IAAAO,WAAA,GAAAP,OAAA;AAA+D,SAAAQ,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAV,wBAAAU,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAhB/D;AACA;AACA;AACA;AACA;AACA;AACA;;AAoBA,MAAMW,YAAmC,GAAGA,CAAC;EAAEC,IAAI;EAAEC,QAAQ;EAAEL,IAAI;EAAEM,SAAS;EAAEC;AAAK,CAAC,KAAK;EACvF,MAAMC,GAAG,GAAG,IAAAC,iBAAU,EAACC,4BAAmB,CAAC;EAE3C,IAAAC,gBAAS,EAAC,MAAM;IACZ;IACAX,IAAI,CAACY,KAAK,CAAC,CAAC;EAChB,CAAC,EAAE,CAACZ,IAAI,CAAC,CAAC;EAEV,IAAAW,gBAAS,EAAC,MAAM;IACZ;IACAX,IAAI,CAACa,MAAM,CAACC,IAAI,KAAK,CAAC,CAAC;IACvBd,IAAI,CAACa,MAAM,CAACC,IAAI,CAACR,SAAS,GAAGA,SAAS;EAC1C,CAAC,EAAE,CAACN,IAAI,CAACa,MAAM,EAAEP,SAAS,CAAC,CAAC;EAE5B,IAAAK,gBAAS,EAAC,MAAM;IACZ,IAAIX,IAAI,CAACe,eAAe,KAAKC,qBAAe,CAACC,YAAY,EAAE;MACvD;MACA;MACAjB,IAAI,CAACkB,KAAK,CAAC,CAAC;IAChB;IACA,OAAO,MAAY;MACf;MACA,IAAI,CAAClB,IAAI,CAACmB,SAAS,EAAEnB,IAAI,CAACoB,OAAO,CAAC,CAAC;IACvC,CAAC;EACL,CAAC,EAAE,CAACpB,IAAI,CAAC,CAAC;EACV,MAAMqB,uBAA4C,GAAG,IAAAC,kBAAW,EAAC,YAAY;IACzE;IACA;IACA,MAAMC,KAAK,GAAG,CAAC,GAAGC,oBAAS,CAACC,QAAQ,CAACC,cAAc,CAAC,CAACC,MAAM,CACtD3B,IAAI,IAAK4B,2BAAe,CAACH,QAAQ,CAACI,aAAa,CAACC,SAAS,CAAC,CAAC,KAAK9B,IAAI,CAAC+B,MAC1E,CAAC;IACD,MAAMC,OAAO,CAACC,GAAG,CAACV,KAAK,CAACW,GAAG,CAAC,MAAOlC,IAAI,IAAK,MAAMA,IAAI,CAACmC,UAAU,CAAC,CAAC,CAAC,CAAC;EACzE,CAAC,EAAE,EAAE,CAAC;EACN,oBACI9D,MAAA,CAAAgB,OAAA,CAAA+C,aAAA;IAAKC,SAAS,EAAC;EAAa,gBACxBhE,MAAA,CAAAgB,OAAA,CAAA+C,aAAA,CAACxD,QAAA,CAAAS,OAAO;IACJiD,GAAG,EAAEtC,IAAI,CAACa,MAAO;IACjBT,IAAI,EAAEA,IAAK;IACXmC,MAAM,EAAE/B,GAAG,CAACgC,WAAW,CAACD,MAAQ;IAChCE,aAAa,EAAEzC,IAAI,CAACa,MAAM,CAAC4B,aAAc;IACzCC,iBAAiB,EAAE1C,IAAI,CAACa,MAAM,CAAC6B,iBAAkB;IACjDC,WAAW,EAAE,KAAM;IACnBC,aAAa,EAAEvC,QAAQ,GAAG,MAAM,GAAGwC,SAAU;IAC7CC,aAAa,EAAEzB;EAAwB,CAC1C,CACA,CAAC;AAEd,CAAC;AAcM,MAAM0B,QAA2B,GAAGA,CAAC;EAAE3C,IAAI;EAAEC,QAAQ;EAAE2C,WAAW;EAAE1C,SAAS;EAAEC;AAAK,CAAC,KAAK;EAC7F,MAAMP,IAAI,GAAG,IAAAiD,gBAAO,EAAC7C,IAAI,CAAC2B,MAAM,CAAC;EAEjC,IAAApB,gBAAS,EAAC,MAAM;IACZ,IAAIX,IAAI,KAAK,IAAI,IAAI,CAACgD,WAAW,EAAE;MAC/BE,iBAAW,CAACC,MAAM,CAAC/C,IAAI,EAAEE,SAAS,CAAC;IACvC;EACJ,CAAC,EAAE,CAACN,IAAI,EAAEI,IAAI,EAAEE,SAAS,EAAE0C,WAAW,CAAC,CAAC;EACxC,IAAIhD,IAAI,KAAK,IAAI,EAAE;IACf,OAAO,IAAI;EACf,CAAC,MAAM;IACH,oBAAO3B,MAAA,CAAAgB,OAAA,CAAA+C,aAAA,CAACjC,YAAY;MAACC,IAAI,EAAEA,IAAK;MAACC,QAAQ,EAAEA,QAAS;MAACL,IAAI,EAAEA,IAAK;MAACM,SAAS,EAAEA,SAAU;MAACC,IAAI,EAAEA;IAAK,CAAE,CAAC;EACzG;AACJ,CAAC;AAAC6C,OAAA,CAAAL,QAAA,GAAAA,QAAA","ignoreList":[]}