matrix-react-sdk
Version:
SDK for matrix.org using React
112 lines (109 loc) • 21.7 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.WidgetPip = void 0;
var _react = _interopRequireWildcard(require("react"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _arrowLeft = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/arrow-left"));
var _PersistentApp = _interopRequireDefault(require("../elements/PersistentApp"));
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _actions = require("../../../dispatcher/actions");
var _useCall = require("../../../hooks/useCall");
var _WidgetStore = _interopRequireDefault(require("../../../stores/WidgetStore"));
var _WidgetLayoutStore = require("../../../stores/widgets/WidgetLayoutStore");
var _useEventEmitter = require("../../../hooks/useEventEmitter");
var _Toolbar = _interopRequireDefault(require("../../../accessibility/Toolbar"));
var _RovingTabIndex = require("../../../accessibility/RovingTabIndex");
var _hangup = require("../../../../res/img/element-icons/call/hangup.svg");
var _languageHandler = require("../../../languageHandler");
var _WidgetType = require("../../../widgets/WidgetType");
var _WidgetMessagingStore = require("../../../stores/widgets/WidgetMessagingStore");
var _WidgetUtils = _interopRequireDefault(require("../../../utils/WidgetUtils"));
var _ElementWidgetActions = require("../../../stores/widgets/ElementWidgetActions");
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.
*/
/**
* A picture-in-picture view for a widget. Additional controls are shown if the
* widget is a call of some sort.
*/
const WidgetPip = ({
widgetId,
room,
viewingRoom,
onStartMoving,
movePersistedElement
}) => {
const widget = (0, _react.useMemo)(() => _WidgetStore.default.instance.getApps(room.roomId).find(app => app.id === widgetId), [room, widgetId]);
const roomName = (0, _useEventEmitter.useTypedEventEmitterState)(room, _matrix.RoomEvent.Name, (0, _react.useCallback)(() => room.name, [room]));
const call = (0, _useCall.useCallForWidget)(widgetId, room.roomId);
const onBackClick = (0, _react.useCallback)(ev => {
ev.preventDefault();
ev.stopPropagation();
if (call !== null) {
_dispatcher.default.dispatch({
action: _actions.Action.ViewRoom,
room_id: room.roomId,
view_call: true,
metricsTrigger: "WebFloatingCallWindow"
});
} else if (viewingRoom) {
_WidgetLayoutStore.WidgetLayoutStore.instance.moveToContainer(room, widget, _WidgetLayoutStore.Container.Center);
} else {
_dispatcher.default.dispatch({
action: _actions.Action.ViewRoom,
room_id: room.roomId,
metricsTrigger: "WebFloatingCallWindow"
});
}
}, [room, call, widget, viewingRoom]);
const onLeaveClick = (0, _react.useCallback)(ev => {
ev.preventDefault();
ev.stopPropagation();
if (call !== null) {
call.disconnect().catch(e => console.error("Failed to leave call", e));
} else {
// Assumed to be a Jitsi widget
_WidgetMessagingStore.WidgetMessagingStore.instance.getMessagingForUid(_WidgetUtils.default.getWidgetUid(widget))?.transport.send(_ElementWidgetActions.ElementWidgetActions.HangupCall, {}).catch(e => console.error("Failed to leave Jitsi", e));
}
}, [call, widget]);
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_WidgetPip",
onMouseDown: onStartMoving,
onClick: onBackClick
}, /*#__PURE__*/_react.default.createElement(_PersistentApp.default, {
persistentWidgetId: widgetId,
persistentRoomId: room.roomId,
pointerEvents: "none",
movePersistedElement: movePersistedElement
}, /*#__PURE__*/_react.default.createElement("div", {
onMouseDown: onStartMoving,
className: "mx_WidgetPip_overlay"
}, /*#__PURE__*/_react.default.createElement(_Toolbar.default, {
className: "mx_WidgetPip_header"
}, /*#__PURE__*/_react.default.createElement(_RovingTabIndex.RovingAccessibleButton, {
onClick: onBackClick,
className: "mx_WidgetPip_backButton",
"aria-label": (0, _languageHandler._t)("action|back")
}, /*#__PURE__*/_react.default.createElement(_arrowLeft.default, {
className: "mx_Icon mx_Icon_16"
}), roomName)), (call !== null || _WidgetType.WidgetType.JITSI.matches(widget?.type)) && /*#__PURE__*/_react.default.createElement(_Toolbar.default, {
className: "mx_WidgetPip_footer"
}, /*#__PURE__*/_react.default.createElement(_RovingTabIndex.RovingAccessibleButton, {
onClick: onLeaveClick,
title: (0, _languageHandler._t)("action|leave"),
"aria-label": (0, _languageHandler._t)("action|leave"),
placement: "top"
}, /*#__PURE__*/_react.default.createElement(_hangup.Icon, {
className: "mx_Icon mx_Icon_24"
}))))));
};
exports.WidgetPip = WidgetPip;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_arrowLeft","_interopRequireDefault","_PersistentApp","_dispatcher","_actions","_useCall","_WidgetStore","_WidgetLayoutStore","_useEventEmitter","_Toolbar","_RovingTabIndex","_hangup","_languageHandler","_WidgetType","_WidgetMessagingStore","_WidgetUtils","_ElementWidgetActions","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","WidgetPip","widgetId","room","viewingRoom","onStartMoving","movePersistedElement","widget","useMemo","WidgetStore","instance","getApps","roomId","find","app","id","roomName","useTypedEventEmitterState","RoomEvent","Name","useCallback","name","useCallForWidget","onBackClick","ev","preventDefault","stopPropagation","defaultDispatcher","dispatch","action","Action","ViewRoom","room_id","view_call","metricsTrigger","WidgetLayoutStore","moveToContainer","Container","Center","onLeaveClick","disconnect","catch","console","error","WidgetMessagingStore","getMessagingForUid","WidgetUtils","getWidgetUid","transport","send","ElementWidgetActions","HangupCall","createElement","className","onMouseDown","onClick","persistentWidgetId","persistentRoomId","pointerEvents","RovingAccessibleButton","_t","WidgetType","JITSI","matches","type","title","placement","Icon","exports"],"sources":["../../../../src/components/views/pips/WidgetPip.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, MutableRefObject, useCallback, useMemo } from \"react\";\nimport { Room, RoomEvent } from \"matrix-js-sdk/src/matrix\";\nimport BackIcon from \"@vector-im/compound-design-tokens/assets/web/icons/arrow-left\";\n\nimport PersistentApp from \"../elements/PersistentApp\";\nimport defaultDispatcher from \"../../../dispatcher/dispatcher\";\nimport { ViewRoomPayload } from \"../../../dispatcher/payloads/ViewRoomPayload\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport { useCallForWidget } from \"../../../hooks/useCall\";\nimport WidgetStore from \"../../../stores/WidgetStore\";\nimport { Container, WidgetLayoutStore } from \"../../../stores/widgets/WidgetLayoutStore\";\nimport { useTypedEventEmitterState } from \"../../../hooks/useEventEmitter\";\nimport Toolbar from \"../../../accessibility/Toolbar\";\nimport { RovingAccessibleButton } from \"../../../accessibility/RovingTabIndex\";\nimport { Icon as HangupIcon } from \"../../../../res/img/element-icons/call/hangup.svg\";\nimport { _t } from \"../../../languageHandler\";\nimport { WidgetType } from \"../../../widgets/WidgetType\";\nimport { WidgetMessagingStore } from \"../../../stores/widgets/WidgetMessagingStore\";\nimport WidgetUtils from \"../../../utils/WidgetUtils\";\nimport { ElementWidgetActions } from \"../../../stores/widgets/ElementWidgetActions\";\nimport { ButtonEvent } from \"../elements/AccessibleButton\";\n\ninterface Props {\n    widgetId: string;\n    room: Room;\n    viewingRoom: boolean;\n    onStartMoving: (e: React.MouseEvent<Element, MouseEvent>) => void;\n    movePersistedElement: MutableRefObject<(() => void) | undefined>;\n}\n\n/**\n * A picture-in-picture view for a widget. Additional controls are shown if the\n * widget is a call of some sort.\n */\nexport const WidgetPip: FC<Props> = ({ widgetId, room, viewingRoom, onStartMoving, movePersistedElement }) => {\n    const widget = useMemo(\n        () => WidgetStore.instance.getApps(room.roomId).find((app) => app.id === widgetId)!,\n        [room, widgetId],\n    );\n\n    const roomName = useTypedEventEmitterState(\n        room,\n        RoomEvent.Name,\n        useCallback(() => room.name, [room]),\n    );\n\n    const call = useCallForWidget(widgetId, room.roomId);\n\n    const onBackClick = useCallback(\n        (ev: ButtonEvent) => {\n            ev.preventDefault();\n            ev.stopPropagation();\n\n            if (call !== null) {\n                defaultDispatcher.dispatch<ViewRoomPayload>({\n                    action: Action.ViewRoom,\n                    room_id: room.roomId,\n                    view_call: true,\n                    metricsTrigger: \"WebFloatingCallWindow\",\n                });\n            } else if (viewingRoom) {\n                WidgetLayoutStore.instance.moveToContainer(room, widget, Container.Center);\n            } else {\n                defaultDispatcher.dispatch<ViewRoomPayload>({\n                    action: Action.ViewRoom,\n                    room_id: room.roomId,\n                    metricsTrigger: \"WebFloatingCallWindow\",\n                });\n            }\n        },\n        [room, call, widget, viewingRoom],\n    );\n\n    const onLeaveClick = useCallback(\n        (ev: ButtonEvent) => {\n            ev.preventDefault();\n            ev.stopPropagation();\n\n            if (call !== null) {\n                call.disconnect().catch((e) => console.error(\"Failed to leave call\", e));\n            } else {\n                // Assumed to be a Jitsi widget\n                WidgetMessagingStore.instance\n                    .getMessagingForUid(WidgetUtils.getWidgetUid(widget))\n                    ?.transport.send(ElementWidgetActions.HangupCall, {})\n                    .catch((e) => console.error(\"Failed to leave Jitsi\", e));\n            }\n        },\n        [call, widget],\n    );\n\n    return (\n        <div className=\"mx_WidgetPip\" onMouseDown={onStartMoving} onClick={onBackClick}>\n            <PersistentApp\n                persistentWidgetId={widgetId}\n                persistentRoomId={room.roomId}\n                pointerEvents=\"none\"\n                movePersistedElement={movePersistedElement}\n            >\n                <div onMouseDown={onStartMoving} className=\"mx_WidgetPip_overlay\">\n                    <Toolbar className=\"mx_WidgetPip_header\">\n                        <RovingAccessibleButton\n                            onClick={onBackClick}\n                            className=\"mx_WidgetPip_backButton\"\n                            aria-label={_t(\"action|back\")}\n                        >\n                            <BackIcon className=\"mx_Icon mx_Icon_16\" />\n                            {roomName}\n                        </RovingAccessibleButton>\n                    </Toolbar>\n                    {(call !== null || WidgetType.JITSI.matches(widget?.type)) && (\n                        <Toolbar className=\"mx_WidgetPip_footer\">\n                            <RovingAccessibleButton\n                                onClick={onLeaveClick}\n                                title={_t(\"action|leave\")}\n                                aria-label={_t(\"action|leave\")}\n                                placement=\"top\"\n                            >\n                                <HangupIcon className=\"mx_Icon mx_Icon_24\" />\n                            </RovingAccessibleButton>\n                        </Toolbar>\n                    )}\n                </div>\n            </PersistentApp>\n        </div>\n    );\n};\n"],"mappings":"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","ignoreList":[]}