mirror of
https://github.com/leporello-js/leporello-js
synced 2026-01-14 05:14:28 -08:00
27 lines
568 B
JavaScript
27 lines
568 B
JavaScript
|
|
import React from 'react'
|
||
|
|
import PropTypes from 'prop-types'
|
||
|
|
import Todo from './Todo'
|
||
|
|
|
||
|
|
const TodoList = ({ todos, toggleTodo }) => (
|
||
|
|
<ul>
|
||
|
|
{todos.map(todo =>
|
||
|
|
<Todo
|
||
|
|
key={todo.id}
|
||
|
|
{...todo}
|
||
|
|
onClick={() => toggleTodo(todo.id)}
|
||
|
|
/>
|
||
|
|
)}
|
||
|
|
</ul>
|
||
|
|
)
|
||
|
|
|
||
|
|
TodoList.propTypes = {
|
||
|
|
todos: PropTypes.arrayOf(PropTypes.shape({
|
||
|
|
id: PropTypes.number.isRequired,
|
||
|
|
completed: PropTypes.bool.isRequired,
|
||
|
|
text: PropTypes.string.isRequired
|
||
|
|
}).isRequired).isRequired,
|
||
|
|
toggleTodo: PropTypes.func.isRequired
|
||
|
|
}
|
||
|
|
|
||
|
|
export default TodoList
|