fix(router): loss directory route

修复"目录"路由丢失的问题

fix: #722
This commit is contained in:
无木 2021-06-08 15:06:04 +08:00
parent 448a4c2809
commit df8cd86051

View File

@ -2,7 +2,7 @@ import type { AppRouteModule, AppRouteRecordRaw } from '/@/router/types';
import type { Router, RouteRecordNormalized } from 'vue-router'; import type { Router, RouteRecordNormalized } from 'vue-router';
import { getParentLayout, LAYOUT } from '/@/router/constant'; import { getParentLayout, LAYOUT } from '/@/router/constant';
import { cloneDeep } from 'lodash-es'; import { cloneDeep, omit } from 'lodash-es';
import { warn } from '/@/utils/log'; import { warn } from '/@/utils/log';
import { createRouter, createWebHashHistory } from 'vue-router'; import { createRouter, createWebHashHistory } from 'vue-router';
@ -73,7 +73,7 @@ export function transformObjToRoute<T = AppRouteModule>(routeList: AppRouteModul
} }
route.children && asyncImportRoute(route.children); route.children && asyncImportRoute(route.children);
}); });
return (routeList as unknown) as T[]; return routeList as unknown as T[];
} }
/** /**
@ -95,7 +95,7 @@ export function flatMultiLevelRoutes(routeModules: AppRouteModule[]) {
function promoteRouteLevel(routeModule: AppRouteModule) { function promoteRouteLevel(routeModule: AppRouteModule) {
// Use vue-router to splice menus // Use vue-router to splice menus
let router: Router | null = createRouter({ let router: Router | null = createRouter({
routes: [(routeModule as unknown) as RouteRecordNormalized], routes: [routeModule as unknown as RouteRecordNormalized],
history: createWebHashHistory(), history: createWebHashHistory(),
}); });
@ -103,7 +103,7 @@ function promoteRouteLevel(routeModule: AppRouteModule) {
addToChildren(routes, routeModule.children || [], routeModule); addToChildren(routes, routeModule.children || [], routeModule);
router = null; router = null;
routeModule.children = routeModule.children?.filter((item) => !item.children?.length); routeModule.children = routeModule.children?.map((item) => omit(item, 'children'));
} }
// Add all sub-routes to the secondary route // Add all sub-routes to the secondary route
@ -120,7 +120,7 @@ function addToChildren(
} }
routeModule.children = routeModule.children || []; routeModule.children = routeModule.children || [];
if (!routeModule.children.find((item) => item.name === route.name)) { if (!routeModule.children.find((item) => item.name === route.name)) {
routeModule.children?.push((route as unknown) as AppRouteModule); routeModule.children?.push(route as unknown as AppRouteModule);
} }
if (child.children?.length) { if (child.children?.length) {
addToChildren(routes, child.children, routeModule); addToChildren(routes, child.children, routeModule);