import { Route } from './index';
|
import Layout from '@/layout/MainLayout/Layout.vue';
|
import { parse } from 'path-to-regexp';
|
|
const modulesRoutes = import.meta.glob([
|
'/src/views/**/*.{vue,tsx}',
|
'!/src/views/**/components/**/*.{vue,tsx}',
|
]);
|
|
// 过滤后端传来的动态路由 重新生成规范路由
|
export function addAsyncRoutes(arrRoutes: Route[]) {
|
if (!arrRoutes || !arrRoutes.length) return [];
|
|
arrRoutes.forEach((v) => {
|
if (v.redirect) {
|
v.component = Layout;
|
} else {
|
const pagePath = parse(v.path)[0];
|
|
v.component = modulesRoutes[`/src/views${pagePath}.vue`];
|
}
|
if (v.children) {
|
addAsyncRoutes(v.children);
|
}
|
});
|
|
return arrRoutes;
|
}
|
|
// 按照路由中meta下的rank等级升序来排序路由
|
export function ascending(arr: Route[]) {
|
return arr.sort((a, b) => {
|
return (a?.meta?.rank ?? 0) - b?.meta?.rank;
|
});
|
}
|