import { RouteLocationNormalized, RouteRecordRaw } from 'vue-router'; import { useUserStore } from '@/store'; export default function usePermission() { const userStore = useUserStore(); return { accessRouter(route: RouteLocationNormalized | RouteRecordRaw) { return ( !route.meta?.requiresAuth || !route.meta?.roles || route.meta?.roles?.includes('*') || this.includeRole(route.meta?.roles, userStore.roles) ); }, includeRole(arr1: Array, arr2: Array) { const temp = arr1.filter((item) => { return arr2.includes(item); }); return !!temp.length; }, findFirstPermissionRoute(_routers: any, role = 'admin') { const cloneRouters = [..._routers]; while (cloneRouters.length) { const firstElement = cloneRouters.shift(); if ( firstElement?.meta?.roles?.find((el: string[]) => { return el.includes('*') || el.includes(role); }) ) return { name: firstElement.name }; if (firstElement?.children) { cloneRouters.push(...firstElement.children); } } return null; }, // You can add any rules you want }; }