UNPKG

matrix-react-sdk

Version:
139 lines (136 loc) 19.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.EditableItem = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _languageHandler = require("../../../languageHandler"); var _Field = _interopRequireDefault(require("./Field")); var _AccessibleButton = _interopRequireDefault(require("./AccessibleButton")); /* Copyright 2024 New Vector Ltd. Copyright 2017-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 EditableItem extends _react.default.Component { constructor(...args) { super(...args); (0, _defineProperty2.default)(this, "state", { verifyRemove: false }); (0, _defineProperty2.default)(this, "onRemove", e => { e.stopPropagation(); e.preventDefault(); this.setState({ verifyRemove: true }); }); (0, _defineProperty2.default)(this, "onDontRemove", e => { e.stopPropagation(); e.preventDefault(); this.setState({ verifyRemove: false }); }); (0, _defineProperty2.default)(this, "onActuallyRemove", e => { e.stopPropagation(); e.preventDefault(); if (this.props.onRemove) this.props.onRemove(this.props.index); this.setState({ verifyRemove: false }); }); } render() { if (this.state.verifyRemove) { return /*#__PURE__*/_react.default.createElement("div", { className: "mx_EditableItem" }, /*#__PURE__*/_react.default.createElement("span", { className: "mx_EditableItem_promptText" }, (0, _languageHandler._t)("common|are_you_sure")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onActuallyRemove, kind: "primary_sm", className: "mx_EditableItem_confirmBtn" }, (0, _languageHandler._t)("action|yes")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onDontRemove, kind: "danger_sm", className: "mx_EditableItem_confirmBtn" }, (0, _languageHandler._t)("action|no"))); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_EditableItem" }, /*#__PURE__*/_react.default.createElement("div", { onClick: this.onRemove, className: "mx_EditableItem_delete", title: (0, _languageHandler._t)("action|remove"), role: "button" }), /*#__PURE__*/_react.default.createElement("span", { className: "mx_EditableItem_item" }, this.props.value)); } } exports.EditableItem = EditableItem; class EditableItemList extends _react.default.PureComponent { constructor(...args) { super(...args); (0, _defineProperty2.default)(this, "onItemAdded", e => { e.stopPropagation(); e.preventDefault(); this.props.onItemAdded?.(this.props.newItem); }); (0, _defineProperty2.default)(this, "onItemRemoved", index => { this.props.onItemRemoved?.(index); }); (0, _defineProperty2.default)(this, "onNewItemChanged", e => { this.props.onNewItemChanged?.(e.target.value); }); } renderNewItemField() { return /*#__PURE__*/_react.default.createElement("form", { onSubmit: this.onItemAdded, autoComplete: "off", noValidate: true, className: "mx_EditableItemList_newItem" }, /*#__PURE__*/_react.default.createElement(_Field.default, { label: this.props.placeholder, type: "text", autoComplete: "off", value: this.props.newItem || "", onChange: this.onNewItemChanged, list: this.props.suggestionsListId }), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onItemAdded, kind: "primary", type: "submit", disabled: !this.props.newItem }, (0, _languageHandler._t)("action|add"))); } render() { const editableItems = this.props.items.map((item, index) => { if (!this.props.canRemove) { return /*#__PURE__*/_react.default.createElement("li", { key: item }, item); } return /*#__PURE__*/_react.default.createElement(EditableItem, { key: item, index: index, value: item, onRemove: this.onItemRemoved }); }); const editableItemsSection = this.props.canRemove ? editableItems : /*#__PURE__*/_react.default.createElement("ul", null, editableItems); const label = this.props.items.length > 0 ? this.props.itemsLabel : this.props.noItemsLabel; return /*#__PURE__*/_react.default.createElement("div", { className: "mx_EditableItemList", id: this.props.id }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_EditableItemList_label" }, label), editableItemsSection, this.props.canEdit ? this.renderNewItemField() : /*#__PURE__*/_react.default.createElement("div", null)); } } exports.default = EditableItemList; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_languageHandler","_Field","_AccessibleButton","EditableItem","React","Component","constructor","args","_defineProperty2","default","verifyRemove","e","stopPropagation","preventDefault","setState","props","onRemove","index","render","state","createElement","className","_t","onClick","onActuallyRemove","kind","onDontRemove","title","role","value","exports","EditableItemList","PureComponent","onItemAdded","newItem","onItemRemoved","onNewItemChanged","target","renderNewItemField","onSubmit","autoComplete","noValidate","label","placeholder","type","onChange","list","suggestionsListId","disabled","editableItems","items","map","item","canRemove","key","editableItemsSection","length","itemsLabel","noItemsLabel","id","canEdit"],"sources":["../../../../src/components/views/elements/EditableItemList.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2017-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, { ChangeEvent } from \"react\";\n\nimport { _t } from \"../../../languageHandler\";\nimport Field from \"./Field\";\nimport AccessibleButton, { ButtonEvent } from \"./AccessibleButton\";\n\ninterface IItemProps {\n    index: number;\n    value?: string;\n    onRemove?(index: number): void;\n}\n\ninterface IItemState {\n    verifyRemove: boolean;\n}\n\nexport class EditableItem extends React.Component<IItemProps, IItemState> {\n    public state = {\n        verifyRemove: false,\n    };\n\n    private onRemove = (e: ButtonEvent): void => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        this.setState({ verifyRemove: true });\n    };\n\n    private onDontRemove = (e: ButtonEvent): void => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        this.setState({ verifyRemove: false });\n    };\n\n    private onActuallyRemove = (e: ButtonEvent): void => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        if (this.props.onRemove) this.props.onRemove(this.props.index);\n        this.setState({ verifyRemove: false });\n    };\n\n    public render(): React.ReactNode {\n        if (this.state.verifyRemove) {\n            return (\n                <div className=\"mx_EditableItem\">\n                    <span className=\"mx_EditableItem_promptText\">{_t(\"common|are_you_sure\")}</span>\n                    <AccessibleButton\n                        onClick={this.onActuallyRemove}\n                        kind=\"primary_sm\"\n                        className=\"mx_EditableItem_confirmBtn\"\n                    >\n                        {_t(\"action|yes\")}\n                    </AccessibleButton>\n                    <AccessibleButton\n                        onClick={this.onDontRemove}\n                        kind=\"danger_sm\"\n                        className=\"mx_EditableItem_confirmBtn\"\n                    >\n                        {_t(\"action|no\")}\n                    </AccessibleButton>\n                </div>\n            );\n        }\n\n        return (\n            <div className=\"mx_EditableItem\">\n                <div\n                    onClick={this.onRemove}\n                    className=\"mx_EditableItem_delete\"\n                    title={_t(\"action|remove\")}\n                    role=\"button\"\n                />\n                <span className=\"mx_EditableItem_item\">{this.props.value}</span>\n            </div>\n        );\n    }\n}\n\ninterface IProps {\n    id: string;\n    items: string[];\n    itemsLabel?: string;\n    noItemsLabel?: string;\n    placeholder?: string;\n    newItem?: string;\n    canEdit?: boolean;\n    canRemove?: boolean;\n    suggestionsListId?: string;\n    onItemAdded?(item?: string): void;\n    onItemRemoved?(index: number): void;\n    onNewItemChanged?(item: string): void;\n}\n\nexport default class EditableItemList<P = {}> extends React.PureComponent<IProps & P> {\n    protected onItemAdded = (e: ButtonEvent): void => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        this.props.onItemAdded?.(this.props.newItem);\n    };\n\n    protected onItemRemoved = (index: number): void => {\n        this.props.onItemRemoved?.(index);\n    };\n\n    protected onNewItemChanged = (e: ChangeEvent<HTMLInputElement>): void => {\n        this.props.onNewItemChanged?.(e.target.value);\n    };\n\n    protected renderNewItemField(): JSX.Element {\n        return (\n            <form\n                onSubmit={this.onItemAdded}\n                autoComplete=\"off\"\n                noValidate={true}\n                className=\"mx_EditableItemList_newItem\"\n            >\n                <Field\n                    label={this.props.placeholder}\n                    type=\"text\"\n                    autoComplete=\"off\"\n                    value={this.props.newItem || \"\"}\n                    onChange={this.onNewItemChanged}\n                    list={this.props.suggestionsListId}\n                />\n                <AccessibleButton\n                    onClick={this.onItemAdded}\n                    kind=\"primary\"\n                    type=\"submit\"\n                    disabled={!this.props.newItem}\n                >\n                    {_t(\"action|add\")}\n                </AccessibleButton>\n            </form>\n        );\n    }\n\n    public render(): React.ReactNode {\n        const editableItems = this.props.items.map((item, index) => {\n            if (!this.props.canRemove) {\n                return <li key={item}>{item}</li>;\n            }\n\n            return <EditableItem key={item} index={index} value={item} onRemove={this.onItemRemoved} />;\n        });\n\n        const editableItemsSection = this.props.canRemove ? editableItems : <ul>{editableItems}</ul>;\n        const label = this.props.items.length > 0 ? this.props.itemsLabel : this.props.noItemsLabel;\n\n        return (\n            <div className=\"mx_EditableItemList\" id={this.props.id}>\n                <div className=\"mx_EditableItemList_label\">{label}</div>\n                {editableItemsSection}\n                {this.props.canEdit ? this.renderNewItemField() : <div />}\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}