-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
109 lines (92 loc) · 3.14 KB
/
main.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
const todoInput = document.querySelector(".todo-input");
const todoButton = document.querySelector(".todo-button");
const todoList = document.querySelector(".todo-list");
const filterOption = document.querySelector(".filter-todo");
document.addEventListener("DOMContentLoaded", getLocalTodos);
todoButton.addEventListener("click", addTodo);
todoList.addEventListener("click", deleteCheck);
filterOption.addEventListener("change", filterTodo);
function createTodoItem(task) {
const todoDiv = document.createElement("div");
todoDiv.classList.add("todo");
const newTodo = document.createElement("li");
newTodo.innerText = task;
newTodo.classList.add("todo-item");
todoDiv.appendChild(newTodo);
const completedButton = document.createElement("button");
completedButton.innerHTML = '<i class="fas fa-check-circle"></i>';
completedButton.classList.add("complete-btn");
todoDiv.appendChild(completedButton);
const trashButton = document.createElement("button");
trashButton.innerHTML = '<i class="fas fa-trash"></i>';
trashButton.classList.add("trash-btn");
todoDiv.appendChild(trashButton);
return todoDiv;
}
function addTodo(event) {
event.preventDefault();
const task = todoInput.value.trim();
if (task !== "") {
const todoItem = createTodoItem(task);
todoList.appendChild(todoItem);
saveLocalTodos(task);
todoInput.value = "";
}
}
function deleteCheck(e) {
const item = e.target;
const todo = item.parentElement;
if (item.classList.contains("trash-btn")) {
todo.classList.add("slide");
removeLocalTodos(todo);
todo.addEventListener("transitionend", function () {
todo.remove();
});
}
if (item.classList.contains("complete-btn")) {
todo.classList.toggle("completed");
}
}
function filterTodo() {
const todos = Array.from(todoList.children);
const selectedOption = filterOption.value;
todos.forEach((todo) => {
const isCompleted = todo.classList.contains("completed");
switch (selectedOption) {
case "all":
todo.style.display = "flex";
break;
case "completed":
todo.style.display = isCompleted ? "flex" : "none";
break;
case "incomplete":
todo.style.display = isCompleted ? "none" : "flex";
break;
}
});
}
function saveLocalTodos(todo) {
let todos = getLocalTodosArray();
todos.push(todo);
localStorage.setItem("todos", JSON.stringify(todos));
}
function getLocalTodosArray() {
const storedTodos = localStorage.getItem("todos");
return storedTodos ? JSON.parse(storedTodos) : [];
}
function getLocalTodos() {
const todos = getLocalTodosArray();
todos.forEach((todo) => {
const todoItem = createTodoItem(todo);
todoList.appendChild(todoItem);
});
}
function removeLocalTodos(todo) {
const todoText = todo.querySelector(".todo-item").innerText;
let todos = getLocalTodosArray();
const todoIndex = todos.indexOf(todoText);
if (todoIndex !== -1) {
todos.splice(todoIndex, 1);
localStorage.setItem("todos", JSON.stringify(todos));
}
}