feat: 定时更新用户权限

This commit is contained in:
yangsy
2026-01-13 13:19:34 +08:00
parent a17a947030
commit 5e84ffa6a2
5 changed files with 60 additions and 1 deletions

View File

@@ -1,4 +1,5 @@
export * from './alarm'; export * from './alarm';
export * from './device'; export * from './device';
export * from './permission';
export * from './query'; export * from './query';
export * from './stomp'; export * from './stomp';

View File

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

View File

@@ -0,0 +1,55 @@
import { pagePermissionApi } from '@/apis';
import { USER_PERMISSIONS_QUERY_KEY } from '@/constants';
import { PERMISSION_TYPE_NAMES } from '@/enums';
import { usePermissionStore, useSettingStore, useStationStore, useUserStore } from '@/stores';
import { useQuery, useQueryClient } from '@tanstack/vue-query';
import { storeToRefs } from 'pinia';
import { computed, watch } from 'vue';
export const useUserPermissionsQuery = () => {
const queryClient = useQueryClient();
const settingStore = useSettingStore();
const { offlineDev } = storeToRefs(settingStore);
const stationStore = useStationStore();
const { stations } = storeToRefs(stationStore);
const userStore = useUserStore();
const { userInfo } = storeToRefs(userStore);
const permissionStore = usePermissionStore();
watch(offlineDev, (offline) => {
if (offline) {
queryClient.cancelQueries({ queryKey: [USER_PERMISSIONS_QUERY_KEY] });
}
});
return useQuery({
queryKey: computed(() => [USER_PERMISSIONS_QUERY_KEY]),
enabled: computed(() => !offlineDev.value),
refetchInterval: 10 * 1000,
queryFn: async ({ signal }) => {
const { employeeId } = userInfo.value ?? {};
if (!employeeId) return null;
const { records } = await pagePermissionApi(
{
model: {
employeeId,
},
extra: {},
current: 1,
size: Object.keys(PERMISSION_TYPE_NAMES).length * stations.value.length,
sort: 'id',
order: 'ascending',
},
{
signal,
},
);
permissionStore.setPermRecords(records);
return null;
},
});
};

View File

@@ -1,5 +1,6 @@
export const LINE_ALARMS_QUERY_KEY = 'line-alarms'; export const LINE_ALARMS_QUERY_KEY = 'line-alarms';
export const LINE_DEVICES_QUERY_KEY = 'line-devices'; export const LINE_DEVICES_QUERY_KEY = 'line-devices';
export const LINE_STATIONS_QUERY_KEY = 'line-stations'; export const LINE_STATIONS_QUERY_KEY = 'line-stations';
export const USER_PERMISSIONS_QUERY_KEY = 'user-permissions';
export const VERIFY_USER_QUERY_KEY = 'verify-user'; export const VERIFY_USER_QUERY_KEY = 'verify-user';
export const VERSION_CHECK_QUERY_KEY = 'version-check'; export const VERSION_CHECK_QUERY_KEY = 'version-check';

View File

@@ -1,6 +1,6 @@
<script setup lang="ts"> <script setup lang="ts">
import { SettingsDrawer, SyncCameraResultModal } from '@/components'; import { SettingsDrawer, SyncCameraResultModal } from '@/components';
import { useLineStationsQuery, useStompClient, useVerifyUserQuery } from '@/composables'; import { useLineStationsQuery, useStompClient, useUserPermissionsQuery, useVerifyUserQuery } from '@/composables';
import { LINE_ALARMS_QUERY_KEY, LINE_DEVICES_QUERY_KEY, LINE_STATIONS_MUTATION_KEY, LINE_STATIONS_QUERY_KEY, STATION_ALARMS_MUTATION_KEY, STATION_DEVICES_MUTATION_KEY } from '@/constants'; import { LINE_ALARMS_QUERY_KEY, LINE_DEVICES_QUERY_KEY, LINE_STATIONS_MUTATION_KEY, LINE_STATIONS_QUERY_KEY, STATION_ALARMS_MUTATION_KEY, STATION_DEVICES_MUTATION_KEY } from '@/constants';
import { useAlarmStore, useSettingStore, useUserStore } from '@/stores'; import { useAlarmStore, useSettingStore, useUserStore } from '@/stores';
import { parseErrorFeedback } from '@/utils'; import { parseErrorFeedback } from '@/utils';
@@ -43,6 +43,7 @@ const { syncCameraResult, afterCheckSyncCameraResult } = useStompClient();
useVerifyUserQuery(); useVerifyUserQuery();
useLineStationsQuery(); useLineStationsQuery();
useUserPermissionsQuery();
// 全局loading状态依赖于轮询query的queryKey以及相关的mutationKey // 全局loading状态依赖于轮询query的queryKey以及相关的mutationKey
const queryingCount = useIsFetching({ const queryingCount = useIsFetching({