admin-vben/packages/effects/access/src/use-access.ts

54 lines
1.4 KiB
TypeScript
Raw Normal View History

import { computed } from 'vue';
import { preferences, updatePreferences } from '@vben/preferences';
2024-07-30 13:10:28 +00:00
import { useAccessStore, useUserStore } from '@vben/stores';
function useAccess() {
2024-07-30 13:10:28 +00:00
const accessStore = useAccessStore();
const userStore = useUserStore();
const accessMode = computed(() => {
return preferences.app.accessMode;
});
/**
*
* @description: Determine whether there is permissionThe role is judged by the user's role
* @param roles
*/
2024-07-18 13:31:34 +00:00
function hasAccessByRoles(roles: string[]) {
2024-07-30 13:10:28 +00:00
const userRoleSet = new Set(userStore.userRoles);
const intersection = roles.filter((item) => userRoleSet.has(item));
return intersection.length > 0;
}
/**
*
* @description: Determine whether there is permissionThe permission code is judged by the user's permission code
* @param codes
*/
2024-07-18 13:31:34 +00:00
function hasAccessByCodes(codes: string[]) {
2024-07-30 13:10:28 +00:00
const userCodesSet = new Set(accessStore.accessCodes);
const intersection = codes.filter((item) => userCodesSet.has(item));
return intersection.length > 0;
}
async function toggleAccessMode() {
updatePreferences({
app: {
accessMode:
preferences.app.accessMode === 'frontend' ? 'backend' : 'frontend',
},
});
}
return {
accessMode,
2024-07-18 13:31:34 +00:00
hasAccessByCodes,
hasAccessByRoles,
toggleAccessMode,
};
}
export { useAccess };