From bfc231743653b27b4ec5fbaa61ea7c92228cf7b3 Mon Sep 17 00:00:00 2001 From: Aman Gupta Date: Sat, 3 Oct 2020 21:38:45 +0530 Subject: [PATCH 1/3] Update README.md --- README.md | 15 +-------------- 1 file changed, 1 insertion(+), 14 deletions(-) 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 ///// From ed94e88967551a540a0b244f550a9eefbc6a700a Mon Sep 17 00:00:00 2001 From: Aman Gupta Date: Sun, 4 Oct 2020 09:25:14 +0530 Subject: [PATCH 2/3] Update index.html --- index.html | 50 +++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 49 insertions(+), 1 deletion(-) 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
+
+ +
+
    + + + +
+
+
+ + + + + + +
+
+ + + From f3c108b78d26d045bc38d375bf8d849308349b54 Mon Sep 17 00:00:00 2001 From: Aman Gupta Date: Sun, 4 Oct 2020 09:26:46 +0530 Subject: [PATCH 3/3] Update app.js --- js/app.js | 223 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 222 insertions(+), 1 deletion(-) 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)); +});