matrix-react-sdk
Version:
SDK for matrix.org using React
85 lines (82 loc) • 11.5 kB
JavaScript
"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 _classnames = _interopRequireDefault(require("classnames"));
var _react = _interopRequireDefault(require("react"));
var _Field = _interopRequireDefault(require("./Field"));
var _languageHandler = require("../../../languageHandler");
var _AccessibleButton = _interopRequireDefault(require("./AccessibleButton"));
var _Tag = require("./Tag");
/*
Copyright 2024 New Vector Ltd.
Copyright 2021-2023 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.
*/
/**
* A simple, controlled, composer for entering string tags. Contains a simple
* input, add button, and per-tag remove button.
*/
class TagComposer extends _react.default.PureComponent {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "onInputChange", ev => {
this.setState({
newTag: ev.target.value
});
});
(0, _defineProperty2.default)(this, "onAdd", ev => {
ev.preventDefault();
if (!this.state.newTag) return;
this.props.onAdd(this.state.newTag);
this.setState({
newTag: ""
});
});
this.state = {
newTag: ""
};
}
onRemove(tag) {
// We probably don't need to proxy this, but for
// sanity of `this` we'll do so anyways.
this.props.onRemove(tag);
}
render() {
return /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classnames.default)("mx_TagComposer", {
mx_TagComposer_disabled: this.props.disabled
})
}, /*#__PURE__*/_react.default.createElement("form", {
className: "mx_TagComposer_input",
onSubmit: this.onAdd
}, /*#__PURE__*/_react.default.createElement(_Field.default, {
id: this.props.id ? this.props.id + "_field" : undefined,
value: this.state.newTag,
onChange: this.onInputChange,
label: this.props.label || (0, _languageHandler._t)("notifications|keyword"),
placeholder: this.props.placeholder || (0, _languageHandler._t)("notifications|keyword_new"),
disabled: this.props.disabled,
autoComplete: "off"
}), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: this.onAdd,
kind: "primary",
disabled: this.props.disabled
}, (0, _languageHandler._t)("action|add"))), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_TagComposer_tags",
role: "list"
}, this.props.tags.map((t, i) => /*#__PURE__*/_react.default.createElement(_Tag.Tag, {
label: t,
key: t,
onDeleteClick: this.onRemove.bind(this, t),
disabled: this.props.disabled,
role: "listitem"
}))));
}
}
exports.default = TagComposer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_classnames","_interopRequireDefault","require","_react","_Field","_languageHandler","_AccessibleButton","_Tag","TagComposer","React","PureComponent","constructor","props","_defineProperty2","default","ev","setState","newTag","target","value","preventDefault","state","onAdd","onRemove","tag","render","createElement","className","classNames","mx_TagComposer_disabled","disabled","onSubmit","id","undefined","onChange","onInputChange","label","_t","placeholder","autoComplete","onClick","kind","role","tags","map","t","i","Tag","key","onDeleteClick","bind","exports"],"sources":["../../../../src/components/views/elements/TagComposer.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021-2023 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 classNames from \"classnames\";\nimport React, { ChangeEvent, FormEvent } from \"react\";\n\nimport Field from \"./Field\";\nimport { _t } from \"../../../languageHandler\";\nimport AccessibleButton from \"./AccessibleButton\";\nimport { Tag } from \"./Tag\";\n\ninterface IProps {\n    id?: string;\n    tags: string[];\n    onAdd: (tag: string) => void;\n    onRemove: (tag: string) => void;\n    disabled?: boolean;\n    label?: string;\n    placeholder?: string;\n}\n\ninterface IState {\n    newTag: string;\n}\n\n/**\n * A simple, controlled, composer for entering string tags. Contains a simple\n * input, add button, and per-tag remove button.\n */\nexport default class TagComposer extends React.PureComponent<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            newTag: \"\",\n        };\n    }\n\n    private onInputChange = (ev: ChangeEvent<HTMLInputElement>): void => {\n        this.setState({ newTag: ev.target.value });\n    };\n\n    private onAdd = (ev: FormEvent): void => {\n        ev.preventDefault();\n        if (!this.state.newTag) return;\n\n        this.props.onAdd(this.state.newTag);\n        this.setState({ newTag: \"\" });\n    };\n\n    private onRemove(tag: string): void {\n        // We probably don't need to proxy this, but for\n        // sanity of `this` we'll do so anyways.\n        this.props.onRemove(tag);\n    }\n\n    public render(): React.ReactNode {\n        return (\n            <div\n                className={classNames(\"mx_TagComposer\", {\n                    mx_TagComposer_disabled: this.props.disabled,\n                })}\n            >\n                <form className=\"mx_TagComposer_input\" onSubmit={this.onAdd}>\n                    <Field\n                        id={this.props.id ? this.props.id + \"_field\" : undefined}\n                        value={this.state.newTag}\n                        onChange={this.onInputChange}\n                        label={this.props.label || _t(\"notifications|keyword\")}\n                        placeholder={this.props.placeholder || _t(\"notifications|keyword_new\")}\n                        disabled={this.props.disabled}\n                        autoComplete=\"off\"\n                    />\n                    <AccessibleButton onClick={this.onAdd} kind=\"primary\" disabled={this.props.disabled}>\n                        {_t(\"action|add\")}\n                    </AccessibleButton>\n                </form>\n                <div className=\"mx_TagComposer_tags\" role=\"list\">\n                    {this.props.tags.map((t, i) => (\n                        <Tag\n                            label={t}\n                            key={t}\n                            onDeleteClick={this.onRemove.bind(this, t)}\n                            disabled={this.props.disabled}\n                            role=\"listitem\"\n                        />\n                    ))}\n                </div>\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}