import React from 'react'; import { Stack } from 'office-ui-fabric-react'; import { TodoListItem } from './TodoListItem'; import { Store, FilterTypes } from '../store'; import { connect } from 'react-redux'; interface TodoListProps { todos: Store['todos']; filter: FilterTypes; } const TodoList = (props: TodoListProps) => { const { filter, todos } = props; const filteredTodos = Object.keys(todos).filter(id => { return filter === 'all' || (filter === 'completed' && todos[id].completed) || (filter === 'active' && !todos[id].completed); }); return ( {filteredTodos.map(id => ( ))} ); }; function mapStateToProps(state: Store) { return { ...state }; } function mapDispatchToProps(dispatch: any) { return {}; } const component = connect( mapStateToProps, mapDispatchToProps )(TodoList); export { component as TodoList };