-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
119 lines (92 loc) · 2.62 KB
/
script.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
110
111
112
113
114
115
116
117
const form = document.querySelector('form');
const taskList = document.querySelector('#task-list');
const input = document.querySelector('#txtTaskName');
const btnDeleteAll = document.querySelector('#btnDeleteAll');
let items;
loadItems();
eventListeners();
function eventListeners() {
form.addEventListener('submit', addNewItem);
taskList.addEventListener('click', deleteItem);
btnDeleteAll.addEventListener('click', deleteAllItems);
}
function loadItems() {
items = getItemsFromLS();
items.forEach(function (item) {
createItem(item);
});
}
// Get items from Local Storage
function getItemsFromLS(){
if(localStorage.getItem('items')===null){
items = [];
}else{
items = JSON.parse(localStorage.getItem('items'));
}
return items;
}
// Set item to Local Storage
function setItemToLS(text){
items = getItemsFromLS();
items.push(text);
localStorage.setItem('items',JSON.stringify(items));
}
// Delete item from LS
function deleteItemFromLS(text){
items = getItemsFromLS();
items.forEach(function(item,index){
if(item === text){
items.splice(index,1);
}
});
localStorage.setItem('items',JSON.stringify(items));
}
function createItem(text) {
// create li
const li = document.createElement('li');
li.className = 'list-group-item list-group-item-secondary';
li.appendChild(document.createTextNode(text));
// create a
const a = document.createElement('a');
a.classList = 'delete-item float-right';
a.setAttribute('href', '#');
a.innerHTML = '<i class="fas fa-times"></i>';
// add a to li
li.appendChild(a);
// add li to ul
taskList.appendChild(li);
}
// add new item
function addNewItem(e) {
if (input.value === '') {
alert('add new item');
}
// create item
createItem(input.value);
// save to LS
setItemToLS(input.value);
// clear input
input.value = '';
e.preventDefault();
}
// delete an item
function deleteItem(e) {
if (e.target.className === 'fas fa-times') {
if (confirm('Do you really want to delete this item ?')) {
e.target.parentElement.parentElement.remove();
deleteItemFromLS(e.target.parentElement.parentElement.textContent);
}
}
e.preventDefault();
}
// delete all items
function deleteAllItems(e) {
if (confirm('Do you really want to delete all list ?')) {
// taskList.innerHTML='';
while(taskList.firstChild){
taskList.removeChild(taskList.firstChild);
}
localStorage.clear();
}
e.preventDefault();
}