mirror of
https://github.com/microsoft/frontend-bootcamp.git
synced 2026-01-26 14:56:42 +08:00
29 lines
775 B
TypeScript
29 lines
775 B
TypeScript
import React from 'react';
|
|
import { TodoListItem } from './TodoListItem';
|
|
|
|
export class TodoList extends React.Component<any, any> {
|
|
render() {
|
|
const { filter, todos, onTodoToggle } = this.props;
|
|
let filteredTodos: typeof todos = {};
|
|
|
|
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} />
|
|
);
|
|
})
|
|
|
|
return (
|
|
<ul className="todos">
|
|
{TodoListItems}
|
|
</ul>
|
|
);
|
|
}
|
|
}
|