UNPKG

matrix-react-sdk

Version:
168 lines (149 loc) 19.8 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 _propTypes = _interopRequireDefault(require("prop-types")); var _languageHandler = require("../../../languageHandler"); var _Field = _interopRequireDefault(require("./Field")); var _AccessibleButton = _interopRequireDefault(require("./AccessibleButton")); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _class2, _temp; class EditableItem extends _react.default.Component { constructor() { super(); (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 }); }); this.state = { 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)("Are you sure?")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this._onActuallyRemove, kind: "primary_sm", className: "mx_EditableItem_confirmBtn" }, (0, _languageHandler._t)("Yes")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this._onDontRemove, kind: "danger_sm", className: "mx_EditableItem_confirmBtn" }, (0, _languageHandler._t)("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)("Remove"), role: "button" }), /*#__PURE__*/_react.default.createElement("span", { className: "mx_EditableItem_item" }, this.props.value)); } } exports.EditableItem = EditableItem; (0, _defineProperty2.default)(EditableItem, "propTypes", { index: _propTypes.default.number, value: _propTypes.default.string, onRemove: _propTypes.default.func }); let EditableItemList = (_dec = (0, _replaceableComponent.replaceableComponent)("views.elements.EditableItemList"), _dec(_class = (_temp = _class2 = class EditableItemList extends _react.default.Component { constructor(...args) { super(...args); (0, _defineProperty2.default)(this, "_onItemAdded", e => { e.stopPropagation(); e.preventDefault(); if (this.props.onItemAdded) this.props.onItemAdded(this.props.newItem); }); (0, _defineProperty2.default)(this, "_onItemRemoved", index => { if (this.props.onItemRemoved) this.props.onItemRemoved(index); }); (0, _defineProperty2.default)(this, "_onNewItemChanged", e => { if (this.props.onNewItemChanged) 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)("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" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_EditableItemList_label" }, label), editableItemsSection, this.props.canEdit ? this._renderNewItemField() : /*#__PURE__*/_react.default.createElement("div", null)); } }, (0, _defineProperty2.default)(_class2, "propTypes", { id: _propTypes.default.string.isRequired, items: _propTypes.default.arrayOf(_propTypes.default.string).isRequired, itemsLabel: _propTypes.default.string, noItemsLabel: _propTypes.default.string, placeholder: _propTypes.default.string, newItem: _propTypes.default.string, onItemAdded: _propTypes.default.func, onItemRemoved: _propTypes.default.func, onNewItemChanged: _propTypes.default.func, canEdit: _propTypes.default.bool, canRemove: _propTypes.default.bool }), _temp)) || _class); exports.default = EditableItemList; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/elements/EditableItemList.js"],"names":["EditableItem","React","Component","constructor","e","stopPropagation","preventDefault","setState","verifyRemove","props","onRemove","index","state","render","_onActuallyRemove","_onDontRemove","_onRemove","value","PropTypes","number","string","func","EditableItemList","onItemAdded","newItem","onItemRemoved","onNewItemChanged","target","_renderNewItemField","_onItemAdded","placeholder","_onNewItemChanged","suggestionsListId","editableItems","items","map","item","canRemove","_onItemRemoved","editableItemsSection","label","length","itemsLabel","noItemsLabel","canEdit","id","isRequired","arrayOf","bool"],"mappings":"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","sourcesContent":["/*\nCopyright 2017, 2019 New Vector Ltd.\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 PropTypes from 'prop-types';\nimport {_t} from '../../../languageHandler';\nimport Field from \"./Field\";\nimport AccessibleButton from \"./AccessibleButton\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\nexport class EditableItem extends React.Component {\n    static propTypes = {\n        index: PropTypes.number,\n        value: PropTypes.string,\n        onRemove: PropTypes.func,\n    };\n\n    constructor() {\n        super();\n\n        this.state = {\n            verifyRemove: false,\n        };\n    }\n\n    _onRemove = (e) => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        this.setState({verifyRemove: true});\n    };\n\n    _onDontRemove = (e) => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        this.setState({verifyRemove: false});\n    };\n\n    _onActuallyRemove = (e) => {\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    render() {\n        if (this.state.verifyRemove) {\n            return (\n                <div className=\"mx_EditableItem\">\n                    <span className=\"mx_EditableItem_promptText\">\n                        {_t(\"Are you sure?\")}\n                    </span>\n                    <AccessibleButton\n                        onClick={this._onActuallyRemove}\n                        kind=\"primary_sm\"\n                        className=\"mx_EditableItem_confirmBtn\"\n                    >\n                        {_t(\"Yes\")}\n                    </AccessibleButton>\n                    <AccessibleButton\n                        onClick={this._onDontRemove}\n                        kind=\"danger_sm\"\n                        className=\"mx_EditableItem_confirmBtn\"\n                    >\n                        {_t(\"No\")}\n                    </AccessibleButton>\n                </div>\n            );\n        }\n\n        return (\n            <div className=\"mx_EditableItem\">\n                <div onClick={this._onRemove} className=\"mx_EditableItem_delete\" title={_t(\"Remove\")} role=\"button\" />\n                <span className=\"mx_EditableItem_item\">{this.props.value}</span>\n            </div>\n        );\n    }\n}\n\n@replaceableComponent(\"views.elements.EditableItemList\")\nexport default class EditableItemList extends React.Component {\n    static propTypes = {\n        id: PropTypes.string.isRequired,\n        items: PropTypes.arrayOf(PropTypes.string).isRequired,\n        itemsLabel: PropTypes.string,\n        noItemsLabel: PropTypes.string,\n        placeholder: PropTypes.string,\n        newItem: PropTypes.string,\n\n        onItemAdded: PropTypes.func,\n        onItemRemoved: PropTypes.func,\n        onNewItemChanged: PropTypes.func,\n\n        canEdit: PropTypes.bool,\n        canRemove: PropTypes.bool,\n    };\n\n    _onItemAdded = (e) => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        if (this.props.onItemAdded) this.props.onItemAdded(this.props.newItem);\n    };\n\n    _onItemRemoved = (index) => {\n        if (this.props.onItemRemoved) this.props.onItemRemoved(index);\n    };\n\n    _onNewItemChanged = (e) => {\n        if (this.props.onNewItemChanged) this.props.onNewItemChanged(e.target.value);\n    };\n\n    _renderNewItemField() {\n        return (\n            <form\n                onSubmit={this._onItemAdded}\n                autoComplete=\"off\"\n                noValidate={true}\n                className=\"mx_EditableItemList_newItem\"\n            >\n                <Field label={this.props.placeholder} type=\"text\"\n                    autoComplete=\"off\" value={this.props.newItem || \"\"} onChange={this._onNewItemChanged}\n                    list={this.props.suggestionsListId} />\n                <AccessibleButton onClick={this._onItemAdded} kind=\"primary\" type=\"submit\" disabled={!this.props.newItem}>\n                    {_t(\"Add\")}\n                </AccessibleButton>\n            </form>\n        );\n    }\n\n    render() {\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\n                key={item}\n                index={index}\n                value={item}\n                onRemove={this._onItemRemoved}\n            />;\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 (<div className=\"mx_EditableItemList\">\n            <div className=\"mx_EditableItemList_label\">\n                { label }\n            </div>\n            { editableItemsSection }\n            { this.props.canEdit ? this._renderNewItemField() : <div /> }\n        </div>);\n    }\n}\n"]}