matrix-react-sdk
Version:
SDK for matrix.org using React
130 lines (127 loc) • 18.6 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.RoomAccountDataExplorer = exports.RoomAccountDataEventEditor = exports.AccountDataExplorer = exports.AccountDataEventEditor = void 0;
var _react = _interopRequireWildcard(require("react"));
var _BaseTool = _interopRequireWildcard(require("./BaseTool"));
var _MatrixClientContext = _interopRequireDefault(require("../../../../contexts/MatrixClientContext"));
var _Event = require("./Event");
var _FilteredList = _interopRequireDefault(require("./FilteredList"));
var _languageHandler = require("../../../../languageHandler");
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 AccountDataEventEditor = ({
mxEvent,
onBack
}) => {
const cli = (0, _react.useContext)(_MatrixClientContext.default);
const fields = (0, _react.useMemo)(() => [(0, _Event.eventTypeField)(mxEvent?.getType())], [mxEvent]);
const onSend = async ([eventType], content) => {
await cli.setAccountData(eventType, content || {});
};
const defaultContent = mxEvent ? (0, _Event.stringify)(mxEvent.getContent()) : undefined;
return /*#__PURE__*/_react.default.createElement(_Event.EventEditor, {
fieldDefs: fields,
defaultContent: defaultContent,
onSend: onSend,
onBack: onBack
});
};
exports.AccountDataEventEditor = AccountDataEventEditor;
const RoomAccountDataEventEditor = ({
mxEvent,
onBack
}) => {
const context = (0, _react.useContext)(_BaseTool.DevtoolsContext);
const cli = (0, _react.useContext)(_MatrixClientContext.default);
const fields = (0, _react.useMemo)(() => [(0, _Event.eventTypeField)(mxEvent?.getType())], [mxEvent]);
const onSend = async ([eventType], content) => {
await cli.setRoomAccountData(context.room.roomId, eventType, content || {});
};
const defaultContent = mxEvent ? (0, _Event.stringify)(mxEvent.getContent()) : undefined;
return /*#__PURE__*/_react.default.createElement(_Event.EventEditor, {
fieldDefs: fields,
defaultContent: defaultContent,
onSend: onSend,
onBack: onBack
});
};
exports.RoomAccountDataEventEditor = RoomAccountDataEventEditor;
const BaseAccountDataExplorer = ({
events,
Editor,
actionLabel,
onBack,
setTool
}) => {
const [query, setQuery] = (0, _react.useState)("");
const [event, setEvent] = (0, _react.useState)(null);
if (event) {
const onBack = () => {
setEvent(null);
};
return /*#__PURE__*/_react.default.createElement(_Event.EventViewer, {
mxEvent: event,
onBack: onBack,
Editor: Editor
});
}
const onAction = async () => {
setTool(actionLabel, Editor);
};
return /*#__PURE__*/_react.default.createElement(_BaseTool.default, {
onBack: onBack,
actionLabel: actionLabel,
onAction: onAction
}, /*#__PURE__*/_react.default.createElement(_FilteredList.default, {
query: query,
onChange: setQuery
}, Array.from(events.entries()).map(([eventType, ev]) => {
const onClick = () => {
setEvent(ev);
};
return /*#__PURE__*/_react.default.createElement("button", {
className: "mx_DevTools_button",
key: eventType,
onClick: onClick
}, eventType);
})));
};
const AccountDataExplorer = ({
onBack,
setTool
}) => {
const cli = (0, _react.useContext)(_MatrixClientContext.default);
return /*#__PURE__*/_react.default.createElement(BaseAccountDataExplorer, {
events: cli.store.accountData,
Editor: AccountDataEventEditor,
actionLabel: (0, _languageHandler._td)("devtools|send_custom_account_data_event"),
onBack: onBack,
setTool: setTool
});
};
exports.AccountDataExplorer = AccountDataExplorer;
const RoomAccountDataExplorer = ({
onBack,
setTool
}) => {
const context = (0, _react.useContext)(_BaseTool.DevtoolsContext);
return /*#__PURE__*/_react.default.createElement(BaseAccountDataExplorer, {
events: context.room.accountData,
Editor: RoomAccountDataEventEditor,
actionLabel: (0, _languageHandler._td)("devtools|send_custom_room_account_data_event"),
onBack: onBack,
setTool: setTool
});
};
exports.RoomAccountDataExplorer = RoomAccountDataExplorer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_BaseTool","_MatrixClientContext","_interopRequireDefault","_Event","_FilteredList","_languageHandler","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","AccountDataEventEditor","mxEvent","onBack","cli","useContext","MatrixClientContext","fields","useMemo","eventTypeField","getType","onSend","eventType","content","setAccountData","defaultContent","stringify","getContent","undefined","createElement","EventEditor","fieldDefs","exports","RoomAccountDataEventEditor","context","DevtoolsContext","setRoomAccountData","room","roomId","BaseAccountDataExplorer","events","Editor","actionLabel","setTool","query","setQuery","useState","event","setEvent","EventViewer","onAction","onChange","Array","from","entries","map","ev","onClick","className","key","AccountDataExplorer","store","accountData","_td","RoomAccountDataExplorer"],"sources":["../../../../../src/components/views/dialogs/devtools/AccountData.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, useMemo, useState } from \"react\";\nimport { IContent, MatrixEvent } from \"matrix-js-sdk/src/matrix\";\n\nimport BaseTool, { DevtoolsContext, IDevtoolsProps } from \"./BaseTool\";\nimport MatrixClientContext from \"../../../../contexts/MatrixClientContext\";\nimport { EventEditor, EventViewer, eventTypeField, IEditorProps, stringify } from \"./Event\";\nimport FilteredList from \"./FilteredList\";\nimport { _td, TranslationKey } from \"../../../../languageHandler\";\n\nexport const AccountDataEventEditor: React.FC<IEditorProps> = ({ mxEvent, onBack }) => {\n    const cli = useContext(MatrixClientContext);\n\n    const fields = useMemo(() => [eventTypeField(mxEvent?.getType())], [mxEvent]);\n\n    const onSend = async ([eventType]: string[], content?: IContent): Promise<void> => {\n        await cli.setAccountData(eventType, content || {});\n    };\n\n    const defaultContent = mxEvent ? stringify(mxEvent.getContent()) : undefined;\n    return <EventEditor fieldDefs={fields} defaultContent={defaultContent} onSend={onSend} onBack={onBack} />;\n};\n\nexport const RoomAccountDataEventEditor: React.FC<IEditorProps> = ({ mxEvent, onBack }) => {\n    const context = useContext(DevtoolsContext);\n    const cli = useContext(MatrixClientContext);\n\n    const fields = useMemo(() => [eventTypeField(mxEvent?.getType())], [mxEvent]);\n\n    const onSend = async ([eventType]: string[], content?: IContent): Promise<void> => {\n        await cli.setRoomAccountData(context.room.roomId, eventType, content || {});\n    };\n\n    const defaultContent = mxEvent ? stringify(mxEvent.getContent()) : undefined;\n    return <EventEditor fieldDefs={fields} defaultContent={defaultContent} onSend={onSend} onBack={onBack} />;\n};\n\ninterface IProps extends IDevtoolsProps {\n    events: Map<string, MatrixEvent>;\n    Editor: React.FC<IEditorProps>;\n    actionLabel: TranslationKey;\n}\n\nconst BaseAccountDataExplorer: React.FC<IProps> = ({ events, Editor, actionLabel, onBack, setTool }) => {\n    const [query, setQuery] = useState(\"\");\n    const [event, setEvent] = useState<MatrixEvent | null>(null);\n\n    if (event) {\n        const onBack = (): void => {\n            setEvent(null);\n        };\n        return <EventViewer mxEvent={event} onBack={onBack} Editor={Editor} />;\n    }\n\n    const onAction = async (): Promise<void> => {\n        setTool(actionLabel, Editor);\n    };\n\n    return (\n        <BaseTool onBack={onBack} actionLabel={actionLabel} onAction={onAction}>\n            <FilteredList query={query} onChange={setQuery}>\n                {Array.from(events.entries()).map(([eventType, ev]) => {\n                    const onClick = (): void => {\n                        setEvent(ev);\n                    };\n\n                    return (\n                        <button className=\"mx_DevTools_button\" key={eventType} onClick={onClick}>\n                            {eventType}\n                        </button>\n                    );\n                })}\n            </FilteredList>\n        </BaseTool>\n    );\n};\n\nexport const AccountDataExplorer: React.FC<IDevtoolsProps> = ({ onBack, setTool }) => {\n    const cli = useContext(MatrixClientContext);\n\n    return (\n        <BaseAccountDataExplorer\n            events={cli.store.accountData}\n            Editor={AccountDataEventEditor}\n            actionLabel={_td(\"devtools|send_custom_account_data_event\")}\n            onBack={onBack}\n            setTool={setTool}\n        />\n    );\n};\n\nexport const RoomAccountDataExplorer: React.FC<IDevtoolsProps> = ({ onBack, setTool }) => {\n    const context = useContext(DevtoolsContext);\n\n    return (\n        <BaseAccountDataExplorer\n            events={context.room.accountData}\n            Editor={RoomAccountDataEventEditor}\n            actionLabel={_td(\"devtools|send_custom_room_account_data_event\")}\n            onBack={onBack}\n            setTool={setTool}\n        />\n    );\n};\n"],"mappings":"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","ignoreList":[]}