forked from solygambas/html-css-javascript-projects
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
45 lines (41 loc) · 1.38 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
const smallCups = document.querySelectorAll(".cup-small");
const liters = document.getElementById("liters");
const percentage = document.getElementById("percentage");
const remained = document.getElementById("remained");
const updateBigCup = () => {
const fullCups = document.querySelectorAll(".cup-small.full").length;
const totalCups = smallCups.length;
if (fullCups === 0) {
percentage.style.visibility = "hidden";
percentage.style.height = 0;
} else {
percentage.style.visibility = "visible";
percentage.style.height = `${(fullCups / totalCups) * 330}px`;
percentage.innerText = `${(fullCups / totalCups) * 100}%`;
}
if (fullCups === totalCups) {
remained.style.visibility = "hidden";
remained.style.height = 0;
} else {
percentage.style.visibility = "visible";
liters.innerText = `${2 - (250 * fullCups) / 1000}L`;
}
};
const highlightCups = (index) => {
if (index === 7 && smallCups[index].classList.contains("full")) index--;
if (
smallCups[index].classList.contains("full") &&
!smallCups[index].nextElementSibling.classList.contains("full")
) {
index--;
}
smallCups.forEach((cup, index2) => {
if (index2 <= index) cup.classList.add("full");
else cup.classList.remove("full");
});
updateBigCup();
};
smallCups.forEach((cup, index) =>
cup.addEventListener("click", () => highlightCups(index))
);
updateBigCup();