fix invalid theme error

This commit is contained in:
heaprc 2025-03-29 04:40:29 +01:00
parent d3357d2acd
commit 9f30dd0e7a

View file

@ -160,18 +160,33 @@ class OptionsWaiter {
// Update theme selection // Update theme selection
const themeSelect = document.getElementById("theme"); const themeSelect = document.getElementById("theme");
themeSelect.selectedIndex = themeSelect.querySelector(`option[value="${theme}"`).index; let themeOption = themeSelect.querySelector(`option[value="${theme}"]`);
if (!themeOption) {
const preferredColorScheme = this.getPreferredColorScheme();
document.querySelector(":root").className = preferredColorScheme;
themeOption = themeSelect.querySelector(`option[value="${preferredColorScheme}"]`);
}
themeSelect.selectedIndex = themeOption.index;
} }
/** /**
* Applies the user's preferred color scheme using the `prefers-color-scheme` media query. * Applies the user's preferred color scheme using the `prefers-color-scheme` media query.
*/ */
applyPreferredColorScheme() { applyPreferredColorScheme() {
const prefersDarkScheme = window.matchMedia("(prefers-color-scheme: dark)").matches; const theme = this.getPreferredColorScheme();
const theme = prefersDarkScheme ? "dark" : "classic";
this.changeTheme(theme); this.changeTheme(theme);
} }
/**
* Get the user's preferred color scheme using the `prefers-color-scheme` media query.
*/
getPreferredColorScheme() {
const prefersDarkScheme = window.matchMedia("(prefers-color-scheme: dark)").matches;
return prefersDarkScheme ? "dark" : "classic";
}
/** /**
* Changes the console logging level. * Changes the console logging level.
* *