-
Notifications
You must be signed in to change notification settings - Fork 0
/
dark-mode.js
46 lines (40 loc) · 1.24 KB
/
dark-mode.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
"use strict";
let darkModeEnabled = false;
let darkModeButton = document.getElementById("dark_mode_button");
darkModeButton.addEventListener("click", switchTheme);
console.log("Dark mode enabled: " + getCookie("dark-mode"));
if (getCookie("dark-mode") === "true") {
switchTheme();
}
function switchTheme() {
if (!darkModeEnabled) {
document.body.setAttribute("data-theme", "dark");
darkModeButton.innerHTML = "Light Mode";
} else {
document.body.removeAttribute("data-theme");
darkModeButton.innerHTML = "Dark Mode";
}
darkModeEnabled = !darkModeEnabled;
setCookie("dark-mode", darkModeEnabled, 10 * 365);
}
function setCookie(cname, cvalue, exdays) {
const d = new Date();
d.setTime(d.getTime() + exdays * 24 * 60 * 60 * 1000);
let expires = "expires=" + d.toUTCString();
document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
}
function getCookie(cname) {
let name = cname + "=";
let decodedCookie = decodeURIComponent(document.cookie);
let ca = decodedCookie.split(";");
for (let i = 0; i < ca.length; i++) {
let c = ca[i];
while (c.charAt(0) === " ") {
c = c.substring(1);
}
if (c.indexOf(name) === 0) {
return c.substring(name.length, c.length);
}
}
return "";
}