2022-07-18 19:06:37 +08:00
|
|
|
|
import { defineStore } from 'pinia'
|
|
|
|
|
import { store } from '../index'
|
|
|
|
|
import { cloneDeep } from 'lodash-es'
|
|
|
|
|
import remainingRouter from '@/router/modules/remaining'
|
2022-08-03 12:38:58 +08:00
|
|
|
|
import { generateRoute, flatMultiLevelRoutes } from '@/utils/routerHelper'
|
|
|
|
|
import { getAsyncRoutesApi } from '@/api/login'
|
|
|
|
|
import { useCache } from '@/hooks/web/useCache'
|
|
|
|
|
|
|
|
|
|
const { wsCache } = useCache()
|
2022-07-18 19:06:37 +08:00
|
|
|
|
|
|
|
|
|
export interface PermissionState {
|
|
|
|
|
routers: AppRouteRecordRaw[]
|
|
|
|
|
addRouters: AppRouteRecordRaw[]
|
|
|
|
|
menuTabRouters: AppRouteRecordRaw[]
|
|
|
|
|
}
|
|
|
|
|
|
2022-10-08 18:51:50 +08:00
|
|
|
|
export const usePermissionStore = defineStore('permission', {
|
2022-07-18 19:06:37 +08:00
|
|
|
|
state: (): PermissionState => ({
|
|
|
|
|
routers: [],
|
|
|
|
|
addRouters: [],
|
|
|
|
|
menuTabRouters: []
|
|
|
|
|
}),
|
|
|
|
|
getters: {
|
|
|
|
|
getRouters(): AppRouteRecordRaw[] {
|
|
|
|
|
return this.routers
|
|
|
|
|
},
|
|
|
|
|
getAddRouters(): AppRouteRecordRaw[] {
|
|
|
|
|
return flatMultiLevelRoutes(cloneDeep(this.addRouters))
|
|
|
|
|
},
|
|
|
|
|
getMenuTabRouters(): AppRouteRecordRaw[] {
|
|
|
|
|
return this.menuTabRouters
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
actions: {
|
2022-08-03 12:38:58 +08:00
|
|
|
|
async generateRoutes(): Promise<unknown> {
|
|
|
|
|
return new Promise<void>(async (resolve) => {
|
|
|
|
|
let res: AppCustomRouteRecordRaw[]
|
|
|
|
|
if (wsCache.get('roleRouters')) {
|
|
|
|
|
res = wsCache.get('roleRouters') as AppCustomRouteRecordRaw[]
|
|
|
|
|
} else {
|
|
|
|
|
res = await getAsyncRoutesApi()
|
|
|
|
|
wsCache.set('roleRouters', res)
|
|
|
|
|
}
|
|
|
|
|
const routerMap: AppRouteRecordRaw[] = generateRoute(res as AppCustomRouteRecordRaw[])
|
2022-07-18 19:06:37 +08:00
|
|
|
|
// 动态路由,404一定要放到最后面
|
|
|
|
|
this.addRouters = routerMap.concat([
|
|
|
|
|
{
|
|
|
|
|
path: '/:path(.*)*',
|
|
|
|
|
redirect: '/404',
|
|
|
|
|
name: '404Page',
|
|
|
|
|
meta: {
|
|
|
|
|
hidden: true,
|
|
|
|
|
breadcrumb: false
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
])
|
|
|
|
|
// 渲染菜单的所有路由
|
|
|
|
|
this.routers = cloneDeep(remainingRouter).concat(routerMap)
|
|
|
|
|
resolve()
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
setMenuTabRouters(routers: AppRouteRecordRaw[]): void {
|
|
|
|
|
this.menuTabRouters = routers
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
export const usePermissionStoreWithOut = () => {
|
|
|
|
|
return usePermissionStore(store)
|
|
|
|
|
}
|