-
Notifications
You must be signed in to change notification settings - Fork 1
/
cheatsheet.js
71 lines (53 loc) · 1.71 KB
/
cheatsheet.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
/* global bootstrap: false */
(() => {
"use strict";
// Tooltip and popover demos
document.querySelectorAll(".tooltip-demo").forEach((tooltip) => {
new bootstrap.Tooltip(tooltip, {
selector: '[data-bs-toggle="tooltip"]',
});
});
document
.querySelectorAll('[data-bs-toggle="popover"]')
.forEach((popover) => {
new bootstrap.Popover(popover);
});
document.querySelectorAll(".toast").forEach((toastNode) => {
const toast = new bootstrap.Toast(toastNode, {
autohide: false,
});
toast.show();
});
// Disable empty links and submit buttons
document.querySelectorAll('[href="#"], [type="submit"]').forEach((link) => {
link.addEventListener("click", (event) => {
event.preventDefault();
});
});
function setActiveItem() {
const { hash } = window.location;
if (hash === "") {
return;
}
const link = document.querySelector(`.bd-aside a[href="${hash}"]`);
if (!link) {
return;
}
const active = document.querySelector(".bd-aside .active");
const parent = link.parentNode.parentNode.previousElementSibling;
link.classList.add("active");
if (parent.classList.contains("collapsed")) {
parent.click();
}
if (!active) {
return;
}
const expanded = active.parentNode.parentNode.previousElementSibling;
active.classList.remove("active");
if (expanded && parent !== expanded) {
expanded.click();
}
}
setActiveItem();
window.addEventListener("hashchange", setActiveItem);
})();