| 
 | 1 | +let form = document.querySelector("form");  | 
 | 2 | +let input = document.querySelector("input");  | 
 | 3 | +let output = document.querySelector(".output");  | 
 | 4 | +let message = document.querySelector(".message-container");  | 
 | 5 | + | 
 | 6 | +function getTodo(value) {  | 
 | 7 | +  let todo = document.createElement("div");  | 
 | 8 | +  let textEl = document.createElement("span");  | 
 | 9 | +  textEl.innerHTML = value;  | 
 | 10 | +  todo.appendChild(textEl);  | 
 | 11 | +  message.classList.toggle("success");  | 
 | 12 | +  message.textContent = "Item Added";  | 
 | 13 | + | 
 | 14 | +  setTimeout(() => {  | 
 | 15 | +    message.classList.toggle("success");  | 
 | 16 | +  }, 2000);  | 
 | 17 | + | 
 | 18 | +  let closeEl = document.createElement("span");  | 
 | 19 | +  closeEl.innerHTML = "×";  | 
 | 20 | +  closeEl.classList.add("delete");  | 
 | 21 | + | 
 | 22 | +  closeEl.addEventListener("click", () => {  | 
 | 23 | +    output.removeChild(todo);  | 
 | 24 | +    message.classList.toggle("error");  | 
 | 25 | +    message.textContent = "Item Deleted";  | 
 | 26 | + | 
 | 27 | +    setTimeout(() => {  | 
 | 28 | +      message.classList.toggle("error");  | 
 | 29 | +    }, 2000);  | 
 | 30 | +  });  | 
 | 31 | + | 
 | 32 | +  todo.appendChild(closeEl);  | 
 | 33 | +  todo.classList.add("todo");  | 
 | 34 | +  return todo;  | 
 | 35 | +}  | 
 | 36 | + | 
 | 37 | +form.addEventListener("submit", (e) => {  | 
 | 38 | +  e.preventDefault();  | 
 | 39 | +  let value = input.value;  | 
 | 40 | +  if (!value.trim()) return;  | 
 | 41 | +  output.appendChild(getTodo(value));  | 
 | 42 | +  input.value = "";  | 
 | 43 | +});  | 
0 commit comments