refactor: 移除polling-store,重构setting-store

This commit is contained in:
yangsy
2026-01-19 15:15:38 +08:00
parent b7b6b216fb
commit 6771abec31
29 changed files with 197 additions and 185 deletions

View File

@@ -1,6 +1,5 @@
export * from './alarm';
export * from './device';
export * from './polling';
export * from './setting';
export * from './station';
export * from './unread';

View File

@@ -1,36 +1,71 @@
import { NDM_SETTING_STORE_ID } from '@/constants';
import { useUserStore } from './user';
import { LINE_ALARMS_QUERY_KEY, LINE_DEVICES_QUERY_KEY, LINE_STATIONS_QUERY_KEY, NDM_SETTING_STORE_ID } from '@/constants';
import router from '@/router';
import { useQueryClient } from '@tanstack/vue-query';
import { darkTheme, lightTheme } from 'naive-ui';
import { defineStore } from 'pinia';
import { computed, ref, watch } from 'vue';
import { useUserStore } from './user';
import router from '@/router';
export const useSettingStore = defineStore(
NDM_SETTING_STORE_ID,
() => {
const darkThemeEnabled = ref(true);
const queryClient = useQueryClient();
// 主题设置
const darkMode = ref(true);
const themeMode = computed(() => {
return darkThemeEnabled.value ? darkTheme : lightTheme;
return darkMode.value ? darkTheme : lightTheme;
});
// 布局设置
const menuCollpased = ref(false);
const stationGridCols = ref(6);
const debugModeEnabled = ref(false);
const enableDebugMode = () => {
debugModeEnabled.value = true;
};
const disableDebugMode = () => {
debugModeEnabled.value = false;
};
// 调试模式
const debugMode = ref(false);
/* 数据设置 */
// 显示设备原始数据
const showDeviceRawData = ref(false);
/* 网络设置 */
// 轮询车站
const pollingStations = ref(true);
// 主动请求
const activeRequests = ref(true);
// 订阅消息
const subscribeMessages = ref(true);
// 模拟用户
const mockUser = ref(false);
/* 数据库设置 */
// 使用本地数据库
const useLocalDB = ref(false);
// 离线开发模式
// 控制 版本轮询 stomp连接 app-layout中的自动getUserInfo
const offlineDev = ref(false);
watch(offlineDev, (newValue, oldValue) => {
// 如果启用离线开发模式且当前未登录 自动填写token以绕过路由守卫并跳过登录页
watch(debugMode, (newValue, oldValue) => {
// 监听关闭调试模式
if (oldValue && !newValue) {
showDeviceRawData.value = false;
pollingStations.value = true;
activeRequests.value = true;
subscribeMessages.value = false;
mockUser.value = false;
}
});
watch(pollingStations, (newValue, oldValue) => {
// 监听关闭车站轮询
if (oldValue && !newValue) {
queryClient.cancelQueries({ queryKey: [LINE_STATIONS_QUERY_KEY] });
queryClient.cancelQueries({ queryKey: [LINE_DEVICES_QUERY_KEY] });
queryClient.cancelQueries({ queryKey: [LINE_ALARMS_QUERY_KEY] });
queryClient.invalidateQueries({ queryKey: [LINE_STATIONS_QUERY_KEY] });
queryClient.invalidateQueries({ queryKey: [LINE_DEVICES_QUERY_KEY] });
queryClient.invalidateQueries({ queryKey: [LINE_ALARMS_QUERY_KEY] });
}
});
watch(mockUser, (newValue, oldValue) => {
// 监听启用模拟用户
if (!oldValue && newValue) {
// 如果启当前未登录填写token以绕过路由守卫
const userStore = useUserStore();
if (!userStore.userLoginResult) {
userStore.userLoginResult = {
@@ -42,9 +77,11 @@ export const useSettingStore = defineStore(
expiration: '',
};
}
// 如果token为空填写token
if (!userStore.userLoginResult.token) {
userStore.userLoginResult.token = 'test';
}
// 如果用户信息为空,填写用户信息
if (!userStore.userInfo) {
userStore.userInfo = {
id: '2',
@@ -55,35 +92,42 @@ export const useSettingStore = defineStore(
tenantId: '1',
};
}
// 如果当前路由为登录页,跳转到首页
if (router.currentRoute.value.path === '/login') {
router.push({ path: '/' });
}
// 开启模拟用户时,也开启调试模式,但关闭其他的网络设置
debugMode.value = true;
pollingStations.value = false;
activeRequests.value = false;
subscribeMessages.value = false;
}
});
return {
darkThemeEnabled,
darkMode,
themeMode,
menuCollpased,
stationGridCols,
debugModeEnabled,
enableDebugMode,
disableDebugMode,
offlineDev,
debugMode,
showDeviceRawData,
pollingStations,
activeRequests,
subscribeMessages,
mockUser,
useLocalDB,
};
},
{
persist: [
{
omit: ['debugModeEnabled'],
omit: ['showDeviceRawData'],
storage: window.localStorage,
},
{
pick: ['debugModeEnabled'],
pick: ['showDeviceRawData'],
storage: window.sessionStorage,
},
],