|  | 
|  | 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