mirror of
https://github.com/microsoft/frontend-bootcamp.git
synced 2026-01-26 14:56:42 +08:00
converting to object todos
This commit is contained in:
@@ -3,25 +3,17 @@ import { TodoListItem } from './TodoListItem';
|
||||
|
||||
export class TodoList extends React.Component<any, any> {
|
||||
render() {
|
||||
const { filter, todos, onTodoToggle } = this.props;
|
||||
let filteredTodos: typeof todos = {};
|
||||
const { filter, todos, complete } = this.props;
|
||||
|
||||
filteredTodos = todos.filter(todo => {
|
||||
const matchesActive = filter == 'active' && !todo.completed;
|
||||
const matchesCompleted = filter == 'completed' && todo.completed;
|
||||
|
||||
return filter == 'all' || matchesActive || matchesCompleted;
|
||||
})
|
||||
|
||||
const TodoListItems = filteredTodos.map((todo) => {
|
||||
return (
|
||||
<TodoListItem key={todo.id} onTodoToggle={onTodoToggle} {...todo} />
|
||||
);
|
||||
})
|
||||
const filteredTodos = Object.keys(todos).filter(id => {
|
||||
return filter === 'all' || (filter === 'completed' && todos[id].completed) || (filter === 'active' && !todos[id].completed);
|
||||
});
|
||||
|
||||
return (
|
||||
<ul className="todos">
|
||||
{TodoListItems}
|
||||
{filteredTodos.map(id => (
|
||||
<TodoListItem key={id} id={id} {...todos[id]} complete={complete} />
|
||||
))}
|
||||
</ul>
|
||||
);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user