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 | 151 +++++++++++++++++++++++++++++--------------------
1 files changed, 89 insertions(+), 62 deletions(-)
diff --git a/src/layout/components/Settings/index.vue b/src/layout/components/Settings/index.vue
index e107218..917b28b 100644
--- a/src/layout/components/Settings/index.vue
+++ b/src/layout/components/Settings/index.vue
@@ -1,66 +1,66 @@
<template>
<el-drawer v-model="showSettings" direction="rtl" size="300px">
- <div class="setting-drawer-title">
- <h3 class="drawer-title">涓婚椋庢牸璁剧疆</h3>
- </div>
- <div class="setting-drawer-block-checbox">
- <div
- class="setting-drawer-block-checbox-item"
- @click="handleTheme('theme-dark')"
- >
- <img src="@/assets/images/dark.svg" alt="dark" />
- <div
- v-if="sideTheme === 'theme-dark'"
- class="setting-drawer-block-checbox-selectIcon"
- style="display: block"
- >
- <i aria-label="鍥炬爣: check" class="anticon anticon-check">
- <svg
- viewBox="64 64 896 896"
- data-icon="check"
- width="1em"
- height="1em"
- :fill="theme"
- aria-hidden="true"
- focusable="false"
- class
- >
- <path
- d="M912 190h-69.9c-9.8 0-19.1 4.5-25.1 12.2L404.7 724.5 207 474a32 32 0 0 0-25.1-12.2H112c-6.7 0-10.4 7.7-6.3 12.9l273.9 347c12.8 16.2 37.4 16.2 50.3 0l488.4-618.9c4.1-5.1.4-12.8-6.3-12.8z"
- />
- </svg>
- </i>
- </div>
- </div>
- <div
- class="setting-drawer-block-checbox-item"
- @click="handleTheme('theme-light')"
- >
- <img src="@/assets/images/light.svg" alt="light" />
- <div
- v-if="sideTheme === 'theme-light'"
- class="setting-drawer-block-checbox-selectIcon"
- style="display: block"
- >
- <i aria-label="鍥炬爣: check" class="anticon anticon-check">
- <svg
- viewBox="64 64 896 896"
- data-icon="check"
- width="1em"
- height="1em"
- :fill="theme"
- aria-hidden="true"
- focusable="false"
- class
- >
- <path
- d="M912 190h-69.9c-9.8 0-19.1 4.5-25.1 12.2L404.7 724.5 207 474a32 32 0 0 0-25.1-12.2H112c-6.7 0-10.4 7.7-6.3 12.9l273.9 347c12.8 16.2 37.4 16.2 50.3 0l488.4-618.9c4.1-5.1.4-12.8-6.3-12.8z"
- />
- </svg>
- </i>
- </div>
- </div>
- </div>
+<!-- <div class="setting-drawer-title">-->
+<!-- <h3 class="drawer-title">涓婚椋庢牸璁剧疆</h3>-->
+<!-- </div>-->
+<!-- <div class="setting-drawer-block-checbox">-->
+<!-- <div-->
+<!-- class="setting-drawer-block-checbox-item"-->
+<!-- @click="handleTheme('theme-dark')"-->
+<!-- >-->
+<!-- <img src="@/assets/images/dark.svg" alt="dark" />-->
+<!-- <div-->
+<!-- v-if="sideTheme === 'theme-dark'"-->
+<!-- class="setting-drawer-block-checbox-selectIcon"-->
+<!-- style="display: block"-->
+<!-- >-->
+<!-- <i aria-label="鍥炬爣: check" class="anticon anticon-check">-->
+<!-- <svg-->
+<!-- viewBox="64 64 896 896"-->
+<!-- data-icon="check"-->
+<!-- width="1em"-->
+<!-- height="1em"-->
+<!-- :fill="theme"-->
+<!-- aria-hidden="true"-->
+<!-- focusable="false"-->
+<!-- class-->
+<!-- >-->
+<!-- <path-->
+<!-- d="M912 190h-69.9c-9.8 0-19.1 4.5-25.1 12.2L404.7 724.5 207 474a32 32 0 0 0-25.1-12.2H112c-6.7 0-10.4 7.7-6.3 12.9l273.9 347c12.8 16.2 37.4 16.2 50.3 0l488.4-618.9c4.1-5.1.4-12.8-6.3-12.8z"-->
+<!-- />-->
+<!-- </svg>-->
+<!-- </i>-->
+<!-- </div>-->
+<!-- </div>-->
+<!-- <div-->
+<!-- class="setting-drawer-block-checbox-item"-->
+<!-- @click="handleTheme('theme-light')"-->
+<!-- >-->
+<!-- <img src="@/assets/images/light.svg" alt="light" />-->
+<!-- <div-->
+<!-- v-if="sideTheme === 'theme-light'"-->
+<!-- class="setting-drawer-block-checbox-selectIcon"-->
+<!-- style="display: block"-->
+<!-- >-->
+<!-- <i aria-label="鍥炬爣: check" class="anticon anticon-check">-->
+<!-- <svg-->
+<!-- viewBox="64 64 896 896"-->
+<!-- data-icon="check"-->
+<!-- width="1em"-->
+<!-- height="1em"-->
+<!-- :fill="theme"-->
+<!-- aria-hidden="true"-->
+<!-- focusable="false"-->
+<!-- class-->
+<!-- >-->
+<!-- <path-->
+<!-- d="M912 190h-69.9c-9.8 0-19.1 4.5-25.1 12.2L404.7 724.5 207 474a32 32 0 0 0-25.1-12.2H112c-6.7 0-10.4 7.7-6.3 12.9l273.9 347c12.8 16.2 37.4 16.2 50.3 0l488.4-618.9c4.1-5.1.4-12.8-6.3-12.8z"-->
+<!-- />-->
+<!-- </svg>-->
+<!-- </i>-->
+<!-- </div>-->
+<!-- </div>-->
+<!-- </div>-->
<div class="drawer-item">
<span>涓婚棰滆壊</span>
<span class="comp-style">
@@ -69,6 +69,24 @@
:predefine="predefineColors"
@change="themeChange"
/>
+ </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 />
@@ -146,12 +164,16 @@
"#81D8D0",
"#E85827",
"#008C8C",
- "#002FA7",
"#F9DC24",
"#B05923",
"#003153",
"#8F4B28",
"#4C0009",
+]);
+const darkModeOptions = ref([
+ { label: "璺熼殢绯荤粺", value: "auto" },
+ { label: "娴呰壊", value: "light" },
+ { label: "娣辫壊", value: "dark" },
]);
/** 鏄惁闇�瑕乼opnav */
@@ -165,6 +187,10 @@
function themeChange(val) {
settingsStore.theme = val;
handleThemeStyle(val);
+}
+
+function darkModeChange(val) {
+ settingsStore.setDarkMode(val);
}
function handleTheme(val) {
@@ -182,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