-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
120 lines (98 loc) · 3.5 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
118
119
120
const taskForm = document.getElementById('task-form');
const confirmCloseDialog = document.getElementById('confirm-close-dialog');
const openTaskFormBtn = document.getElementById('open-task-form-btn');
const closeTaskFormBtn = document.getElementById('close-task-form-btn');
const addOrUpdateTaskBtn = document.getElementById('add-or-update-task-btn');
const cancelBtn = document.getElementById('cancel-btn');
const discardBtn = document.getElementById('discard-btn');
const tasksContainer = document.getElementById('tasks-container');
const titleInput = document.getElementById('title-input');
const dateInput = document.getElementById('date-input');
const descriptionInput = document.getElementById('description-input');
const taskData = JSON.parse(localStorage.getItem('data')) || [];
let currentTask = {};
const addOrUpdateTask = () => {
const dataArrIndex = taskData.findIndex(item => item.id === currentTask.id);
const taskObj = {
id: `${titleInput.value.toLowerCase().split(' ').join('-')}-${Date.now()}`,
title: titleInput.value,
date: dateInput.value,
description: descriptionInput.value,
};
if (dataArrIndex === -1) {
taskData.unshift(taskObj);
} else {
taskData[dataArrIndex] = taskObj;
}
localStorage.setItem('data', JSON.stringify(taskData));
updateTaskContainer();
reset();
};
const updateTaskContainer = () => {
tasksContainer.innerHTML = '';
taskData.forEach(({ id, title, date, description }) => {
tasksContainer.innerHTML += `
<div class="task" id="${id}">
<p><strong>Title:</strong> ${title}</p>
<p><strong>Date:</strong> ${date}</p>
<p><strong>Description:</strong> ${description}</p>
<button onclick="editTask(this)" type="button" class="btn">Edit</button>
<button onclick="deleteTask(this)" type="button" class="btn">Delete</button>
</div>
`;
});
};
const deleteTask = buttonEl => {
const dataArrIndex = taskData.findIndex(
item => item.id === buttonEl.parentElement.id
);
buttonEl.parentElement.remove();
taskData.splice(dataArrIndex, 1);
localStorage.setItem('data', JSON.stringify(taskData));
};
const editTask = buttonEl => {
const dataArrIndex = taskData.findIndex(
item => item.id === buttonEl.parentElement.id
);
currentTask = taskData[dataArrIndex];
titleInput.value = currentTask.title;
dateInput.value = currentTask.date;
descriptionInput.value = currentTask.description;
addOrUpdateTaskBtn.innerText = 'Update Task';
taskForm.classList.toggle('hidden');
};
const reset = () => {
titleInput.value = '';
dateInput.value = '';
descriptionInput.value = '';
taskForm.classList.toggle('hidden');
currentTask = {};
};
if (taskData.length) {
updateTaskContainer();
}
openTaskFormBtn.addEventListener('click', () =>
taskForm.classList.toggle('hidden')
);
closeTaskFormBtn.addEventListener('click', () => {
const formInputsContainValues =
titleInput.value || dateInput.value || descriptionInput.value;
const formInputValuesUpdated =
titleInput.value !== currentTask.title ||
dateInput.value !== currentTask.date ||
descriptionInput.value !== currentTask.description;
if (formInputsContainValues && formInputValuesUpdated) {
confirmCloseDialog.showModal();
} else {
reset();
}
});
cancelBtn.addEventListener('click', () => confirmCloseDialog.close());
discardBtn.addEventListener('click', () => {
confirmCloseDialog.close();
reset();
});
taskForm.addEventListener('submit', e => {
e.preventDefault();
addOrUpdateTask();
});