-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathchecklistProgress.js
118 lines (90 loc) · 3.83 KB
/
checklistProgress.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
/*
ID Categories:
task_ = <li> task number
checkB_ = <input> checkbox, <label> checkbox
checkV_ = <span> checkbox symbol value
taskV_ = <input> task text
*/
var visibTasks = 0;
var completeTasks = 0;
var progress = 0.0;
function add_task() {
const task = document.getElementById("hiddenTasks").lastElementChild; // Get next empty task
const list = document.getElementById("visibleTasks"); // Get visible list
if (visibTasks < 10)
list.insertBefore(task, list.children[0]); // Insert empty task at top
visibTasks++;
update_list_status();
}
function delete_task(elemIDNum) {
const task = document.getElementById("task" + elemIDNum); // Task <li> element
const list = document.getElementById("hiddenTasks"); // Get hidden list
list.insertBefore(task, list.children[0]); // Move to hidden list
// Reset task properties
if (document.getElementById("checkB" + elemIDNum).checked == true) // Remove from completeTasks (if necessary)
completeTasks--;
document.getElementById("checkB" + elemIDNum).checked = false; // Uncheck box
document.getElementById("checkV" + elemIDNum).innerHTML = "done"; // Reset symbol
document.getElementById("taskV" + elemIDNum).readOnly = false; // Reset readOnly status
document.getElementById("taskV" + elemIDNum).value = ""; // Reset text value
document.getElementById("taskV" + elemIDNum).style = "background: transparent; border-color: transparent"; // Reset task color
visibTasks--;
update_list_status();
}
function toggle_task_status(elemID) {
const button = document.getElementById("checkB" + elemID); // Button element
const symbol = document.getElementById("checkV" + elemID); // Symbol element
const task = document.getElementById("taskV" + elemID); // Task element
if (button.checked)
{
completeTasks++;
symbol.innerHTML = "done_outline"; // Switch to thick checkmark
task.readOnly = true;
task.style = "transition: background .5s; background: #222b26; border-color: transparent; color: white";
}
else
{
completeTasks--;
symbol.innerHTML = "done"; // Switch to thin checkmark
task.readOnly = false;
task.style = "transition: background .5s; background: transparent; border-color: transparent; color: white";
}
update_list_status();
}
function toggle_add_button() {
var button = document.getElementById("addButton");
if (visibTasks < 10) // All task elements are shown
button.style.display = "block";
else
button.style.display = "none";
}
function calc_progress() {
progress = (completeTasks / visibTasks) * 100; // Calculate progress percentage
const progressBar = document.getElementById("progressBar"); // Progress bar element
progressBar.style.width = progress.toString() + "%"; // Update width
progressBar.innerHTML = progress.toFixed() + "%"; // Display percentage
}
function update_list_status() {
const emptyList = document.getElementById("noTasks");
const doneList = document.getElementById("finishTasks");
if (visibTasks == 0) // List is empty
{
emptyList.style.display = "block";
doneList.style.display = "none";
}
else if (visibTasks == completeTasks) // All visible tasks are done
{
emptyList.style.display = "none";
doneList.style.display = "block";
document.querySelector('#confetti').click();
}
else
{
emptyList.style.display = "none";
doneList.style.display = "none";
}
calc_progress();
toggle_add_button();
// Debugging statement
//console.log(visibTasks + " : " + completeTasks + " = " + progress);
}