matrix-react-sdk
Version:
SDK for matrix.org using React
173 lines (169 loc) • 26.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var Roles = _interopRequireWildcard(require("../../../Roles"));
var _languageHandler = require("../../../languageHandler");
var _Field = _interopRequireDefault(require("./Field"));
var _KeyboardShortcuts = require("../../../accessibility/KeyboardShortcuts");
var _KeyBindingsManager = require("../../../KeyBindingsManager");
var _objects = require("../../../utils/objects");
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 2015, 2016 OpenMarket Ltd
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
const CUSTOM_VALUE = "SELECT_VALUE_CUSTOM";
class PowerSelector extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "unmounted", false);
(0, _defineProperty2.default)(this, "onSelectChange", async event => {
const isCustom = event.target.value === CUSTOM_VALUE;
if (isCustom) {
this.setState({
custom: true
});
} else {
const powerLevel = parseInt(event.target.value);
this.setState({
selectValue: powerLevel
});
try {
await this.props.onChange(powerLevel, this.props.powerLevelKey);
} catch {
if (this.unmounted) return;
// If the request failed, roll back the state of the selector.
this.initStateFromProps();
}
}
});
(0, _defineProperty2.default)(this, "onCustomChange", event => {
this.setState({
customValue: parseInt(event.target.value)
});
});
(0, _defineProperty2.default)(this, "onCustomBlur", async event => {
event.preventDefault();
event.stopPropagation();
if (Number.isFinite(this.state.customValue)) {
try {
await this.props.onChange(this.state.customValue, this.props.powerLevelKey);
} catch {
if (this.unmounted) return;
// If the request failed, roll back the state of the selector.
this.initStateFromProps();
}
} else {
this.initStateFromProps(); // reset, invalid input
}
});
(0, _defineProperty2.default)(this, "onCustomKeyDown", event => {
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(event);
switch (action) {
case _KeyboardShortcuts.KeyBindingAction.Enter:
event.preventDefault();
event.stopPropagation();
// Do not call the onChange handler directly here - it can cause an infinite loop.
// Long story short, a user hits Enter to submit the value which onChange handles as
// raising a dialog which causes a blur which causes a dialog which causes a blur and
// so on. By not causing the onChange to be called here, we avoid the loop because we
// handle the onBlur safely.
event.target.blur();
break;
}
});
this.state = {
levelRoleMap: {},
// List of power levels to show in the drop-down
options: [],
customValue: this.props.value,
selectValue: 0
};
}
componentDidMount() {
this.initStateFromProps();
}
componentDidUpdate(prevProps) {
if ((0, _objects.objectHasDiff)(this.props, prevProps)) {
this.initStateFromProps();
}
}
componentWillUnmount() {
this.unmounted = true;
}
initStateFromProps() {
// This needs to be done now because levelRoleMap has translated strings
const levelRoleMap = Roles.levelRoleMap(this.props.usersDefault);
const options = Object.keys(levelRoleMap).filter(level => {
return level === undefined || parseInt(level) <= this.props.maxValue || parseInt(level) == this.props.value;
}).map(level => parseInt(level));
const isCustom = levelRoleMap[this.props.value] === undefined;
this.setState({
levelRoleMap,
options,
custom: isCustom,
customValue: this.props.value,
selectValue: isCustom ? CUSTOM_VALUE : this.props.value
});
}
render() {
let picker;
const label = typeof this.props.label === "undefined" ? (0, _languageHandler._t)("power_level|label") : this.props.label;
if (this.state.custom) {
picker = /*#__PURE__*/_react.default.createElement(_Field.default, {
type: "number",
label: label,
max: this.props.maxValue,
onBlur: this.onCustomBlur,
onKeyDown: this.onCustomKeyDown,
onChange: this.onCustomChange,
value: String(this.state.customValue),
disabled: this.props.disabled
});
} else {
// Each level must have a definition in this.state.levelRoleMap
const options = this.state.options.map(level => {
return {
value: String(level),
text: Roles.textualPowerLevel(level, this.props.usersDefault)
};
});
options.push({
value: CUSTOM_VALUE,
text: (0, _languageHandler._t)("power_level|custom_level")
});
const optionsElements = options.map(op => {
return /*#__PURE__*/_react.default.createElement("option", {
value: op.value,
key: op.value,
"data-testid": `power-level-option-${op.value}`
}, op.text);
});
picker = /*#__PURE__*/_react.default.createElement(_Field.default, {
element: "select",
label: label,
onChange: this.onSelectChange,
value: String(this.state.selectValue),
disabled: this.props.disabled,
"data-testid": "power-level-select-element"
}, optionsElements);
}
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PowerSelector"
}, picker);
}
}
exports.default = PowerSelector;
(0, _defineProperty2.default)(PowerSelector, "defaultProps", {
maxValue: Infinity,
usersDefault: 0
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","Roles","_interopRequireWildcard","_languageHandler","_Field","_KeyboardShortcuts","_KeyBindingsManager","_objects","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","CUSTOM_VALUE","PowerSelector","React","Component","constructor","props","_defineProperty2","event","isCustom","target","value","setState","custom","powerLevel","parseInt","selectValue","onChange","powerLevelKey","unmounted","initStateFromProps","customValue","preventDefault","stopPropagation","Number","isFinite","state","action","getKeyBindingsManager","getAccessibilityAction","KeyBindingAction","Enter","blur","levelRoleMap","options","componentDidMount","componentDidUpdate","prevProps","objectHasDiff","componentWillUnmount","usersDefault","keys","filter","level","undefined","maxValue","map","render","picker","label","_t","createElement","type","max","onBlur","onCustomBlur","onKeyDown","onCustomKeyDown","onCustomChange","String","disabled","text","textualPowerLevel","push","optionsElements","op","key","element","onSelectChange","className","exports","Infinity"],"sources":["../../../../src/components/views/elements/PowerSelector.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2015, 2016 OpenMarket Ltd\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 from \"react\";\n\nimport * as Roles from \"../../../Roles\";\nimport { _t } from \"../../../languageHandler\";\nimport Field from \"./Field\";\nimport { KeyBindingAction } from \"../../../accessibility/KeyboardShortcuts\";\nimport { getKeyBindingsManager } from \"../../../KeyBindingsManager\";\nimport { objectHasDiff } from \"../../../utils/objects\";\n\nconst CUSTOM_VALUE = \"SELECT_VALUE_CUSTOM\";\n\ninterface Props<K extends undefined | string> {\n    value: number;\n    // The maximum value that can be set with the power selector\n    maxValue: number;\n\n    // Default user power level for the room\n    usersDefault: number;\n\n    // should the user be able to change the value? false by default.\n    disabled?: boolean;\n\n    // The name to annotate the selector with\n    label?: string;\n\n    onChange(value: number, powerLevelKey: K extends undefined ? void : K): void | Promise<void>;\n\n    // Optional key to pass as the second argument to `onChange`\n    powerLevelKey: K extends undefined ? void : K;\n}\n\ninterface IState {\n    levelRoleMap: Partial<Record<number | \"undefined\", string>>;\n    // List of power levels to show in the drop-down\n    options: number[];\n\n    customValue: number;\n    selectValue: number | string;\n    custom?: boolean;\n}\n\nexport default class PowerSelector<K extends undefined | string> extends React.Component<Props<K>, IState> {\n    public static defaultProps: Partial<Props<any>> = {\n        maxValue: Infinity,\n        usersDefault: 0,\n    };\n    private unmounted = false;\n\n    public constructor(props: Props<K>) {\n        super(props);\n\n        this.state = {\n            levelRoleMap: {},\n            // List of power levels to show in the drop-down\n            options: [],\n\n            customValue: this.props.value,\n            selectValue: 0,\n        };\n    }\n\n    public componentDidMount(): void {\n        this.initStateFromProps();\n    }\n\n    public componentDidUpdate(prevProps: Readonly<Props<K>>): void {\n        if (objectHasDiff(this.props, prevProps)) {\n            this.initStateFromProps();\n        }\n    }\n\n    public componentWillUnmount(): void {\n        this.unmounted = true;\n    }\n\n    private initStateFromProps(): void {\n        // This needs to be done now because levelRoleMap has translated strings\n        const levelRoleMap = Roles.levelRoleMap(this.props.usersDefault);\n        const options = Object.keys(levelRoleMap)\n            .filter((level) => {\n                return (\n                    level === undefined || parseInt(level) <= this.props.maxValue || parseInt(level) == this.props.value\n                );\n            })\n            .map((level) => parseInt(level));\n\n        const isCustom = levelRoleMap[this.props.value] === undefined;\n\n        this.setState({\n            levelRoleMap,\n            options,\n            custom: isCustom,\n            customValue: this.props.value,\n            selectValue: isCustom ? CUSTOM_VALUE : this.props.value,\n        });\n    }\n\n    private onSelectChange = async (event: React.ChangeEvent<HTMLSelectElement>): Promise<void> => {\n        const isCustom = event.target.value === CUSTOM_VALUE;\n        if (isCustom) {\n            this.setState({ custom: true });\n        } else {\n            const powerLevel = parseInt(event.target.value);\n            this.setState({ selectValue: powerLevel });\n            try {\n                await this.props.onChange(powerLevel, this.props.powerLevelKey);\n            } catch {\n                if (this.unmounted) return;\n                // If the request failed, roll back the state of the selector.\n                this.initStateFromProps();\n            }\n        }\n    };\n\n    private onCustomChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n        this.setState({ customValue: parseInt(event.target.value) });\n    };\n\n    private onCustomBlur = async (event: React.FocusEvent): Promise<void> => {\n        event.preventDefault();\n        event.stopPropagation();\n\n        if (Number.isFinite(this.state.customValue)) {\n            try {\n                await this.props.onChange(this.state.customValue, this.props.powerLevelKey);\n            } catch {\n                if (this.unmounted) return;\n                // If the request failed, roll back the state of the selector.\n                this.initStateFromProps();\n            }\n        } else {\n            this.initStateFromProps(); // reset, invalid input\n        }\n    };\n\n    private onCustomKeyDown = (event: React.KeyboardEvent<HTMLInputElement>): void => {\n        const action = getKeyBindingsManager().getAccessibilityAction(event);\n        switch (action) {\n            case KeyBindingAction.Enter:\n                event.preventDefault();\n                event.stopPropagation();\n\n                // Do not call the onChange handler directly here - it can cause an infinite loop.\n                // Long story short, a user hits Enter to submit the value which onChange handles as\n                // raising a dialog which causes a blur which causes a dialog which causes a blur and\n                // so on. By not causing the onChange to be called here, we avoid the loop because we\n                // handle the onBlur safely.\n                (event.target as HTMLInputElement).blur();\n                break;\n        }\n    };\n\n    public render(): React.ReactNode {\n        let picker;\n        const label = typeof this.props.label === \"undefined\" ? _t(\"power_level|label\") : this.props.label;\n        if (this.state.custom) {\n            picker = (\n                <Field\n                    type=\"number\"\n                    label={label}\n                    max={this.props.maxValue}\n                    onBlur={this.onCustomBlur}\n                    onKeyDown={this.onCustomKeyDown}\n                    onChange={this.onCustomChange}\n                    value={String(this.state.customValue)}\n                    disabled={this.props.disabled}\n                />\n            );\n        } else {\n            // Each level must have a definition in this.state.levelRoleMap\n            const options = this.state.options.map((level) => {\n                return {\n                    value: String(level),\n                    text: Roles.textualPowerLevel(level, this.props.usersDefault),\n                };\n            });\n            options.push({ value: CUSTOM_VALUE, text: _t(\"power_level|custom_level\") });\n            const optionsElements = options.map((op) => {\n                return (\n                    <option value={op.value} key={op.value} data-testid={`power-level-option-${op.value}`}>\n                        {op.text}\n                    </option>\n                );\n            });\n\n            picker = (\n                <Field\n                    element=\"select\"\n                    label={label}\n                    onChange={this.onSelectChange}\n                    value={String(this.state.selectValue)}\n                    disabled={this.props.disabled}\n                    data-testid=\"power-level-select-element\"\n                >\n                    {optionsElements}\n                </Field>\n            );\n        }\n\n        return <div className=\"mx_PowerSelector\">{picker}</div>;\n    }\n}\n"],"mappings":"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","ignoreList":[]}