-
Notifications
You must be signed in to change notification settings - Fork 358
Expand file tree
/
Copy pathdarkmode-toggle.js
More file actions
63 lines (51 loc) · 1.59 KB
/
darkmode-toggle.js
File metadata and controls
63 lines (51 loc) · 1.59 KB
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
// Constants
const THEME = {
DARK: "dark",
LIGHT: "light",
STORAGE_KEY: "denoDocsTheme",
};
// DOM Elements
const colorThemes = document.querySelectorAll("[data-color-mode]");
const darkModeToggleButton = document.getElementById("theme-toggle");
// Get user's preferred theme
const getUserPreference = () => {
const storedTheme = localStorage.getItem(THEME.STORAGE_KEY);
if (storedTheme) return storedTheme;
return window.matchMedia("(prefers-color-scheme: dark)").matches
? THEME.DARK
: THEME.LIGHT;
};
// Update theme in DOM and localStorage
const setTheme = (theme) => {
document.documentElement.classList.remove(THEME.DARK, THEME.LIGHT);
document.documentElement.classList.add(theme);
colorThemes.forEach((el) => {
el.setAttribute("data-color-mode", theme);
});
localStorage.setItem(THEME.STORAGE_KEY, theme);
};
// Toggle between light and dark themes
const toggleDarkMode = () => {
const currentTheme = getUserPreference();
const newTheme = currentTheme === THEME.LIGHT ? THEME.DARK : THEME.LIGHT;
setTheme(newTheme);
};
// Initialize
const init = () => {
if (!darkModeToggleButton) {
console.warn("Theme toggle button not found");
return;
}
// Set initial theme
setTheme(getUserPreference());
// Add click listener
darkModeToggleButton.addEventListener("click", toggleDarkMode);
// Listen for system theme changes
window.matchMedia("(prefers-color-scheme: dark)")
.addEventListener("change", (e) => {
if (!localStorage.getItem(THEME.STORAGE_KEY)) {
setTheme(e.matches ? THEME.DARK : THEME.LIGHT);
}
});
};
init();