-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
52 lines (41 loc) · 1.46 KB
/
main.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
(function () {
const accordionItems = setupItems({ selector: "#accordion-item" });
accordionItems.forEach((buttonNode) => {
buttonNode.addEventListener("click", (e) => {
const buttonId = e.target.dataset.id;
const buttonActive = e.target.dataset.active;
/* Checking for previous activated elements and deactivating it */
accordionItems.forEach((item) => {
const itemId = item.dataset.id;
const itemActive = item.dataset.active;
if (itemActive === "true" && buttonId !== itemId) {
toggleActive({ item, active: itemActive });
}
});
toggleActive({ item: e.target, active: buttonActive });
});
});
})();
function setupItems({ selector }) {
const accordionButtons = document.querySelectorAll(selector);
accordionButtons.forEach((button, index) => {
// assign data-id attribute to every accordion button to keep it idetified
button.dataset.id = index;
button.dataset.active = false;
});
return accordionButtons;
}
function toggleActive({ item, active }) {
const itemSpan = item.children[0];
const itemArrow = item.children[1];
const content = item.nextElementSibling;
if (active === "true") {
item.dataset.active = false;
content.style.maxHeight = 0;
} else {
item.dataset.active = true;
content.style.maxHeight = content.scrollHeight + "px";
}
itemSpan.classList.toggle("accordion__btn__span--active");
itemArrow.classList.toggle("arrow-active");
}