diff --git a/public/index.html b/public/index.html index 1bca004..bb91bb7 100644 --- a/public/index.html +++ b/public/index.html @@ -437,13 +437,18 @@ -
- - +
+

界面外观 (Appearance)

+
+ + +

选择“跟随系统”后,应用将自动同步您操作系统或浏览器的黑暗/白天模式设置。

+
diff --git a/public/js/app.js b/public/js/app.js index 1e1e7c9..bee5886 100644 --- a/public/js/app.js +++ b/public/js/app.js @@ -183,6 +183,17 @@ // Auth & Theme listeners dom.themeToggle.addEventListener('change', toggleTheme); + + // System Theme Listener (Real-time) + const systemThemeMedia = window.matchMedia('(prefers-color-scheme: light)'); + if (systemThemeMedia.addEventListener) { + systemThemeMedia.addEventListener('change', () => { + const savedTheme = localStorage.getItem('theme') || (window.SITE_SETTINGS && window.SITE_SETTINGS.default_theme) || 'dark'; + if (savedTheme === 'auto') { + applyTheme('auto'); + } + }); + } dom.btnLogin.addEventListener('click', openLoginModal); dom.closeLoginModal.addEventListener('click', closeLoginModal); dom.loginForm.addEventListener('submit', handleLogin); @@ -1705,6 +1716,16 @@ networkChart.draw(); } } + + // Default Theme + if (settings.default_theme) { + if (dom.defaultThemeInput) dom.defaultThemeInput.value = settings.default_theme; + // If setting is 'auto', we also sync immediately + const savedTheme = localStorage.getItem('theme'); + if (!savedTheme || savedTheme === 'auto') { + applyTheme(settings.default_theme); + } + } } async function saveSiteSettings() { @@ -1723,6 +1744,11 @@ p95_type: dom.p95TypeSelect.value }; + // If user sets default to auto, we should clear their manual override or set it to auto + if (settings.default_theme === 'auto') { + localStorage.setItem('theme', 'auto'); + } + dom.btnSaveSiteSettings.disabled = true; dom.btnSaveSiteSettings.textContent = '保存中...';