summaryrefslogtreecommitdiffstats
path: root/assets/js/themes.js
diff options
context:
space:
mode:
Diffstat (limited to 'assets/js/themes.js')
-rw-r--r--assets/js/themes.js37
1 files changed, 30 insertions, 7 deletions
diff --git a/assets/js/themes.js b/assets/js/themes.js
index 683aea39..90a05c36 100644
--- a/assets/js/themes.js
+++ b/assets/js/themes.js
@@ -1,8 +1,8 @@
-var toggle_theme = document.getElementById('toggle_theme')
+var toggle_theme = document.getElementById('toggle_theme');
toggle_theme.href = 'javascript:void(0);';
toggle_theme.addEventListener('click', function () {
- var dark_mode = document.getElementById('dark_theme').media == 'none';
+ var dark_mode = document.getElementById('dark_theme').media === 'none';
var url = '/toggle_theme?redirect=false';
var xhr = new XMLHttpRequest();
@@ -11,19 +11,24 @@ toggle_theme.addEventListener('click', function () {
xhr.open('GET', url, true);
set_mode(dark_mode);
- localStorage.setItem('dark_mode', dark_mode);
+ window.localStorage.setItem('dark_mode', dark_mode ? 'dark' : 'light');
xhr.send();
});
window.addEventListener('storage', function (e) {
- if (e.key == 'dark_mode') {
- var dark_mode = e.newValue === 'true';
- set_mode(dark_mode);
+ if (e.key === 'dark_mode') {
+ update_mode(e.newValue);
}
});
-function set_mode(bool) {
+window.addEventListener('load', function () {
+ window.localStorage.setItem('dark_mode', document.getElementById('dark_mode_pref').textContent);
+ // Update localStorage if dark mode preference changed on preferences page
+ update_mode(window.localStorage.dark_mode);
+});
+
+function set_mode (bool) {
document.getElementById('dark_theme').media = !bool ? 'none' : '';
document.getElementById('light_theme').media = bool ? 'none' : '';
@@ -33,3 +38,21 @@ function set_mode(bool) {
toggle_theme.children[0].setAttribute('class', 'icon ion-ios-moon');
}
}
+
+function update_mode (mode) {
+ if (mode === 'true' /* for backwards compatibility */ || mode === 'dark') {
+ // If preference for dark mode indicated
+ set_mode(true);
+ }
+ else if (mode === 'false' /* for backwards compaibility */ || mode === 'light') {
+ // If preference for light mode indicated
+ set_mode(false);
+ }
+ else if (document.getElementById('dark_mode_pref').textContent === '' && window.matchMedia('(prefers-color-scheme: dark)').matches) {
+ // If no preference indicated here and no preference indicated on the preferences page (backend), but the browser tells us that the operating system has a dark theme
+ set_mode(true);
+ }
+ // else do nothing, falling back to the mode defined by the `dark_mode` preference on the preferences page (backend)
+}
+
+