-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathscripts.js
69 lines (57 loc) · 2.92 KB
/
scripts.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
(function() {
"use strict";
function switch_theme_rules(theme) {
for (let sheet_file = 0; sheet_file < document.styleSheets.length; sheet_file++) {
if (document.styleSheets[sheet_file].href && document.styleSheets[sheet_file].href.includes("/hlt-") && !(document.styleSheets[sheet_file].href.includes("-light/") || document.styleSheets[sheet_file].href.includes("-dark/"))) {
try {
for (let sheet_rule = 0; sheet_rule < document.styleSheets[sheet_file].cssRules.length; sheet_rule++) {
const rule = document.styleSheets[sheet_file].cssRules[sheet_rule];
if (rule && rule.media && rule.media.mediaText.includes("prefers-color-scheme")) {
const rule_media = rule.media.mediaText;
let new_rule_media = rule.media.mediaText;
if (window.matchMedia("(prefers-color-scheme: dark)").matches) {
if (theme == "dark") {
new_rule_media = rule_media.replace("light", "dark");
}
if (theme == "light") {
new_rule_media = rule_media.replace("dark", "light");
}
} else {
if (theme == "dark") {
new_rule_media = rule_media.replace("dark", "light");
}
if (theme == "light") {
new_rule_media = rule_media.replace("light", "dark");
}
}
rule.media.deleteMedium(rule_media);
rule.media.appendMedium(new_rule_media);
}
}
}
catch (e) {
const broken_sheet = document.styleSheets[sheet_file].href;
console.warn(broken_sheet + " broke something with theme toggle : " + e);
}
}
}
}
const hltThemeToggle = function () {
if (document.documentElement.getAttribute("data-bs-theme") === "dark") {
switch_theme_rules("dark");
} else {
switch_theme_rules("light");
}
}
const observer = new MutationObserver(function (mutations) {
mutations.forEach(mutation => {
if (mutation.type === "attributes" && mutation.attributeName === "data-bs-theme") {
hltThemeToggle();
}
});
});
observer.observe(document.documentElement, {attributes: true});
const prefersColorScheme = window.matchMedia("(prefers-color-scheme: dark)");
prefersColorScheme.addEventListener("change", e => {hltThemeToggle()});
hltThemeToggle();
})();