123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- import { store } from '/@/store/index.ts';
- import { Session } from '/@/utils/storage';
- import { NextLoading } from '/@/utils/loading';
- import { setAddRoute, setFilterMenuAndCacheTagsViewRoutes } from '/@/router/index';
- import { demoRoutes, dynamicRoutes } from '/@/router/route';
- import api from '/@/api/system';
- const layouModules: any = import.meta.glob('../layout/routerView/*.{vue,tsx}');
- const viewsModules: any = import.meta.glob('../views/**/*.{vue,tsx}');
- /**
- * 获取目录下的 .vue、.tsx 全部文件
- * @method import.meta.glob
- * @link 参考:https://cn.vitejs.dev/guide/features.html#json
- */
- const dynamicViewsModules: Record<string, Function> = Object.assign({}, { ...layouModules }, { ...viewsModules });
- /**
- * 后端控制路由:初始化方法,防止刷新时路由丢失
- * @method NextLoading 界面 loading 动画开始执行
- * @method store.dispatch('userInfos/setUserInfos') 触发初始化用户信息
- * @method store.dispatch('requestOldRoutes/setBackEndControlRoutes') 存储接口原始路由(未处理component),根据需求选择使用
- * @method setAddRoute 添加动态路由
- * @method setFilterMenuAndCacheTagsViewRoutes 设置递归过滤有权限的路由到 vuex routesList 中(已处理成多级嵌套路由)及缓存多级嵌套数组处理后的一维数组
- */
- export async function initBackEndControlRoutes() {
- // 界面 loading 动画开始执行
- if (window.nextLoading === undefined) NextLoading.start();
- // 无 token 停止执行下一步
- if (!Session.get('token')) return false;
- // 触发初始化用户信息
- store.dispatch('userInfos/setUserInfos');
- // store.dispatch('userInfos/setPermissions');
- let menuRoute = Session.get('userMenu')
- // let permissions = Session.get('permissions')
- if (!menuRoute) {
- await getBackEndControlRoutes(); // 获取路由
- menuRoute = Session.get('userMenu')
- }
- // 获取路由菜单数据
- // 存储接口原始路由(未处理component),根据需求选择使用
- store.dispatch('requestOldRoutes/setBackEndControlRoutes', JSON.parse(JSON.stringify(menuRoute)));
- // 处理路由(component),替换 dynamicRoutes(/@/router/route)第一个顶级 children 的路由
- dynamicRoutes[0].children?.push(...await backEndComponent(menuRoute), ...demoRoutes);
- // 添加动态路由
- await setAddRoute();
- // 设置递归过滤有权限的路由到 vuex routesList 中(已处理成多级嵌套路由)及缓存多级嵌套数组处理后的一维数组
- setFilterMenuAndCacheTagsViewRoutes();
- }
- /**
- * 请求后端路由菜单接口
- * @description isRequestRoutes 为 true,则开启后端控制路由
- * @returns 返回后端路由菜单数据
- */
- export async function getBackEndControlRoutes() {
- return api.login.currentUser().then((res: any) => {
- Session.set('userMenu', res || [])
- // Session.set('permissions',res.data.permissions)
- // store.dispatch('userInfos/setPermissions',res.data.permissions)
- })
- }
- /**
- * 重新请求后端路由菜单接口
- * @description 用于菜单管理界面刷新菜单(未进行测试)
- * @description 路径:/src/views/system/menu/component/addMenu.vue
- */
- export function setBackEndControlRefreshRoutes() {
- getBackEndControlRoutes();
- }
- /**
- * 后端路由 component 转换
- * @param routes 后端返回的路由表数组
- * @returns 返回处理成函数后的 component
- */
- export function backEndComponent(routes: any) {
- if (!routes) return;
- return routes.map((item: any) => {
- if (item.component) item.component = dynamicImport(dynamicViewsModules, item.component as string);
- item.children?.length && backEndComponent(item.children);
- // 将 meta 信息进行整理
- item.meta = {
- icon: item.icon,
- isAffix: item.isAffix,
- isHide: item.isHide,
- isIframe: item.isIframe,
- isKeepAlive: item.isKeepAlive,
- isLink: item.isLink,
- linkUrl: item.linkUrl,
- title: item.title,
- }
- return item;
- });
- }
- /**
- * 后端路由 component 转换函数
- * @param dynamicViewsModules 获取目录下的 .vue、.tsx 全部文件
- * @param component 当前要处理项 component
- * @returns 返回处理成函数后的 component
- */
- export function dynamicImport(dynamicViewsModules: Record<string, Function>, component: string) {
- const keys = Object.keys(dynamicViewsModules);
- const matchKeys = keys.filter((key) => {
- const k = key.replace(/..\/views|../, '');
- return k.startsWith(`${component}`) || k.startsWith(`/${component}`);
- });
- if (matchKeys?.length === 1) {
- const matchKey = matchKeys[0];
- return dynamicViewsModules[matchKey];
- }
- if (matchKeys?.length > 1) {
- return false;
- }
- }
|