From e597b6da4faa1f30c7b3479cdbb96ac5b4fbb0f5 Mon Sep 17 00:00:00 2001
From: buhuazhen <hua100783@gmail.com>
Date: 星期二, 17 三月 2026 11:44:20 +0800
Subject: [PATCH] feat(主题): 新增暗色模式支持

---
 src/layout/components/Settings/index.vue |   28 ++++++++++++++++++++++++++++
 1 files changed, 28 insertions(+), 0 deletions(-)

diff --git a/src/layout/components/Settings/index.vue b/src/layout/components/Settings/index.vue
index b4796f3..917b28b 100644
--- a/src/layout/components/Settings/index.vue
+++ b/src/layout/components/Settings/index.vue
@@ -71,6 +71,24 @@
         />
       </span>
     </div>
+    <div class="drawer-item">
+      <span>鏄剧ず妯″紡</span>
+      <span class="comp-style">
+        <el-select
+          v-model="settingsStore.darkMode"
+          placeholder="璇烽�夋嫨"
+          style="width: 130px"
+          @change="darkModeChange"
+        >
+          <el-option
+            v-for="item in darkModeOptions"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value"
+          />
+        </el-select>
+      </span>
+    </div>
     <el-divider />
 
     <h3 class="drawer-title">绯荤粺甯冨眬閰嶇疆</h3>
@@ -152,6 +170,11 @@
   "#8F4B28",
   "#4C0009",
 ]);
+const darkModeOptions = ref([
+  { label: "璺熼殢绯荤粺", value: "auto" },
+  { label: "娴呰壊", value: "light" },
+  { label: "娣辫壊", value: "dark" },
+]);
 
 /** 鏄惁闇�瑕乼opnav */
 function topNavChange(val) {
@@ -164,6 +187,10 @@
 function themeChange(val) {
   settingsStore.theme = val;
   handleThemeStyle(val);
+}
+
+function darkModeChange(val) {
+  settingsStore.setDarkMode(val);
 }
 
 function handleTheme(val) {
@@ -181,6 +208,7 @@
     dynamicTitle: storeSettings.value.dynamicTitle,
     sideTheme: storeSettings.value.sideTheme,
     theme: storeSettings.value.theme,
+    darkMode: storeSettings.value.darkMode,
   };
   localStorage.setItem("layout-setting", JSON.stringify(layoutSetting));
   setTimeout(proxy.$modal.closeLoading(), 1000);

--
Gitblit v1.9.3