UNPKG

matrix-react-sdk

Version:
148 lines (124 loc) 18.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.getRememberedCapabilitiesForWidget = getRememberedCapabilitiesForWidget; exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _BaseDialog = _interopRequireDefault(require("./BaseDialog")); var _languageHandler = require("../../../languageHandler"); var _matrixWidgetApi = require("matrix-widget-api"); 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"); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _temp; function getRememberedCapabilitiesForWidget(widget /*: Widget*/ ) /*: Capability[]*/ { return JSON.parse(localStorage.getItem(`widget_${widget.id}_approved_caps`) || "[]"); } function setRememberedCapabilitiesForWidget(widget /*: Widget*/ , caps /*: Capability[]*/ ) { localStorage.setItem(`widget_${widget.id}_approved_caps`, JSON.stringify(caps)); } let WidgetCapabilitiesPromptDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.WidgetCapabilitiesPromptDialog"), _dec(_class = (_temp = class WidgetCapabilitiesPromptDialog extends _react.default.PureComponent /*:: <IProps, IState>*/ { constructor(props /*: IProps*/ ) { super(props); (0, _defineProperty2.default)(this, "eventPermissionsMap", new Map()); (0, _defineProperty2.default)(this, "onToggle", (capability /*: Capability*/ ) => { const newStates = (0, _objects.objectShallowClone)(this.state.booleanStates); newStates[capability] = !newStates[capability]; this.setState({ booleanStates: newStates }); }); (0, _defineProperty2.default)(this, "onRememberSelectionChange", (newVal /*: boolean*/ ) => { this.setState({ rememberSelection: newVal }); }); (0, _defineProperty2.default)(this, "onSubmit", async ev => { this.closeAndTryRemember(Object.entries(this.state.booleanStates).filter(([_, isSelected]) => isSelected).map(([cap]) => cap)); }); (0, _defineProperty2.default)(this, "onReject", async ev => { this.closeAndTryRemember([]); // nothing was approved }); const parsedEvents = _matrixWidgetApi.WidgetEventCapability.findEventCapabilities(this.props.requestedCapabilities); parsedEvents.forEach(e => this.eventPermissionsMap.set(e.raw, e)); const states /*: IBooleanStates*/ = {}; this.props.requestedCapabilities.forEach(c => states[c] = true); this.state = { booleanStates: states, rememberSelection: true }; } closeAndTryRemember(approved /*: Capability[]*/ ) { if (this.state.rememberSelection) { setRememberedCapabilitiesForWidget(this.props.widget, approved); } this.props.onFinished({ approved }); } render() { const checkboxRows = Object.entries(this.state.booleanStates).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)("Approve widget permissions") }, /*#__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)("This widget would like to:")), checkboxRows, /*#__PURE__*/_react.default.createElement(_DialogButtons.default, { primaryButton: (0, _languageHandler._t)("Approve"), cancelButton: (0, _languageHandler._t)("Decline All"), 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)("Remember my selection for this widget") }) })))); } }, _temp)) || _class); exports.default = WidgetCapabilitiesPromptDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/WidgetCapabilitiesPromptDialog.tsx"],"names":["getRememberedCapabilitiesForWidget","widget","JSON","parse","localStorage","getItem","id","setRememberedCapabilitiesForWidget","caps","setItem","stringify","WidgetCapabilitiesPromptDialog","React","PureComponent","constructor","props","Map","capability","newStates","state","booleanStates","setState","newVal","rememberSelection","ev","closeAndTryRemember","Object","entries","filter","_","isSelected","map","cap","parsedEvents","WidgetEventCapability","findEventCapabilities","requestedCapabilities","forEach","e","eventPermissionsMap","set","raw","states","c","approved","onFinished","render","checkboxRows","isChecked","i","text","CapabilityText","for","widgetKind","byline","onToggle","primary","onSubmit","onReject","onRememberSelectionChange"],"mappings":"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","sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport React from 'react';\nimport BaseDialog from \"./BaseDialog\";\nimport { _t } from \"../../../languageHandler\";\nimport { IDialogProps } from \"./IDialogProps\";\nimport {\n    Capability,\n    Widget,\n    WidgetEventCapability,\n    WidgetKind,\n} from \"matrix-widget-api\";\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\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\nexport function getRememberedCapabilitiesForWidget(widget: Widget): Capability[] {\n    return JSON.parse(localStorage.getItem(`widget_${widget.id}_approved_caps`) || \"[]\");\n}\n\nfunction setRememberedCapabilitiesForWidget(widget: Widget, caps: Capability[]) {\n    localStorage.setItem(`widget_${widget.id}_approved_caps`, JSON.stringify(caps));\n}\n\ninterface IProps extends IDialogProps {\n    requestedCapabilities: Set<Capability>;\n    widget: Widget;\n    widgetKind: WidgetKind; // TODO: Refactor into the Widget class\n}\n\ninterface IBooleanStates {\n    // @ts-ignore - TS wants a string key, but we know better\n    [capability: Capability]: boolean;\n}\n\ninterface IState {\n    booleanStates: IBooleanStates;\n    rememberSelection: boolean;\n}\n\n@replaceableComponent(\"views.dialogs.WidgetCapabilitiesPromptDialog\")\nexport default class WidgetCapabilitiesPromptDialog extends React.PureComponent<IProps, IState> {\n    private eventPermissionsMap = new Map<Capability, WidgetEventCapability>();\n\n    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: IBooleanStates = {};\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) => {\n        const newStates = objectShallowClone(this.state.booleanStates);\n        newStates[capability] = !newStates[capability];\n        this.setState({booleanStates: newStates});\n    };\n\n    private onRememberSelectionChange = (newVal: boolean) => {\n        this.setState({rememberSelection: newVal});\n    };\n\n    private onSubmit = async (ev) => {\n        this.closeAndTryRemember(Object.entries(this.state.booleanStates)\n            .filter(([_, isSelected]) => isSelected)\n            .map(([cap]) => cap));\n    };\n\n    private onReject = async (ev) => {\n        this.closeAndTryRemember([]); // nothing was approved\n    };\n\n    private closeAndTryRemember(approved: Capability[]) {\n        if (this.state.rememberSelection) {\n            setRememberedCapabilitiesForWidget(this.props.widget, approved);\n        }\n        this.props.onFinished({approved});\n    }\n\n    public render() {\n        const checkboxRows = Object.entries(this.state.booleanStates).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\n                        checked={isChecked}\n                        onChange={() => this.onToggle(cap)}\n                    >{text.primary}</StyledCheckbox>\n                    {byline}\n                </div>\n            );\n        });\n\n        return (\n            <BaseDialog\n                className=\"mx_WidgetCapabilitiesPromptDialog\"\n                onFinished={this.props.onFinished}\n                title={_t(\"Approve widget permissions\")}\n            >\n                <form onSubmit={this.onSubmit}>\n                    <div className=\"mx_Dialog_content\">\n                        <div className=\"text-muted\">{_t(\"This widget would like to:\")}</div>\n                        {checkboxRows}\n                        <DialogButtons\n                            primaryButton={_t(\"Approve\")}\n                            cancelButton={_t(\"Decline All\")}\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(\"Remember my selection for this widget\")} />}\n                        />\n                    </div>\n                </form>\n            </BaseDialog>\n        );\n    }\n}\n"]}