UNPKG

matrix-react-sdk

Version:
91 lines (87 loc) 15.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _BaseCard = _interopRequireDefault(require("./BaseCard")); var _WidgetUtils = _interopRequireWildcard(require("../../../utils/WidgetUtils")); var _AppTile = _interopRequireDefault(require("../elements/AppTile")); var _languageHandler = require("../../../languageHandler"); var _ContextMenu = require("../../structures/ContextMenu"); var _WidgetContextMenu = require("../context_menus/WidgetContextMenu"); var _WidgetLayoutStore = require("../../../stores/widgets/WidgetLayoutStore"); var _UIStore = _interopRequireDefault(require("../../../stores/UIStore")); var _RightPanelStore = _interopRequireDefault(require("../../../stores/right-panel/RightPanelStore")); var _Heading = _interopRequireDefault(require("../typography/Heading")); 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 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 WidgetCard = ({ room, widgetId, onClose }) => { const cli = (0, _react.useContext)(_MatrixClientContext.default); const apps = (0, _WidgetUtils.useWidgets)(room); const app = apps.find(a => a.id === widgetId); const isRight = app && _WidgetLayoutStore.WidgetLayoutStore.instance.isInContainer(room, app, _WidgetLayoutStore.Container.Right); const [menuDisplayed, handle, openMenu, closeMenu] = (0, _ContextMenu.useContextMenu)(); (0, _react.useEffect)(() => { if (!app || !isRight) { // stop showing this card _RightPanelStore.default.instance.popCard(); } }, [app, isRight]); // Don't render anything as we are about to transition if (!app || !isRight) return null; let contextMenu; if (menuDisplayed) { const rect = handle.current?.getBoundingClientRect(); const rightMargin = rect ? rect.right : 0; const bottomMargin = rect ? rect.bottom : 0; contextMenu = /*#__PURE__*/_react.default.createElement(_WidgetContextMenu.WidgetContextMenu, { chevronFace: _ContextMenu.ChevronFace.None, right: _UIStore.default.instance.windowWidth - rightMargin - 12, top: bottomMargin + 12, onFinished: closeMenu, app: app }); } const header = /*#__PURE__*/_react.default.createElement("div", { className: "mx_BaseCard_header_title" }, /*#__PURE__*/_react.default.createElement(_Heading.default, { size: "4", className: "mx_BaseCard_header_title_heading" }, _WidgetUtils.default.getWidgetName(app)), /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenuButton, { className: "mx_BaseCard_header_title_button--option", ref: handle, onClick: openMenu, isExpanded: menuDisplayed, label: (0, _languageHandler._t)("common|options") }), contextMenu); return /*#__PURE__*/_react.default.createElement(_BaseCard.default, { header: header, className: "mx_WidgetCard", onClose: onClose, withoutScrollContainer: true }, /*#__PURE__*/_react.default.createElement(_AppTile.default, { app: app, fullWidth: true, showMenubar: false, room: room, userId: cli.getSafeUserId(), creatorUserId: app.creatorUserId, widgetPageTitle: _WidgetUtils.default.getWidgetDataTitle(app), waitForIframeLoad: app.waitForIframeLoad })); }; var _default = exports.default = WidgetCard; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_MatrixClientContext","_interopRequireDefault","_BaseCard","_WidgetUtils","_AppTile","_languageHandler","_ContextMenu","_WidgetContextMenu","_WidgetLayoutStore","_UIStore","_RightPanelStore","_Heading","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","WidgetCard","room","widgetId","onClose","cli","useContext","MatrixClientContext","apps","useWidgets","app","find","id","isRight","WidgetLayoutStore","instance","isInContainer","Container","Right","menuDisplayed","handle","openMenu","closeMenu","useContextMenu","useEffect","RightPanelStore","popCard","contextMenu","rect","current","getBoundingClientRect","rightMargin","right","bottomMargin","bottom","createElement","WidgetContextMenu","chevronFace","ChevronFace","None","UIStore","windowWidth","top","onFinished","header","className","size","WidgetUtils","getWidgetName","ContextMenuButton","ref","onClick","isExpanded","label","_t","withoutScrollContainer","fullWidth","showMenubar","userId","getSafeUserId","creatorUserId","widgetPageTitle","getWidgetDataTitle","waitForIframeLoad","_default","exports"],"sources":["../../../../src/components/views/right_panel/WidgetCard.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 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, { useContext, useEffect } from \"react\";\nimport { Room } from \"matrix-js-sdk/src/matrix\";\n\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport BaseCard from \"./BaseCard\";\nimport WidgetUtils, { useWidgets } from \"../../../utils/WidgetUtils\";\nimport AppTile from \"../elements/AppTile\";\nimport { _t } from \"../../../languageHandler\";\nimport { ChevronFace, ContextMenuButton, useContextMenu } from \"../../structures/ContextMenu\";\nimport { WidgetContextMenu } from \"../context_menus/WidgetContextMenu\";\nimport { Container, WidgetLayoutStore } from \"../../../stores/widgets/WidgetLayoutStore\";\nimport UIStore from \"../../../stores/UIStore\";\nimport RightPanelStore from \"../../../stores/right-panel/RightPanelStore\";\nimport Heading from \"../typography/Heading\";\n\ninterface IProps {\n    room: Room;\n    widgetId: string;\n    onClose(): void;\n}\n\nconst WidgetCard: React.FC<IProps> = ({ room, widgetId, onClose }) => {\n    const cli = useContext(MatrixClientContext);\n\n    const apps = useWidgets(room);\n    const app = apps.find((a) => a.id === widgetId);\n    const isRight = app && WidgetLayoutStore.instance.isInContainer(room, app, Container.Right);\n\n    const [menuDisplayed, handle, openMenu, closeMenu] = useContextMenu();\n\n    useEffect(() => {\n        if (!app || !isRight) {\n            // stop showing this card\n            RightPanelStore.instance.popCard();\n        }\n    }, [app, isRight]);\n\n    // Don't render anything as we are about to transition\n    if (!app || !isRight) return null;\n\n    let contextMenu: JSX.Element | undefined;\n    if (menuDisplayed) {\n        const rect = handle.current?.getBoundingClientRect();\n        const rightMargin = rect ? rect.right : 0;\n        const bottomMargin = rect ? rect.bottom : 0;\n        contextMenu = (\n            <WidgetContextMenu\n                chevronFace={ChevronFace.None}\n                right={UIStore.instance.windowWidth - rightMargin - 12}\n                top={bottomMargin + 12}\n                onFinished={closeMenu}\n                app={app}\n            />\n        );\n    }\n\n    const header = (\n        <div className=\"mx_BaseCard_header_title\">\n            <Heading size=\"4\" className=\"mx_BaseCard_header_title_heading\">\n                {WidgetUtils.getWidgetName(app)}\n            </Heading>\n            <ContextMenuButton\n                className=\"mx_BaseCard_header_title_button--option\"\n                ref={handle}\n                onClick={openMenu}\n                isExpanded={menuDisplayed}\n                label={_t(\"common|options\")}\n            />\n            {contextMenu}\n        </div>\n    );\n\n    return (\n        <BaseCard header={header} className=\"mx_WidgetCard\" onClose={onClose} withoutScrollContainer>\n            <AppTile\n                app={app}\n                fullWidth\n                showMenubar={false}\n                room={room}\n                userId={cli.getSafeUserId()}\n                creatorUserId={app.creatorUserId}\n                widgetPageTitle={WidgetUtils.getWidgetDataTitle(app)}\n                waitForIframeLoad={app.waitForIframeLoad}\n            />\n        </BaseCard>\n    );\n};\n\nexport default WidgetCard;\n"],"mappings":"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","ignoreList":[]}