mirror of
https://github.com/reduxjs/redux-devtools.git
synced 2024-11-27 20:13:56 +03:00
76 lines
1.7 KiB
JavaScript
76 lines
1.7 KiB
JavaScript
|
import React, { Component, PropTypes } from 'react';
|
||
|
import classnames from 'classnames';
|
||
|
import TodoTextInput from './TodoTextInput';
|
||
|
|
||
|
class TodoItem extends Component {
|
||
|
constructor(props, context) {
|
||
|
super(props, context);
|
||
|
this.state = {
|
||
|
editing: false,
|
||
|
};
|
||
|
}
|
||
|
|
||
|
handleDoubleClick() {
|
||
|
this.setState({ editing: true });
|
||
|
}
|
||
|
|
||
|
handleSave(id, text) {
|
||
|
if (text.length === 0) {
|
||
|
this.props.deleteTodo(id);
|
||
|
} else {
|
||
|
this.props.editTodo(id, text);
|
||
|
}
|
||
|
this.setState({ editing: false });
|
||
|
}
|
||
|
|
||
|
render() {
|
||
|
const { todo, completeTodo, deleteTodo } = this.props;
|
||
|
|
||
|
let element;
|
||
|
if (this.state.editing) {
|
||
|
element = (
|
||
|
<TodoTextInput
|
||
|
text={todo.text}
|
||
|
editing={this.state.editing}
|
||
|
onSave={(text) => this.handleSave(todo.id, text)}
|
||
|
/>
|
||
|
);
|
||
|
} else {
|
||
|
element = (
|
||
|
<div className="view">
|
||
|
<input
|
||
|
className="toggle"
|
||
|
type="checkbox"
|
||
|
checked={todo.completed}
|
||
|
onChange={() => completeTodo(todo.id)}
|
||
|
/>
|
||
|
<label onDoubleClick={this.handleDoubleClick.bind(this)}>
|
||
|
{todo.text}
|
||
|
</label>
|
||
|
<button className="destroy" onClick={() => deleteTodo(todo.id)} />
|
||
|
</div>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<li
|
||
|
className={classnames({
|
||
|
completed: todo.completed,
|
||
|
editing: this.state.editing,
|
||
|
})}
|
||
|
>
|
||
|
{element}
|
||
|
</li>
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
TodoItem.propTypes = {
|
||
|
todo: PropTypes.object.isRequired,
|
||
|
editTodo: PropTypes.func.isRequired,
|
||
|
deleteTodo: PropTypes.func.isRequired,
|
||
|
completeTodo: PropTypes.func.isRequired,
|
||
|
};
|
||
|
|
||
|
export default TodoItem;
|