UNPKG

matrix-react-sdk

Version:
70 lines (67 loc) 12 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 _useEventEmitter = require("../../../../hooks/useEventEmitter"); var _languageHandler = require("../../../../languageHandler"); var _BaseTool = _interopRequireWildcard(require("./BaseTool")); var _WidgetStore = _interopRequireDefault(require("../../../../stores/WidgetStore")); var _AsyncStore = require("../../../../stores/AsyncStore"); var _FilteredList = _interopRequireDefault(require("./FilteredList")); var _RoomState = require("./RoomState"); 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 2023 The Matrix.org Foundation C.I.C. Copyright 2022 Michael Telatynski <7t3chguy@gmail.com> SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ const WidgetExplorer = ({ onBack }) => { const context = (0, _react.useContext)(_BaseTool.DevtoolsContext); const [query, setQuery] = (0, _react.useState)(""); const [widget, setWidget] = (0, _react.useState)(null); const widgets = (0, _useEventEmitter.useEventEmitterState)(_WidgetStore.default.instance, _AsyncStore.UPDATE_EVENT, () => { return _WidgetStore.default.instance.getApps(context.room.roomId); }); if (widget && widgets.includes(widget)) { const onBack = () => { setWidget(null); }; const allState = Array.from(Array.from(context.room.currentState.events.values()).map(e => { return e.values(); })).reduce((p, c) => { p.push(...c); return p; }, []); const event = allState.find(ev => ev.getId() === widget.eventId); if (!event) { // "should never happen" return /*#__PURE__*/_react.default.createElement(_BaseTool.default, { onBack: onBack }, (0, _languageHandler._t)("devtools|failed_to_find_widget")); } return /*#__PURE__*/_react.default.createElement(_RoomState.StateEventEditor, { mxEvent: event, onBack: onBack }); } return /*#__PURE__*/_react.default.createElement(_BaseTool.default, { onBack: onBack }, /*#__PURE__*/_react.default.createElement(_FilteredList.default, { query: query, onChange: setQuery }, widgets.map(w => /*#__PURE__*/_react.default.createElement("button", { className: "mx_DevTools_button", key: w.url + w.eventId, onClick: () => setWidget(w) }, w.url)))); }; var _default = exports.default = WidgetExplorer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useEventEmitter","_languageHandler","_BaseTool","_WidgetStore","_interopRequireDefault","_AsyncStore","_FilteredList","_RoomState","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","WidgetExplorer","onBack","context","useContext","DevtoolsContext","query","setQuery","useState","widget","setWidget","widgets","useEventEmitterState","WidgetStore","instance","UPDATE_EVENT","getApps","room","roomId","includes","allState","Array","from","currentState","events","values","map","reduce","p","c","push","event","find","ev","getId","eventId","createElement","_t","StateEventEditor","mxEvent","onChange","w","className","key","url","onClick","_default","exports"],"sources":["../../../../../src/components/views/dialogs/devtools/WidgetExplorer.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2023 The Matrix.org Foundation C.I.C.\nCopyright 2022 Michael Telatynski <7t3chguy@gmail.com>\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, useState } from \"react\";\nimport { MatrixEvent } from \"matrix-js-sdk/src/matrix\";\n\nimport { useEventEmitterState } from \"../../../../hooks/useEventEmitter\";\nimport { _t } from \"../../../../languageHandler\";\nimport BaseTool, { DevtoolsContext, IDevtoolsProps } from \"./BaseTool\";\nimport WidgetStore, { IApp } from \"../../../../stores/WidgetStore\";\nimport { UPDATE_EVENT } from \"../../../../stores/AsyncStore\";\nimport FilteredList from \"./FilteredList\";\nimport { StateEventEditor } from \"./RoomState\";\n\nconst WidgetExplorer: React.FC<IDevtoolsProps> = ({ onBack }) => {\n    const context = useContext(DevtoolsContext);\n    const [query, setQuery] = useState(\"\");\n    const [widget, setWidget] = useState<IApp | null>(null);\n\n    const widgets = useEventEmitterState(WidgetStore.instance, UPDATE_EVENT, () => {\n        return WidgetStore.instance.getApps(context.room.roomId);\n    });\n\n    if (widget && widgets.includes(widget)) {\n        const onBack = (): void => {\n            setWidget(null);\n        };\n\n        const allState = Array.from(\n            Array.from(context.room.currentState.events.values()).map((e: Map<string, MatrixEvent>) => {\n                return e.values();\n            }),\n        ).reduce((p, c) => {\n            p.push(...c);\n            return p;\n        }, [] as MatrixEvent[]);\n        const event = allState.find((ev) => ev.getId() === widget.eventId);\n        if (!event) {\n            // \"should never happen\"\n            return <BaseTool onBack={onBack}>{_t(\"devtools|failed_to_find_widget\")}</BaseTool>;\n        }\n\n        return <StateEventEditor mxEvent={event} onBack={onBack} />;\n    }\n\n    return (\n        <BaseTool onBack={onBack}>\n            <FilteredList query={query} onChange={setQuery}>\n                {widgets.map((w) => (\n                    <button className=\"mx_DevTools_button\" key={w.url + w.eventId} onClick={() => setWidget(w)}>\n                        {w.url}\n                    </button>\n                ))}\n            </FilteredList>\n        </BaseTool>\n    );\n};\n\nexport default WidgetExplorer;\n"],"mappings":"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","ignoreList":[]}