UNPKG

matrix-react-sdk

Version:
114 lines (111 loc) 20.1 kB
"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 _matrixWidgetApi = require("matrix-widget-api"); var _utils = require("matrix-js-sdk/src/utils"); var _BaseDialog = _interopRequireDefault(require("./BaseDialog")); var _languageHandler = require("../../../languageHandler"); var _objects = require("../../../utils/objects"); var _StyledCheckbox = _interopRequireDefault(require("../elements/StyledCheckbox")); var _DialogButtons = _interopRequireDefault(require("../elements/DialogButtons")); var _LabelledToggleSwitch = _interopRequireDefault(require("../elements/LabelledToggleSwitch")); var _CapabilityText = require("../../../widgets/CapabilityText"); /* Copyright 2024 New Vector Ltd. Copyright 2020, 2021 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. */ class WidgetCapabilitiesPromptDialog extends _react.default.PureComponent { constructor(props) { super(props); (0, _defineProperty2.default)(this, "eventPermissionsMap", new Map()); (0, _defineProperty2.default)(this, "onToggle", capability => { const newStates = (0, _objects.objectShallowClone)(this.state.booleanStates); newStates[capability] = !newStates[capability]; this.setState({ booleanStates: newStates }); }); (0, _defineProperty2.default)(this, "onRememberSelectionChange", newVal => { this.setState({ rememberSelection: newVal }); }); (0, _defineProperty2.default)(this, "onSubmit", async () => { this.closeAndTryRemember(Object.entries(this.state.booleanStates).filter(([_, isSelected]) => isSelected).map(([cap]) => cap)); }); (0, _defineProperty2.default)(this, "onReject", async () => { this.closeAndTryRemember([]); // nothing was approved }); const parsedEvents = _matrixWidgetApi.WidgetEventCapability.findEventCapabilities(this.props.requestedCapabilities); parsedEvents.forEach(e => this.eventPermissionsMap.set(e.raw, e)); const states = {}; this.props.requestedCapabilities.forEach(c => states[c] = true); this.state = { booleanStates: states, rememberSelection: true }; } closeAndTryRemember(approved) { this.props.onFinished({ approved, remember: this.state.rememberSelection }); } render() { // We specifically order the timeline capabilities down to the bottom. The capability text // generation cares strongly about this. const orderedCapabilities = Object.entries(this.state.booleanStates).sort(([capA], [capB]) => { const isTimelineA = (0, _matrixWidgetApi.isTimelineCapability)(capA); const isTimelineB = (0, _matrixWidgetApi.isTimelineCapability)(capB); if (!isTimelineA && !isTimelineB) return (0, _utils.lexicographicCompare)(capA, capB); if (isTimelineA && !isTimelineB) return 1; if (!isTimelineA && isTimelineB) return -1; if (isTimelineA && isTimelineB) return (0, _utils.lexicographicCompare)(capA, capB); return 0; }); const checkboxRows = orderedCapabilities.map(([cap, isChecked], i) => { const text = _CapabilityText.CapabilityText.for(cap, this.props.widgetKind); const byline = text.byline ? /*#__PURE__*/_react.default.createElement("span", { className: "mx_WidgetCapabilitiesPromptDialog_byline" }, text.byline) : null; return /*#__PURE__*/_react.default.createElement("div", { className: "mx_WidgetCapabilitiesPromptDialog_cap", key: cap + i }, /*#__PURE__*/_react.default.createElement(_StyledCheckbox.default, { checked: isChecked, onChange: () => this.onToggle(cap) }, text.primary), byline); }); return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, { className: "mx_WidgetCapabilitiesPromptDialog", onFinished: this.props.onFinished, title: (0, _languageHandler._t)("widget|capabilities_dialog|title") }, /*#__PURE__*/_react.default.createElement("form", { onSubmit: this.onSubmit }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_Dialog_content" }, /*#__PURE__*/_react.default.createElement("div", { className: "text-muted" }, (0, _languageHandler._t)("widget|capabilities_dialog|content_starting_text")), checkboxRows, /*#__PURE__*/_react.default.createElement(_DialogButtons.default, { primaryButton: (0, _languageHandler._t)("action|approve"), cancelButton: (0, _languageHandler._t)("widget|capabilities_dialog|decline_all_permission"), onPrimaryButtonClick: this.onSubmit, onCancel: this.onReject, additive: /*#__PURE__*/_react.default.createElement(_LabelledToggleSwitch.default, { value: this.state.rememberSelection, toggleInFront: true, onChange: this.onRememberSelectionChange, label: (0, _languageHandler._t)("widget|capabilities_dialog|remember_Selection") }) })))); } } exports.default = WidgetCapabilitiesPromptDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrixWidgetApi","_utils","_BaseDialog","_languageHandler","_objects","_StyledCheckbox","_DialogButtons","_LabelledToggleSwitch","_CapabilityText","WidgetCapabilitiesPromptDialog","React","PureComponent","constructor","props","_defineProperty2","default","Map","capability","newStates","objectShallowClone","state","booleanStates","setState","newVal","rememberSelection","closeAndTryRemember","Object","entries","filter","_","isSelected","map","cap","parsedEvents","WidgetEventCapability","findEventCapabilities","requestedCapabilities","forEach","e","eventPermissionsMap","set","raw","states","c","approved","onFinished","remember","render","orderedCapabilities","sort","capA","capB","isTimelineA","isTimelineCapability","isTimelineB","lexicographicCompare","checkboxRows","isChecked","i","text","CapabilityText","for","widgetKind","byline","createElement","className","key","checked","onChange","onToggle","primary","title","_t","onSubmit","primaryButton","cancelButton","onPrimaryButtonClick","onCancel","onReject","additive","value","toggleInFront","onRememberSelectionChange","label","exports"],"sources":["../../../../src/components/views/dialogs/WidgetCapabilitiesPromptDialog.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020, 2021 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 from \"react\";\nimport { Capability, isTimelineCapability, Widget, WidgetEventCapability, WidgetKind } from \"matrix-widget-api\";\nimport { lexicographicCompare } from \"matrix-js-sdk/src/utils\";\n\nimport BaseDialog from \"./BaseDialog\";\nimport { _t } from \"../../../languageHandler\";\nimport { objectShallowClone } from \"../../../utils/objects\";\nimport StyledCheckbox from \"../elements/StyledCheckbox\";\nimport DialogButtons from \"../elements/DialogButtons\";\nimport LabelledToggleSwitch from \"../elements/LabelledToggleSwitch\";\nimport { CapabilityText } from \"../../../widgets/CapabilityText\";\n\ninterface IProps {\n    requestedCapabilities: Set<Capability>;\n    widget: Widget;\n    widgetKind: WidgetKind; // TODO: Refactor into the Widget class\n    onFinished(result?: { approved: Capability[]; remember: boolean }): void;\n}\n\ntype BooleanStates = Partial<{\n    [capability in Capability]: boolean;\n}>;\n\ninterface IState {\n    booleanStates: BooleanStates;\n    rememberSelection: boolean;\n}\n\nexport default class WidgetCapabilitiesPromptDialog extends React.PureComponent<IProps, IState> {\n    private eventPermissionsMap = new Map<Capability, WidgetEventCapability>();\n\n    public constructor(props: IProps) {\n        super(props);\n\n        const parsedEvents = WidgetEventCapability.findEventCapabilities(this.props.requestedCapabilities);\n        parsedEvents.forEach((e) => this.eventPermissionsMap.set(e.raw, e));\n\n        const states: BooleanStates = {};\n        this.props.requestedCapabilities.forEach((c) => (states[c] = true));\n\n        this.state = {\n            booleanStates: states,\n            rememberSelection: true,\n        };\n    }\n\n    private onToggle = (capability: Capability): void => {\n        const newStates = objectShallowClone(this.state.booleanStates);\n        newStates[capability] = !newStates[capability];\n        this.setState({ booleanStates: newStates });\n    };\n\n    private onRememberSelectionChange = (newVal: boolean): void => {\n        this.setState({ rememberSelection: newVal });\n    };\n\n    private onSubmit = async (): Promise<void> => {\n        this.closeAndTryRemember(\n            Object.entries(this.state.booleanStates)\n                .filter(([_, isSelected]) => isSelected)\n                .map(([cap]) => cap),\n        );\n    };\n\n    private onReject = async (): Promise<void> => {\n        this.closeAndTryRemember([]); // nothing was approved\n    };\n\n    private closeAndTryRemember(approved: Capability[]): void {\n        this.props.onFinished({ approved, remember: this.state.rememberSelection });\n    }\n\n    public render(): React.ReactNode {\n        // We specifically order the timeline capabilities down to the bottom. The capability text\n        // generation cares strongly about this.\n        const orderedCapabilities = Object.entries(this.state.booleanStates).sort(([capA], [capB]) => {\n            const isTimelineA = isTimelineCapability(capA);\n            const isTimelineB = isTimelineCapability(capB);\n\n            if (!isTimelineA && !isTimelineB) return lexicographicCompare(capA, capB);\n            if (isTimelineA && !isTimelineB) return 1;\n            if (!isTimelineA && isTimelineB) return -1;\n            if (isTimelineA && isTimelineB) return lexicographicCompare(capA, capB);\n\n            return 0;\n        });\n        const checkboxRows = orderedCapabilities.map(([cap, isChecked], i) => {\n            const text = CapabilityText.for(cap, this.props.widgetKind);\n            const byline = text.byline ? (\n                <span className=\"mx_WidgetCapabilitiesPromptDialog_byline\">{text.byline}</span>\n            ) : null;\n\n            return (\n                <div className=\"mx_WidgetCapabilitiesPromptDialog_cap\" key={cap + i}>\n                    <StyledCheckbox checked={isChecked} onChange={() => this.onToggle(cap)}>\n                        {text.primary}\n                    </StyledCheckbox>\n                    {byline}\n                </div>\n            );\n        });\n\n        return (\n            <BaseDialog\n                className=\"mx_WidgetCapabilitiesPromptDialog\"\n                onFinished={this.props.onFinished}\n                title={_t(\"widget|capabilities_dialog|title\")}\n            >\n                <form onSubmit={this.onSubmit}>\n                    <div className=\"mx_Dialog_content\">\n                        <div className=\"text-muted\">{_t(\"widget|capabilities_dialog|content_starting_text\")}</div>\n                        {checkboxRows}\n                        <DialogButtons\n                            primaryButton={_t(\"action|approve\")}\n                            cancelButton={_t(\"widget|capabilities_dialog|decline_all_permission\")}\n                            onPrimaryButtonClick={this.onSubmit}\n                            onCancel={this.onReject}\n                            additive={\n                                <LabelledToggleSwitch\n                                    value={this.state.rememberSelection}\n                                    toggleInFront={true}\n                                    onChange={this.onRememberSelectionChange}\n                                    label={_t(\"widget|capabilities_dialog|remember_Selection\")}\n                                />\n                            }\n                        />\n                    </div>\n                </form>\n            </BaseDialog>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}