UNPKG

matrix-react-sdk

Version:
114 lines (109 loc) 20.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.hasLowerOrEqualLevelThanDefaultLevel = exports.getUserIdsFromCompletions = exports.AddPrivilegedUsers = void 0; var _react = _interopRequireWildcard(require("react")); var _matrix = require("matrix-js-sdk/src/matrix"); var _languageHandler = require("../../../languageHandler"); var _UserProvider = _interopRequireDefault(require("../../../autocomplete/UserProvider")); var _AutocompleteInput = require("../../structures/AutocompleteInput"); var _PowerSelector = _interopRequireDefault(require("../elements/PowerSelector")); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _Modal = _interopRequireDefault(require("../../../Modal")); var _ErrorDialog = _interopRequireDefault(require("../dialogs/ErrorDialog")); var _SettingsFieldset = _interopRequireDefault(require("./SettingsFieldset")); 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 AddPrivilegedUsers = ({ room, defaultUserLevel }) => { const client = (0, _react.useContext)(_MatrixClientContext.default); const userProvider = (0, _react.useRef)(new _UserProvider.default(room)); const [isLoading, setIsLoading] = (0, _react.useState)(false); const [powerLevel, setPowerLevel] = (0, _react.useState)(defaultUserLevel); const [selectedUsers, setSelectedUsers] = (0, _react.useState)([]); const hasLowerOrEqualLevelThanDefaultLevelFilter = (0, _react.useCallback)(user => hasLowerOrEqualLevelThanDefaultLevel(room, user, defaultUserLevel), [room, defaultUserLevel]); const onSubmit = async event => { event.preventDefault(); setIsLoading(true); const userIds = getUserIdsFromCompletions(selectedUsers); const powerLevelEvent = room.currentState.getStateEvents(_matrix.EventType.RoomPowerLevels, ""); // `RoomPowerLevels` event should exist, but technically it is not guaranteed. if (powerLevelEvent === null) { _Modal.default.createDialog(_ErrorDialog.default, { title: (0, _languageHandler._t)("common|error"), description: (0, _languageHandler._t)("error|update_power_level") }); return; } try { await client.setPowerLevel(room.roomId, userIds, powerLevel); setSelectedUsers([]); setPowerLevel(defaultUserLevel); } catch (error) { _Modal.default.createDialog(_ErrorDialog.default, { title: (0, _languageHandler._t)("common|error"), description: (0, _languageHandler._t)("error|update_power_level") }); } finally { setIsLoading(false); } }; return /*#__PURE__*/_react.default.createElement("form", { style: { display: "flex" }, onSubmit: onSubmit }, /*#__PURE__*/_react.default.createElement(_SettingsFieldset.default, { legend: (0, _languageHandler._t)("room_settings|permissions|add_privileged_user_heading"), description: (0, _languageHandler._t)("room_settings|permissions|add_privileged_user_description"), style: { flexGrow: 1 } }, /*#__PURE__*/_react.default.createElement(_AutocompleteInput.AutocompleteInput, { provider: userProvider.current, placeholder: (0, _languageHandler._t)("room_settings|permissions|add_privileged_user_filter_placeholder"), onSelectionChange: setSelectedUsers, selection: selectedUsers, additionalFilter: hasLowerOrEqualLevelThanDefaultLevelFilter }), /*#__PURE__*/_react.default.createElement(_PowerSelector.default, { value: powerLevel, onChange: setPowerLevel }), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { type: "submit", element: "button", kind: "primary", disabled: !selectedUsers.length || isLoading, onClick: null, "data-testid": "add-privileged-users-submit-button" }, (0, _languageHandler._t)("action|apply")))); }; exports.AddPrivilegedUsers = AddPrivilegedUsers; const hasLowerOrEqualLevelThanDefaultLevel = (room, user, defaultUserLevel) => { if (user.completionId === undefined) { return false; } const member = room.getMember(user.completionId); if (member === null) { return false; } return member.powerLevel <= defaultUserLevel; }; exports.hasLowerOrEqualLevelThanDefaultLevel = hasLowerOrEqualLevelThanDefaultLevel; const getUserIdsFromCompletions = completions => { const completionsWithId = completions.filter(completion => completion.completionId !== undefined); // undefined completionId's are filtered out above but TypeScript does not seem to understand. return completionsWithId.map(completion => completion.completionId); }; exports.getUserIdsFromCompletions = getUserIdsFromCompletions; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_languageHandler","_UserProvider","_interopRequireDefault","_AutocompleteInput","_PowerSelector","_MatrixClientContext","_AccessibleButton","_Modal","_ErrorDialog","_SettingsFieldset","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","AddPrivilegedUsers","room","defaultUserLevel","client","useContext","MatrixClientContext","userProvider","useRef","UserProvider","isLoading","setIsLoading","useState","powerLevel","setPowerLevel","selectedUsers","setSelectedUsers","hasLowerOrEqualLevelThanDefaultLevelFilter","useCallback","user","hasLowerOrEqualLevelThanDefaultLevel","onSubmit","event","preventDefault","userIds","getUserIdsFromCompletions","powerLevelEvent","currentState","getStateEvents","EventType","RoomPowerLevels","Modal","createDialog","ErrorDialog","title","_t","description","roomId","error","createElement","style","display","legend","flexGrow","AutocompleteInput","provider","current","placeholder","onSelectionChange","selection","additionalFilter","value","onChange","type","element","kind","disabled","length","onClick","exports","completionId","undefined","member","getMember","completions","completionsWithId","filter","completion","map"],"sources":["../../../../src/components/views/settings/AddPrivilegedUsers.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, { FormEvent, useCallback, useContext, useRef, useState } from \"react\";\nimport { Room, EventType } from \"matrix-js-sdk/src/matrix\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { ICompletion } from \"../../../autocomplete/Autocompleter\";\nimport UserProvider from \"../../../autocomplete/UserProvider\";\nimport { AutocompleteInput } from \"../../structures/AutocompleteInput\";\nimport PowerSelector from \"../elements/PowerSelector\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport Modal from \"../../../Modal\";\nimport ErrorDialog from \"../dialogs/ErrorDialog\";\nimport SettingsFieldset from \"./SettingsFieldset\";\n\ninterface AddPrivilegedUsersProps {\n    room: Room;\n    defaultUserLevel: number;\n}\n\nexport const AddPrivilegedUsers: React.FC<AddPrivilegedUsersProps> = ({ room, defaultUserLevel }) => {\n    const client = useContext(MatrixClientContext);\n    const userProvider = useRef(new UserProvider(room));\n    const [isLoading, setIsLoading] = useState<boolean>(false);\n    const [powerLevel, setPowerLevel] = useState<number>(defaultUserLevel);\n    const [selectedUsers, setSelectedUsers] = useState<ICompletion[]>([]);\n    const hasLowerOrEqualLevelThanDefaultLevelFilter = useCallback(\n        (user: ICompletion) => hasLowerOrEqualLevelThanDefaultLevel(room, user, defaultUserLevel),\n        [room, defaultUserLevel],\n    );\n\n    const onSubmit = async (event: FormEvent): Promise<void> => {\n        event.preventDefault();\n        setIsLoading(true);\n\n        const userIds = getUserIdsFromCompletions(selectedUsers);\n        const powerLevelEvent = room.currentState.getStateEvents(EventType.RoomPowerLevels, \"\");\n\n        // `RoomPowerLevels` event should exist, but technically it is not guaranteed.\n        if (powerLevelEvent === null) {\n            Modal.createDialog(ErrorDialog, {\n                title: _t(\"common|error\"),\n                description: _t(\"error|update_power_level\"),\n            });\n\n            return;\n        }\n\n        try {\n            await client.setPowerLevel(room.roomId, userIds, powerLevel);\n            setSelectedUsers([]);\n            setPowerLevel(defaultUserLevel);\n        } catch (error) {\n            Modal.createDialog(ErrorDialog, {\n                title: _t(\"common|error\"),\n                description: _t(\"error|update_power_level\"),\n            });\n        } finally {\n            setIsLoading(false);\n        }\n    };\n\n    return (\n        <form style={{ display: \"flex\" }} onSubmit={onSubmit}>\n            <SettingsFieldset\n                legend={_t(\"room_settings|permissions|add_privileged_user_heading\")}\n                description={_t(\"room_settings|permissions|add_privileged_user_description\")}\n                style={{ flexGrow: 1 }}\n            >\n                <AutocompleteInput\n                    provider={userProvider.current}\n                    placeholder={_t(\"room_settings|permissions|add_privileged_user_filter_placeholder\")}\n                    onSelectionChange={setSelectedUsers}\n                    selection={selectedUsers}\n                    additionalFilter={hasLowerOrEqualLevelThanDefaultLevelFilter}\n                />\n                <PowerSelector value={powerLevel} onChange={setPowerLevel} />\n                <AccessibleButton\n                    type=\"submit\"\n                    element=\"button\"\n                    kind=\"primary\"\n                    disabled={!selectedUsers.length || isLoading}\n                    onClick={null}\n                    data-testid=\"add-privileged-users-submit-button\"\n                >\n                    {_t(\"action|apply\")}\n                </AccessibleButton>\n            </SettingsFieldset>\n        </form>\n    );\n};\n\nexport const hasLowerOrEqualLevelThanDefaultLevel = (\n    room: Room,\n    user: ICompletion,\n    defaultUserLevel: number,\n): boolean => {\n    if (user.completionId === undefined) {\n        return false;\n    }\n\n    const member = room.getMember(user.completionId);\n\n    if (member === null) {\n        return false;\n    }\n\n    return member.powerLevel <= defaultUserLevel;\n};\n\nexport const getUserIdsFromCompletions = (completions: ICompletion[]): string[] => {\n    const completionsWithId = completions.filter((completion) => completion.completionId !== undefined);\n\n    // undefined completionId's are filtered out above but TypeScript does not seem to understand.\n    return completionsWithId.map((completion) => completion.completionId!);\n};\n"],"mappings":"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","ignoreList":[]}