From 8e9bc97e709f7e49586dffb9cc3d2dac4cfef4ca Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期四, 26 三月 2026 10:13:02 +0800
Subject: [PATCH] 进销存升级 1.语法修改

---
 src/store/modules/settings.js |  149 +++++++++++++++++++++++++++++++++++--------------
 1 files changed, 105 insertions(+), 44 deletions(-)

diff --git a/src/store/modules/settings.js b/src/store/modules/settings.js
index 06b91d2..3a5f6a2 100644
--- a/src/store/modules/settings.js
+++ b/src/store/modules/settings.js
@@ -1,44 +1,105 @@
-import defaultSettings from '@/settings'
-import { useDynamicTitle } from '@/utils/dynamicTitle'
-
-const { sideTheme, showSettings, topNav, tagsView, fixedHeader, sidebarLogo, dynamicTitle } = defaultSettings
-
-const storageSetting = JSON.parse(localStorage.getItem('layout-setting')) || ''
-const state = {
-  title: '',
-  theme: storageSetting.theme || '#409EFF',
-  sideTheme: storageSetting.sideTheme || sideTheme,
-  showSettings: showSettings,
-  topNav: storageSetting.topNav === undefined ? topNav : storageSetting.topNav,
-  tagsView: storageSetting.tagsView === undefined ? tagsView : storageSetting.tagsView,
-  fixedHeader: storageSetting.fixedHeader === undefined ? fixedHeader : storageSetting.fixedHeader,
-  sidebarLogo: storageSetting.sidebarLogo === undefined ? sidebarLogo : storageSetting.sidebarLogo,
-  dynamicTitle: storageSetting.dynamicTitle === undefined ? dynamicTitle : storageSetting.dynamicTitle
-}
-const mutations = {
-  CHANGE_SETTING: (state, { key, value }) => {
-    if (state.hasOwnProperty(key)) {
-      state[key] = value
-    }
-  }
-}
-
-const actions = {
-  // 淇敼甯冨眬璁剧疆
-  changeSetting({ commit }, data) {
-    commit('CHANGE_SETTING', data)
-  },
-  // 璁剧疆缃戦〉鏍囬
-  setTitle({ commit }, title) {
-    state.title = title
-    useDynamicTitle();
-  }
-}
-
-export default {
-  namespaced: true,
-  state,
-  mutations,
-  actions
-}
-
+import defaultSettings from "@/settings";
+import { useColorMode, usePreferredDark } from "@vueuse/core";
+import { useDynamicTitle } from "@/utils/dynamicTitle";
+
+const preferredDark = usePreferredDark();
+const colorMode = useColorMode({
+  emitAuto: true,
+});
+
+const {
+  sideTheme,
+  showSettings,
+  topNav,
+  tagsView,
+  fixedHeader,
+  sidebarLogo,
+  dynamicTitle,
+  darkMode,
+} = defaultSettings;
+
+const storageSetting = JSON.parse(localStorage.getItem("layout-setting") || "{}");
+const defaultDarkMode = darkMode || "auto";
+const initialDarkMode = storageSetting.darkMode || defaultDarkMode;
+colorMode.value = initialDarkMode;
+const getIsDark = (mode) => mode === "dark" || (mode === "auto" && preferredDark.value);
+
+const useSettingsStore = defineStore("settings", () => {
+  const title = ref("");
+  const theme = ref(storageSetting.theme || "#002fa7");
+  const sideThemeValue = ref(storageSetting.sideTheme || sideTheme);
+  const showSettingsValue = ref(showSettings);
+  const topNavValue = ref(
+    storageSetting.topNav === undefined ? topNav : storageSetting.topNav
+  );
+  const tagsViewValue = ref(
+    storageSetting.tagsView === undefined ? tagsView : storageSetting.tagsView
+  );
+  const fixedHeaderValue = ref(
+    storageSetting.fixedHeader === undefined ? fixedHeader : storageSetting.fixedHeader
+  );
+  const sidebarLogoValue = ref(
+    storageSetting.sidebarLogo === undefined ? sidebarLogo : storageSetting.sidebarLogo
+  );
+  const dynamicTitleValue = ref(
+    storageSetting.dynamicTitle === undefined ? dynamicTitle : storageSetting.dynamicTitle
+  );
+  const darkModeValue = ref(initialDarkMode);
+  const isDark = computed(() => getIsDark(darkModeValue.value));
+
+  function changeSetting(data) {
+    const { key, value } = data;
+    const settingMap = {
+      title,
+      theme,
+      sideTheme: sideThemeValue,
+      showSettings: showSettingsValue,
+      topNav: topNavValue,
+      tagsView: tagsViewValue,
+      fixedHeader: fixedHeaderValue,
+      sidebarLogo: sidebarLogoValue,
+      dynamicTitle: dynamicTitleValue,
+      darkMode: darkModeValue,
+    };
+    if (Object.prototype.hasOwnProperty.call(settingMap, key)) {
+      settingMap[key].value = value;
+      if (key === "darkMode") {
+        colorMode.value = value;
+      }
+    }
+  }
+
+  function setTitle(value) {
+    title.value = value;
+    useDynamicTitle();
+  }
+
+  function setDarkMode(mode) {
+    darkModeValue.value = mode;
+    colorMode.value = mode;
+  }
+
+  function toggleTheme() {
+    setDarkMode(isDark.value ? "light" : "dark");
+  }
+
+  return {
+    title,
+    theme,
+    sideTheme: sideThemeValue,
+    showSettings: showSettingsValue,
+    topNav: topNavValue,
+    tagsView: tagsViewValue,
+    fixedHeader: fixedHeaderValue,
+    sidebarLogo: sidebarLogoValue,
+    dynamicTitle: dynamicTitleValue,
+    darkMode: darkModeValue,
+    isDark,
+    changeSetting,
+    setTitle,
+    setDarkMode,
+    toggleTheme,
+  };
+});
+
+export default useSettingsStore;

--
Gitblit v1.9.3