Merge pull request #2007 from 0xh3xa/bugfix/invalid-theme-option

Load the user's preferred color scheme if the URL contains an invalid theme
This commit is contained in:
a3957273 2025-04-03 08:00:39 +01:00 committed by GitHub
commit 14472d3b40
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

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.
* *