-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTodoList.js
58 lines (52 loc) · 1.41 KB
/
TodoList.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
import React, {useState} from 'react'
import TodoItem from './TodoItem'
function TodoList() {
const [tasks, setTasks] = useState([
{
id: 1,
text: 'Doctor Appointment',
completed: true
},
{
id: 2,
text: 'Meeting at school',
completed: false
}
])
const [text, setText] = useState('')
function addTask(text) {
const newTask = {
id: Date.now(),
text,
completed: false
}
setTasks([...tasks, newTask])
setText('')
}
function deleteTask(id) {
setTasks(tasks.filter(task => task.id !== id))
}
function toggleCompleted (id) {
setTasks(tasks.map(task => {
if (task.id === id) {
return {...task, completed: !task.completed}
} else {
return task
}
}))
}
return (
<div className='todo-list'>
{tasks.map(task => (
<TodoItem
key={task.id} task={task} deleteTask={deleteTask} toggleCompleted={toggleCompleted}
/>
))}
<input
value={text} onChange={e => setText(e.target.value)}
/>
<button onClick={() => addTask(text)}>Add</button>
</div>
)
}
export default TodoList