2017-10-04 12:00:01 +03:00
|
|
|
/*
|
2019-02-08 19:11:30 +03:00
|
|
|
Copyright 2017, 2019 New Vector Ltd.
|
2017-10-04 12:00:01 +03:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
2020-07-03 01:32:21 +03:00
|
|
|
import {_t} from '../../../languageHandler';
|
2019-02-08 19:11:30 +03:00
|
|
|
import Field from "./Field";
|
|
|
|
import AccessibleButton from "./AccessibleButton";
|
2017-10-04 12:00:01 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
export class EditableItem extends React.Component {
|
|
|
|
static propTypes = {
|
2017-10-04 12:00:01 +03:00
|
|
|
index: PropTypes.number,
|
2019-02-08 19:11:30 +03:00
|
|
|
value: PropTypes.string,
|
2017-10-04 12:00:01 +03:00
|
|
|
onRemove: PropTypes.func,
|
2019-02-08 19:11:30 +03:00
|
|
|
};
|
2017-10-04 12:28:26 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
constructor() {
|
|
|
|
super();
|
2017-10-04 12:00:01 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
this.state = {
|
|
|
|
verifyRemove: false,
|
|
|
|
};
|
|
|
|
}
|
2017-10-04 12:00:01 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
_onRemove = (e) => {
|
|
|
|
e.stopPropagation();
|
|
|
|
e.preventDefault();
|
2017-10-24 18:19:09 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
this.setState({verifyRemove: true});
|
|
|
|
};
|
2017-10-04 12:00:01 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
_onDontRemove = (e) => {
|
|
|
|
e.stopPropagation();
|
|
|
|
e.preventDefault();
|
2017-10-04 12:00:01 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
this.setState({verifyRemove: false});
|
|
|
|
};
|
2017-10-04 12:00:01 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
_onActuallyRemove = (e) => {
|
|
|
|
e.stopPropagation();
|
|
|
|
e.preventDefault();
|
2017-10-04 12:00:01 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
if (this.props.onRemove) this.props.onRemove(this.props.index);
|
|
|
|
this.setState({verifyRemove: false});
|
|
|
|
};
|
|
|
|
|
2019-02-22 03:15:25 +03:00
|
|
|
render() {
|
|
|
|
if (this.state.verifyRemove) {
|
|
|
|
return (
|
|
|
|
<div className="mx_EditableItem">
|
2019-02-08 19:11:30 +03:00
|
|
|
<span className="mx_EditableItem_promptText">
|
|
|
|
{_t("Are you sure?")}
|
|
|
|
</span>
|
2019-02-22 03:15:25 +03:00
|
|
|
<AccessibleButton onClick={this._onActuallyRemove} kind="primary_sm"
|
|
|
|
className="mx_EditableItem_confirmBtn">
|
|
|
|
{_t("Yes")}
|
|
|
|
</AccessibleButton>
|
|
|
|
<AccessibleButton onClick={this._onDontRemove} kind="danger_sm"
|
|
|
|
className="mx_EditableItem_confirmBtn">
|
|
|
|
{_t("No")}
|
|
|
|
</AccessibleButton>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2019-02-08 19:11:30 +03:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="mx_EditableItem">
|
2020-03-16 19:29:35 +03:00
|
|
|
<div onClick={this._onRemove} className="mx_EditableItem_delete" title={_t("Remove")} role="button" />
|
2019-02-08 19:11:30 +03:00
|
|
|
<span className="mx_EditableItem_item">{this.props.value}</span>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-22 03:53:29 +03:00
|
|
|
export default class EditableItemList extends React.Component {
|
2019-02-08 19:11:30 +03:00
|
|
|
static propTypes = {
|
2019-07-06 13:15:10 +03:00
|
|
|
id: PropTypes.string.isRequired,
|
2019-02-08 19:11:30 +03:00
|
|
|
items: PropTypes.arrayOf(PropTypes.string).isRequired,
|
|
|
|
itemsLabel: PropTypes.string,
|
|
|
|
noItemsLabel: PropTypes.string,
|
|
|
|
placeholder: PropTypes.string,
|
2019-02-21 02:13:35 +03:00
|
|
|
newItem: PropTypes.string,
|
2017-10-04 12:00:01 +03:00
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
onItemAdded: PropTypes.func,
|
|
|
|
onItemRemoved: PropTypes.func,
|
2019-02-21 02:13:35 +03:00
|
|
|
onNewItemChanged: PropTypes.func,
|
2019-02-08 19:11:30 +03:00
|
|
|
|
|
|
|
canEdit: PropTypes.bool,
|
2019-02-22 03:15:25 +03:00
|
|
|
canRemove: PropTypes.bool,
|
2019-02-08 19:11:30 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
_onItemAdded = (e) => {
|
|
|
|
e.stopPropagation();
|
|
|
|
e.preventDefault();
|
|
|
|
|
2019-02-21 02:13:35 +03:00
|
|
|
if (this.props.onItemAdded) this.props.onItemAdded(this.props.newItem);
|
2019-02-08 19:11:30 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
_onItemRemoved = (index) => {
|
|
|
|
if (this.props.onItemRemoved) this.props.onItemRemoved(index);
|
|
|
|
};
|
|
|
|
|
2019-02-21 02:13:35 +03:00
|
|
|
_onNewItemChanged = (e) => {
|
|
|
|
if (this.props.onNewItemChanged) this.props.onNewItemChanged(e.target.value);
|
|
|
|
};
|
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
_renderNewItemField() {
|
2020-12-22 15:14:55 +03:00
|
|
|
let addButton;
|
|
|
|
console.log(this.props.newItem);
|
|
|
|
if (this.props.newItem) {
|
|
|
|
addButton = (
|
|
|
|
<AccessibleButton onClick={this._onItemAdded} kind="primary" type="submit">
|
|
|
|
{_t("Add")}
|
|
|
|
</AccessibleButton>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-02-08 19:11:30 +03:00
|
|
|
return (
|
2019-10-03 23:47:19 +03:00
|
|
|
<form onSubmit={this._onItemAdded} autoComplete="off"
|
2019-02-08 19:11:30 +03:00
|
|
|
noValidate={true} className="mx_EditableItemList_newItem">
|
2020-03-30 00:59:15 +03:00
|
|
|
<Field label={this.props.placeholder} type="text"
|
2020-03-09 18:31:07 +03:00
|
|
|
autoComplete="off" value={this.props.newItem || ""} onChange={this._onNewItemChanged}
|
|
|
|
list={this.props.suggestionsListId} />
|
2020-12-22 15:14:55 +03:00
|
|
|
{ addButton }
|
2019-02-08 19:11:30 +03:00
|
|
|
</form>
|
2019-02-22 03:53:29 +03:00
|
|
|
);
|
2019-02-08 19:11:30 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2017-10-04 12:00:01 +03:00
|
|
|
const editableItems = this.props.items.map((item, index) => {
|
2019-02-22 03:15:25 +03:00
|
|
|
if (!this.props.canRemove) {
|
2019-06-30 12:41:39 +03:00
|
|
|
return <li key={item}>{item}</li>;
|
2019-02-22 03:15:25 +03:00
|
|
|
}
|
|
|
|
|
2017-10-04 12:00:01 +03:00
|
|
|
return <EditableItem
|
2019-06-30 12:41:39 +03:00
|
|
|
key={item}
|
2017-10-04 12:00:01 +03:00
|
|
|
index={index}
|
2019-02-08 19:11:30 +03:00
|
|
|
value={item}
|
|
|
|
onRemove={this._onItemRemoved}
|
2017-10-04 12:00:01 +03:00
|
|
|
/>;
|
|
|
|
});
|
|
|
|
|
2019-02-22 03:15:25 +03:00
|
|
|
const editableItemsSection = this.props.canRemove ? editableItems : <ul>{editableItems}</ul>;
|
2019-02-08 19:11:30 +03:00
|
|
|
const label = this.props.items.length > 0 ? this.props.itemsLabel : this.props.noItemsLabel;
|
2017-10-04 12:00:01 +03:00
|
|
|
|
|
|
|
return (<div className="mx_EditableItemList">
|
|
|
|
<div className="mx_EditableItemList_label">
|
|
|
|
{ label }
|
|
|
|
</div>
|
2019-02-22 03:15:25 +03:00
|
|
|
{ editableItemsSection }
|
2019-02-08 19:11:30 +03:00
|
|
|
{ this.props.canEdit ? this._renderNewItemField() : <div /> }
|
2017-10-04 12:00:01 +03:00
|
|
|
</div>);
|
2019-02-08 19:11:30 +03:00
|
|
|
}
|
|
|
|
}
|