forked from thecodercoder/fem-faq-accordion
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
47 lines (39 loc) · 1.33 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
document.querySelectorAll('.accordion__question').forEach((item) => {
item.addEventListener('click', (event) => {
console.log('click!');
let accCollapse = item.nextElementSibling;
if (!item.classList.contains('collapsing')) {
// Open accordion item
if (!item.classList.contains('open')) {
console.log('toggle accordion button');
accCollapse.style.display = 'block';
let accHeight = accCollapse.clientHeight;
console.log(accHeight);
setTimeout(() => {
accCollapse.style.height = accHeight + 'px';
accCollapse.style.display = '';
}, 1);
accCollapse.classList = 'accordion__collapse collapsing';
setTimeout(() => {
console.log('open accordion content');
accCollapse.classList = 'accordion__collapse collapse open';
}, 300);
}
// Close accordion item
else {
// Remove "collapse open" from .accordion__collapse, add "collapsing"
accCollapse.classList = 'accordion__collapse collapsing';
setTimeout(() => {
accCollapse.style.height = '0px';
}, 1);
// After X amount of time, remove "collapsing" class and add "collapse" class
setTimeout(() => {
console.log('close accordion content');
accCollapse.classList = 'accordion__collapse collapse';
accCollapse.style.height = '';
}, 300);
}
item.classList.toggle('open');
}
});
});