UNPKG

matrix-react-sdk

Version:
99 lines (91 loc) 17.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.PowerLevelSelector = PowerLevelSelector; var _react = _interopRequireWildcard(require("react")); var _compoundWeb = require("@vector-im/compound-web"); var _MatrixClientContext = require("../../../contexts/MatrixClientContext"); var _PowerSelector = _interopRequireDefault(require("../elements/PowerSelector")); var _languageHandler = require("../../../languageHandler"); 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 2024 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. */ /** * Display in a fieldset, the power level of the users and allow to change them. * The apply button is disabled until the power level of an user is changed. * If there is no user to display, the children is displayed instead. */ function PowerLevelSelector({ userLevels, canChangeLevels, currentUserLevel, onClick, filter, title, children }) { const matrixClient = (0, _MatrixClientContext.useMatrixClientContext)(); const [currentPowerLevel, setCurrentPowerLevel] = (0, _react.useState)(null); // If the power level has changed, we need to enable the apply button const powerLevelChanged = Boolean(currentPowerLevel && currentPowerLevel.value !== userLevels[currentPowerLevel?.userId]); const collator = new Intl.Collator(); // We sort the users by power level, then we filter them const users = Object.keys(userLevels).sort((userA, userB) => sortUser(collator, userA, userB, userLevels)).filter(filter); // No user to display, we return the children into fragment to convert it to JSX.Element type if (!users.length) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, children); return /*#__PURE__*/_react.default.createElement(_SettingsFieldset.default, { legend: title }, users.map(userId => { // We only want to display users with a valid power level aka an integer if (!Number.isInteger(userLevels[userId])) return; const isMe = userId === matrixClient.getUserId(); // If I can change levels, I can change the level of anyone with a lower level than mine const canChange = canChangeLevels && (userLevels[userId] < currentUserLevel || isMe); // When the new power level is selected, the fields are rerendered and we need to keep the current value const userLevel = currentPowerLevel?.userId === userId ? currentPowerLevel?.value : userLevels[userId]; return /*#__PURE__*/_react.default.createElement(_PowerSelector.default, { value: userLevel, disabled: !canChange, label: userId, key: userId, onChange: value => setCurrentPowerLevel({ value, userId }) }); }), /*#__PURE__*/_react.default.createElement(_compoundWeb.Button, { size: "sm", kind: "primary" // mx_Dialog_nonDialogButton is necessary to avoid the Dialog CSS to override the button style , className: "mx_Dialog_nonDialogButton mx_PowerLevelSelector_Button", onClick: () => { if (currentPowerLevel !== null) { onClick(currentPowerLevel.value, currentPowerLevel.userId); setCurrentPowerLevel(null); } }, disabled: !powerLevelChanged, "aria-label": (0, _languageHandler._t)("action|apply") }, (0, _languageHandler._t)("action|apply"))); } /** * Sort the users by power level, then by name * @param userA * @param userB * @param userLevels */ function sortUser(collator, userA, userB, userLevels) { const powerLevelDiff = userLevels[userA] - userLevels[userB]; return powerLevelDiff !== 0 ? powerLevelDiff : collator.compare(userA.toLocaleLowerCase(), userB.toLocaleLowerCase()); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_compoundWeb","_MatrixClientContext","_PowerSelector","_interopRequireDefault","_languageHandler","_SettingsFieldset","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","PowerLevelSelector","userLevels","canChangeLevels","currentUserLevel","onClick","filter","title","children","matrixClient","useMatrixClientContext","currentPowerLevel","setCurrentPowerLevel","useState","powerLevelChanged","Boolean","value","userId","collator","Intl","Collator","users","keys","sort","userA","userB","sortUser","length","createElement","Fragment","legend","map","Number","isInteger","isMe","getUserId","canChange","userLevel","disabled","label","key","onChange","Button","size","kind","className","_t","powerLevelDiff","compare","toLocaleLowerCase"],"sources":["../../../../src/components/views/settings/PowerLevelSelector.tsx"],"sourcesContent":["/*\n * Copyright 2024 New Vector Ltd.\n * Copyright 2024 The Matrix.org Foundation C.I.C.\n *\n * SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\n * Please see LICENSE files in the repository root for full details.\n */\n\nimport React, { useState, JSX, PropsWithChildren } from \"react\";\nimport { Button } from \"@vector-im/compound-web\";\n\nimport { useMatrixClientContext } from \"../../../contexts/MatrixClientContext\";\nimport PowerSelector from \"../elements/PowerSelector\";\nimport { _t } from \"../../../languageHandler\";\nimport SettingsFieldset from \"./SettingsFieldset\";\n\n/**\n * Display in a fieldset, the power level of the users and allow to change them.\n * The apply button is disabled until the power level of an user is changed.\n * If there is no user to display, the children is displayed instead.\n */\ninterface PowerLevelSelectorProps {\n    /**\n     * The power levels of the users\n     * The key is the user id and the value is the power level\n     */\n    userLevels: Record<string, number>;\n    /**\n     * Whether the user can change the power levels of other users\n     */\n    canChangeLevels: boolean;\n    /**\n     * The current user power level\n     */\n    currentUserLevel: number;\n    /**\n     * The callback when the apply button is clicked\n     * @param value - new power level for the user\n     * @param userId - the user id\n     */\n    onClick: (value: number, userId: string) => void;\n    /**\n     * Filter the users to display\n     * @param user\n     */\n    filter: (user: string) => boolean;\n    /**\n     * The title of the fieldset\n     */\n    title: string;\n}\n\nexport function PowerLevelSelector({\n    userLevels,\n    canChangeLevels,\n    currentUserLevel,\n    onClick,\n    filter,\n    title,\n    children,\n}: PropsWithChildren<PowerLevelSelectorProps>): JSX.Element | null {\n    const matrixClient = useMatrixClientContext();\n    const [currentPowerLevel, setCurrentPowerLevel] = useState<{ value: number; userId: string } | null>(null);\n\n    // If the power level has changed, we need to enable the apply button\n    const powerLevelChanged = Boolean(\n        currentPowerLevel && currentPowerLevel.value !== userLevels[currentPowerLevel?.userId],\n    );\n\n    const collator = new Intl.Collator();\n\n    // We sort the users by power level, then we filter them\n    const users = Object.keys(userLevels)\n        .sort((userA, userB) => sortUser(collator, userA, userB, userLevels))\n        .filter(filter);\n\n    // No user to display, we return the children into fragment to convert it to JSX.Element type\n    if (!users.length) return <>{children}</>;\n\n    return (\n        <SettingsFieldset legend={title}>\n            {users.map((userId) => {\n                // We only want to display users with a valid power level aka an integer\n                if (!Number.isInteger(userLevels[userId])) return;\n\n                const isMe = userId === matrixClient.getUserId();\n                // If I can change levels, I can change the level of anyone with a lower level than mine\n                const canChange = canChangeLevels && (userLevels[userId] < currentUserLevel || isMe);\n\n                // When the new power level is selected, the fields are rerendered and we need to keep the current value\n                const userLevel = currentPowerLevel?.userId === userId ? currentPowerLevel?.value : userLevels[userId];\n\n                return (\n                    <PowerSelector\n                        value={userLevel}\n                        disabled={!canChange}\n                        label={userId}\n                        key={userId}\n                        onChange={(value) => setCurrentPowerLevel({ value, userId })}\n                    />\n                );\n            })}\n\n            <Button\n                size=\"sm\"\n                kind=\"primary\"\n                // mx_Dialog_nonDialogButton is necessary to avoid the Dialog CSS to override the button style\n                className=\"mx_Dialog_nonDialogButton mx_PowerLevelSelector_Button\"\n                onClick={() => {\n                    if (currentPowerLevel !== null) {\n                        onClick(currentPowerLevel.value, currentPowerLevel.userId);\n                        setCurrentPowerLevel(null);\n                    }\n                }}\n                disabled={!powerLevelChanged}\n                aria-label={_t(\"action|apply\")}\n            >\n                {_t(\"action|apply\")}\n            </Button>\n        </SettingsFieldset>\n    );\n}\n\n/**\n * Sort the users by power level, then by name\n * @param userA\n * @param userB\n * @param userLevels\n */\nfunction sortUser(\n    collator: Intl.Collator,\n    userA: string,\n    userB: string,\n    userLevels: PowerLevelSelectorProps[\"userLevels\"],\n): number {\n    const powerLevelDiff = userLevels[userA] - userLevels[userB];\n    return powerLevelDiff !== 0\n        ? powerLevelDiff\n        : collator.compare(userA.toLocaleLowerCase(), userB.toLocaleLowerCase());\n}\n"],"mappings":";;;;;;;AAQA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,YAAA,GAAAD,OAAA;AAEA,IAAAE,oBAAA,GAAAF,OAAA;AACA,IAAAG,cAAA,GAAAC,sBAAA,CAAAJ,OAAA;AACA,IAAAK,gBAAA,GAAAL,OAAA;AACA,IAAAM,iBAAA,GAAAF,sBAAA,CAAAJ,OAAA;AAAkD,SAAAO,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAT,wBAAAS,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAdlD;AACA;AACA;AACA;AACA;AACA;AACA;;AAUA;AACA;AACA;AACA;AACA;;AAgCO,SAASW,kBAAkBA,CAAC;EAC/BC,UAAU;EACVC,eAAe;EACfC,gBAAgB;EAChBC,OAAO;EACPC,MAAM;EACNC,KAAK;EACLC;AACwC,CAAC,EAAsB;EAC/D,MAAMC,YAAY,GAAG,IAAAC,2CAAsB,EAAC,CAAC;EAC7C,MAAM,CAACC,iBAAiB,EAAEC,oBAAoB,CAAC,GAAG,IAAAC,eAAQ,EAA2C,IAAI,CAAC;;EAE1G;EACA,MAAMC,iBAAiB,GAAGC,OAAO,CAC7BJ,iBAAiB,IAAIA,iBAAiB,CAACK,KAAK,KAAKd,UAAU,CAACS,iBAAiB,EAAEM,MAAM,CACzF,CAAC;EAED,MAAMC,QAAQ,GAAG,IAAIC,IAAI,CAACC,QAAQ,CAAC,CAAC;;EAEpC;EACA,MAAMC,KAAK,GAAG5B,MAAM,CAAC6B,IAAI,CAACpB,UAAU,CAAC,CAChCqB,IAAI,CAAC,CAACC,KAAK,EAAEC,KAAK,KAAKC,QAAQ,CAACR,QAAQ,EAAEM,KAAK,EAAEC,KAAK,EAAEvB,UAAU,CAAC,CAAC,CACpEI,MAAM,CAACA,MAAM,CAAC;;EAEnB;EACA,IAAI,CAACe,KAAK,CAACM,MAAM,EAAE,oBAAOvD,MAAA,CAAAe,OAAA,CAAAyC,aAAA,CAAAxD,MAAA,CAAAe,OAAA,CAAA0C,QAAA,QAAGrB,QAAW,CAAC;EAEzC,oBACIpC,MAAA,CAAAe,OAAA,CAAAyC,aAAA,CAAChD,iBAAA,CAAAO,OAAgB;IAAC2C,MAAM,EAAEvB;EAAM,GAC3Bc,KAAK,CAACU,GAAG,CAAEd,MAAM,IAAK;IACnB;IACA,IAAI,CAACe,MAAM,CAACC,SAAS,CAAC/B,UAAU,CAACe,MAAM,CAAC,CAAC,EAAE;IAE3C,MAAMiB,IAAI,GAAGjB,MAAM,KAAKR,YAAY,CAAC0B,SAAS,CAAC,CAAC;IAChD;IACA,MAAMC,SAAS,GAAGjC,eAAe,KAAKD,UAAU,CAACe,MAAM,CAAC,GAAGb,gBAAgB,IAAI8B,IAAI,CAAC;;IAEpF;IACA,MAAMG,SAAS,GAAG1B,iBAAiB,EAAEM,MAAM,KAAKA,MAAM,GAAGN,iBAAiB,EAAEK,KAAK,GAAGd,UAAU,CAACe,MAAM,CAAC;IAEtG,oBACI7C,MAAA,CAAAe,OAAA,CAAAyC,aAAA,CAACnD,cAAA,CAAAU,OAAa;MACV6B,KAAK,EAAEqB,SAAU;MACjBC,QAAQ,EAAE,CAACF,SAAU;MACrBG,KAAK,EAAEtB,MAAO;MACduB,GAAG,EAAEvB,MAAO;MACZwB,QAAQ,EAAGzB,KAAK,IAAKJ,oBAAoB,CAAC;QAAEI,KAAK;QAAEC;MAAO,CAAC;IAAE,CAChE,CAAC;EAEV,CAAC,CAAC,eAEF7C,MAAA,CAAAe,OAAA,CAAAyC,aAAA,CAACrD,YAAA,CAAAmE,MAAM;IACHC,IAAI,EAAC,IAAI;IACTC,IAAI,EAAC;IACL;IAAA;IACAC,SAAS,EAAC,wDAAwD;IAClExC,OAAO,EAAEA,CAAA,KAAM;MACX,IAAIM,iBAAiB,KAAK,IAAI,EAAE;QAC5BN,OAAO,CAACM,iBAAiB,CAACK,KAAK,EAAEL,iBAAiB,CAACM,MAAM,CAAC;QAC1DL,oBAAoB,CAAC,IAAI,CAAC;MAC9B;IACJ,CAAE;IACF0B,QAAQ,EAAE,CAACxB,iBAAkB;IAC7B,cAAY,IAAAgC,mBAAE,EAAC,cAAc;EAAE,GAE9B,IAAAA,mBAAE,EAAC,cAAc,CACd,CACM,CAAC;AAE3B;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAASpB,QAAQA,CACbR,QAAuB,EACvBM,KAAa,EACbC,KAAa,EACbvB,UAAiD,EAC3C;EACN,MAAM6C,cAAc,GAAG7C,UAAU,CAACsB,KAAK,CAAC,GAAGtB,UAAU,CAACuB,KAAK,CAAC;EAC5D,OAAOsB,cAAc,KAAK,CAAC,GACrBA,cAAc,GACd7B,QAAQ,CAAC8B,OAAO,CAACxB,KAAK,CAACyB,iBAAiB,CAAC,CAAC,EAAExB,KAAK,CAACwB,iBAAiB,CAAC,CAAC,CAAC;AAChF","ignoreList":[]}