refactor: 抽离登录校验查询

This commit is contained in:
yangsy
2025-12-17 16:19:33 +08:00
parent a90e788dc5
commit c8274a8c6b
5 changed files with 35 additions and 19 deletions

View File

@@ -1,4 +1,5 @@
export * from './use-line-alarms-query';
export * from './use-line-devices-query';
export * from './use-line-stations-query';
export * from './use-verify-user-query';
export * from './use-version-check-query';

View File

@@ -0,0 +1,28 @@
import { verifyApi } from '@/apis';
import { VERIFY_USER_QUERY_KEY } from '@/constants';
import { useSettingStore } from '@/stores';
import { useQuery, useQueryClient } from '@tanstack/vue-query';
import { storeToRefs } from 'pinia';
import { computed, watch } from 'vue';
export const useVerifyUserQuery = () => {
const queryClient = useQueryClient();
const settingStore = useSettingStore();
const { offlineDev } = storeToRefs(settingStore);
watch(offlineDev, (offline) => {
if (offline) {
queryClient.cancelQueries({ queryKey: [VERIFY_USER_QUERY_KEY] });
}
});
return useQuery({
queryKey: [VERIFY_USER_QUERY_KEY],
enabled: computed(() => !offlineDev.value),
refetchInterval: 10 * 1000,
queryFn: async ({ signal }) => {
await verifyApi({ signal });
return null;
},
});
};

View File

@@ -1,39 +1,24 @@
import { verifyApi, type VersionInfo } from '@/apis';
import { type VersionInfo } from '@/apis';
import { VERSION_CHECK_QUERY_KEY } from '@/constants';
import { useSettingStore, useUserStore } from '@/stores';
import { useQuery, useQueryClient } from '@tanstack/vue-query';
import { useQuery } from '@tanstack/vue-query';
import axios from 'axios';
import { useThemeVars } from 'naive-ui';
import { storeToRefs } from 'pinia';
import { computed, h, ref, watch } from 'vue';
import { h, ref, watch } from 'vue';
export const useVersionCheckQuery = () => {
const localVersionInfo = ref<VersionInfo>();
const showDialog = ref<boolean>(false);
const themeVars = useThemeVars();
const queryClient = useQueryClient();
const userStore = useUserStore();
const { userLoginResult } = storeToRefs(userStore);
const settingStore = useSettingStore();
const { offlineDev } = storeToRefs(settingStore);
const { data: remoteVersionInfo, dataUpdatedAt } = useQuery({
queryKey: [VERSION_CHECK_QUERY_KEY],
enabled: computed(() => !offlineDev.value),
refetchInterval: 10 * 1000,
queryFn: async ({ signal }) => {
if (!!userLoginResult.value?.token) await verifyApi({ signal });
const { data } = await axios.get<VersionInfo>(`/manifest.json?t=${Date.now()}`, { signal });
return data;
},
});
watch(offlineDev, (offline) => {
if (offline) {
queryClient.cancelQueries({ queryKey: [VERSION_CHECK_QUERY_KEY] });
}
});
watch(dataUpdatedAt, () => {
const newVersionInfo = remoteVersionInfo.value;
if (!newVersionInfo) return;