UNPKG

matrix-react-sdk

Version:
98 lines (95 loc) 15.5 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 _reactFocusLock = _interopRequireDefault(require("react-focus-lock")); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _languageHandler = require("../../../languageHandler"); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _KeyboardShortcuts = require("../../../accessibility/KeyboardShortcuts"); var _KeyBindingsManager = require("../../../KeyBindingsManager"); /* Copyright 2024 New Vector Ltd. Copyright 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. */ /** * Scrollable dialog base from Compound (Web Components). */ class ScrollableBaseModal extends _react.default.PureComponent { constructor(props) { super(props); (0, _defineProperty2.default)(this, "onKeyDown", e => { const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(e); switch (action) { case _KeyboardShortcuts.KeyBindingAction.Escape: e.stopPropagation(); e.preventDefault(); this.cancel(); break; } }); (0, _defineProperty2.default)(this, "onCancel", () => { this.cancel(); }); (0, _defineProperty2.default)(this, "onSubmit", e => { e.stopPropagation(); e.preventDefault(); if (!this.state.canSubmit) return; // pretend the submit button was disabled this.submit(); }); } get matrixClient() { // XXX: The contract on MatrixClientContext says it is only available within a LoggedInView subtree, // given that modals function outside the MatrixChat React tree this simulates that. We don't want to // use safeGet as it throwing would mean we cannot use modals whilst the user isn't logged in. // The longer term solution is to move our ModalManager into the React tree to inherit contexts properly. return _MatrixClientPeg.MatrixClientPeg.get(); } render() { return /*#__PURE__*/_react.default.createElement(_MatrixClientContext.default.Provider, { value: this.matrixClient }, /*#__PURE__*/_react.default.createElement(_reactFocusLock.default, { returnFocus: true, lockProps: { onKeyDown: this.onKeyDown, role: "dialog", ["aria-labelledby"]: "mx_CompoundDialog_title", // Like BaseDialog, we'll just point this at the whole content ["aria-describedby"]: "mx_CompoundDialog_content" }, className: "mx_CompoundDialog mx_ScrollableBaseDialog" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CompoundDialog_header" }, /*#__PURE__*/_react.default.createElement("h1", null, this.state.title)), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onCancel, className: "mx_CompoundDialog_cancelButton", "aria-label": (0, _languageHandler._t)("dialog_close_label") }), /*#__PURE__*/_react.default.createElement("form", { onSubmit: this.onSubmit, className: "mx_CompoundDialog_form" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_CompoundDialog_content" }, this.renderContent()), /*#__PURE__*/_react.default.createElement("div", { className: "mx_CompoundDialog_footer" }, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onCancel, kind: "primary_outline" }, this.state.cancelLabel ?? (0, _languageHandler._t)("action|cancel")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onSubmit, kind: "primary", disabled: !this.state.canSubmit, type: "submit", element: "button", className: "mx_Dialog_nonDialogButton" }, this.state.actionLabel))))); } } exports.default = ScrollableBaseModal; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactFocusLock","_MatrixClientPeg","_MatrixClientContext","_languageHandler","_AccessibleButton","_KeyboardShortcuts","_KeyBindingsManager","ScrollableBaseModal","React","PureComponent","constructor","props","_defineProperty2","default","e","action","getKeyBindingsManager","getAccessibilityAction","KeyBindingAction","Escape","stopPropagation","preventDefault","cancel","state","canSubmit","submit","matrixClient","MatrixClientPeg","get","render","createElement","Provider","value","returnFocus","lockProps","onKeyDown","role","className","title","onClick","onCancel","_t","onSubmit","renderContent","kind","cancelLabel","disabled","type","element","actionLabel","exports"],"sources":["../../../../src/components/views/dialogs/ScrollableBaseModal.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 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, { FormEvent } from \"react\";\nimport { MatrixClient } from \"matrix-js-sdk/src/matrix\";\nimport FocusLock from \"react-focus-lock\";\n\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { _t } from \"../../../languageHandler\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { KeyBindingAction } from \"../../../accessibility/KeyboardShortcuts\";\nimport { getKeyBindingsManager } from \"../../../KeyBindingsManager\";\n\nexport interface IScrollableBaseState {\n    canSubmit: boolean;\n    title: string;\n    actionLabel: string;\n    cancelLabel?: string;\n}\n\n/**\n * Scrollable dialog base from Compound (Web Components).\n */\nexport default abstract class ScrollableBaseModal<\n    TProps extends { onFinished?: (...args: any[]) => void },\n    TState extends IScrollableBaseState,\n> extends React.PureComponent<TProps, TState> {\n    protected constructor(props: TProps) {\n        super(props);\n    }\n\n    protected get matrixClient(): MatrixClient {\n        // XXX: The contract on MatrixClientContext says it is only available within a LoggedInView subtree,\n        // given that modals function outside the MatrixChat React tree this simulates that. We don't want to\n        // use safeGet as it throwing would mean we cannot use modals whilst the user isn't logged in.\n        // The longer term solution is to move our ModalManager into the React tree to inherit contexts properly.\n        return MatrixClientPeg.get()!;\n    }\n\n    private onKeyDown = (e: KeyboardEvent | React.KeyboardEvent): void => {\n        const action = getKeyBindingsManager().getAccessibilityAction(e);\n        switch (action) {\n            case KeyBindingAction.Escape:\n                e.stopPropagation();\n                e.preventDefault();\n                this.cancel();\n                break;\n        }\n    };\n\n    private onCancel = (): void => {\n        this.cancel();\n    };\n\n    private onSubmit = (e: MouseEvent | FormEvent): void => {\n        e.stopPropagation();\n        e.preventDefault();\n        if (!this.state.canSubmit) return; // pretend the submit button was disabled\n        this.submit();\n    };\n\n    protected abstract cancel(): void;\n    protected abstract submit(): void;\n    protected abstract renderContent(): React.ReactNode;\n\n    public render(): React.ReactNode {\n        return (\n            <MatrixClientContext.Provider value={this.matrixClient}>\n                <FocusLock\n                    returnFocus={true}\n                    lockProps={{\n                        onKeyDown: this.onKeyDown,\n                        role: \"dialog\",\n                        [\"aria-labelledby\"]: \"mx_CompoundDialog_title\",\n\n                        // Like BaseDialog, we'll just point this at the whole content\n                        [\"aria-describedby\"]: \"mx_CompoundDialog_content\",\n                    }}\n                    className=\"mx_CompoundDialog mx_ScrollableBaseDialog\"\n                >\n                    <div className=\"mx_CompoundDialog_header\">\n                        <h1>{this.state.title}</h1>\n                    </div>\n                    <AccessibleButton\n                        onClick={this.onCancel}\n                        className=\"mx_CompoundDialog_cancelButton\"\n                        aria-label={_t(\"dialog_close_label\")}\n                    />\n                    <form onSubmit={this.onSubmit} className=\"mx_CompoundDialog_form\">\n                        <div className=\"mx_CompoundDialog_content\">{this.renderContent()}</div>\n                        <div className=\"mx_CompoundDialog_footer\">\n                            <AccessibleButton onClick={this.onCancel} kind=\"primary_outline\">\n                                {this.state.cancelLabel ?? _t(\"action|cancel\")}\n                            </AccessibleButton>\n                            <AccessibleButton\n                                onClick={this.onSubmit}\n                                kind=\"primary\"\n                                disabled={!this.state.canSubmit}\n                                type=\"submit\"\n                                element=\"button\"\n                                className=\"mx_Dialog_nonDialogButton\"\n                            >\n                                {this.state.actionLabel}\n                            </AccessibleButton>\n                        </div>\n                    </form>\n                </FocusLock>\n            </MatrixClientContext.Provider>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}