diff --git a/README.md b/README.md index e7670232..30352429 100644 --- a/README.md +++ b/README.md @@ -2,20 +2,7 @@ In this tutorial, a JavaScript beginner can be able to create a beautiful and functional to do list using JavaScript. I will talk about the logic behind every line of code, before opening my text editor and start typing the code. it's a step by step tutorial, you won't get lost at any stage of this tutorial. - -to follow the tutorial step by step, when we get to the second part (when we type the code), you'll need to download the starter template from here. - -The tutorial video link : https://youtu.be/b8sUhU_eq3g - -When you open the folder, you'll find all the files needed to get started, the CSS code, is already typed (see style.css file), as we're not going to talk about CSS in our tutorial. we're going just to talk about HTML and JavaScript. - -the to-do list we're going to create has a beautiful UI, the user can add a to-do by filling the input and hit ENTER, after that he can rather check the to-do when it's done, or remove it using the delete button. - -The user's to-do list is stored in the local storage, so when he refreshes the page, he can always find the list there. - -There is the possibility for the user, to clear the list, by clicking the button clear, at the top right corner of our app. - -The to do list app, shows the today's date to the user, for that we're using a method called toLocaleDateString, which you can read about here: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toLocaleDateString +for that we're using a method called toLocaleDateString, which you can read about here: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toLocaleDateString ///// Here you can find some other tutorial, that you might like to see ///// diff --git a/index.html b/index.html index 3bf3ada8..76fed260 100644 --- a/index.html +++ b/index.html @@ -1 +1,49 @@ - + + + + + + To-Do App + + + + + + +
+ +
+
+ +
+
+

Your To-Do list

+
99
+
+
hello
+
+ +
+ +
+
+ + + + + + +
+
+ + + diff --git a/js/app.js b/js/app.js index 74cbc288..d8b89124 100644 --- a/js/app.js +++ b/js/app.js @@ -1 +1,222 @@ -// CODE EXPLAINED channel \ No newline at end of file +// CODE EXPLAINED channel + + +function myFunction() { + var d = new Date(); + console.log(d); + var weekday = new Array(7); + weekday[0]="Sunday"; + weekday[1]="Monday"; + weekday[2]="Tuesday"; + weekday[3]="Wednesday"; + weekday[4]="Thrusday"; + weekday[5]="Friday"; + weekday[6]="Saturday"; + + var month = new Array(11); + month[0] = "Jan"; + month[1] = "Feb"; + month[2] = "Mar"; + month[3] = "April"; + month[4] = "May"; + month[5] = "June"; + month[6] = "July"; + month[7] = "Aug"; + month[8] = "Sept"; + month[9] = "Oct"; + month[10] = "Nov"; + month[11] = "Dec"; + + var mon = month[d.getMonth()]; + var day = weekday[d.getDay()]; + var date = d.getDate(); + document.getElementById("date").innerHTML = day +", "+ mon + " "+date ; + } + + myFunction(); + + function showTime(){ + var date = new Date(); + var h = date.getHours(); // 0 - 23 + var m = date.getMinutes(); // 0 - 59 + + var session = "AM"; + + if(h == 0){ + h = 12; + } + + if(h > 12){ + h = h - 12; + session = "PM"; + } + + h = (h < 10) ? "0" + h : h; + m = (m < 10) ? "0" + m : m; + + + var time = h + ":" + m + ":" + " " + session; + document.getElementById("MyClockDisplay").innerText = time; + document.getElementById("MyClockDisplay").textContent = time; + + setTimeout(showTime, 1000); + +} + +showTime(); + +// showing data in todolist +const clear = document.querySelector(".clear"); +const list= document.getElementById("list"); +const input=document.getElementById('input'); + +const check = "fa-check-circle"; +const uncheck = "fa-circle-thin"; +const linethrough="lineThrough"; +let LIST, id; + + +//get item +let data = localStorage.getItem("storeitem"); + +if(data) +{ + LIST =JSON.parse(data); + id=LIST.length; + loadList(LIST); + +} +else{ + LIST=[]; + id=0; +} + +function loadList(array){ + array.forEach(function(item){ + add(item.name,item.id,item.done,item.trash); + }); +} +//clear +clear.addEventListener("click",function(){ + localStorage.clear(); + location.reload(); +}) + + + + function add(todo,id,done,trash){ + + + if(trash){ + return; + } + const don = done ? check:uncheck; + const line = done ? linethrough:""; + + const item = `
  • + +

    ${todo}

    + +
  • `; + + const position="beforeend"; + + list.insertAdjacentHTML(position, item); + } + + + + document.addEventListener("keyup",function(even){ + if(event.keyCode==13) + { + const todo = input.value; + + if(todo=="") + { + alert('ERROR :Please Input a task') + } + + if(todo) + { + add(todo, id, false,false); + + LIST.push({ + name:todo, + id:id, + done:false, + trash:false + }); + localStorage.setItem("storeitem",JSON.stringify(LIST)); + id++; + + } + input.value=""; + + } + }); + + + const btu= document.getElementById('foo'); + + btu.addEventListener("click",function(cgata){ + + + const todo = input.value; + + if(todo=="") + { + alert('ERROR :Please Input a task') + } + + if(todo) + { + add(todo, id, false,false); + + LIST.push({ + name:todo, + id:id, + done:false, + trash:false + }); + id++; + + } + input.value=""; + + }) + + + function completeto(element) + { + element.classList.toggle(check); + element.classList.toggle(uncheck); + element.parentNode.querySelector(".text").classList.toggle(linethrough); + + LIST[element.id].done =LIST[element.id].done?false:true; + } + + + function removeto(element) + { + element.parentNode.parentNode.removeChild(element.parentNode); + LIST[element.id].trash=true; + + } + + + list.addEventListener("click",function(event){ + const element = event.target; + const elementjob = element.attributes.job.value; + + if(elementjob=="complete") + { + completeto(element); + + } + else if(elementjob=="delete") + { + removeto(element); + } + + localStorage.setItem("storeitem",JSON.stringify(LIST)); +});