refactor: 移除polling-store,重构setting-store
This commit is contained in:
@@ -1,6 +1,5 @@
|
||||
export * from './alarm';
|
||||
export * from './device';
|
||||
export * from './polling';
|
||||
export * from './setting';
|
||||
export * from './station';
|
||||
export * from './unread';
|
||||
|
||||
@@ -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,
|
||||
},
|
||||
],
|
||||
|
||||
Reference in New Issue
Block a user