48 lines
1.3 KiB
TypeScript
48 lines
1.3 KiB
TypeScript
import type { Component } from 'vue';
|
|
import { EnumRoutePath } from '@/enum';
|
|
import type { RoutePathKey, CustomRoute } from '@/interface';
|
|
import { router } from '@/router';
|
|
|
|
/** 获取路由name map */
|
|
function getRouteNameMap() {
|
|
return new Map<RoutePathKey, RoutePathKey>((Object.keys(EnumRoutePath) as RoutePathKey[]).map(v => [v, v]));
|
|
}
|
|
|
|
/** 路由名称 */
|
|
export const ROUTE_NAME_MAP = getRouteNameMap();
|
|
|
|
/** 给需要缓存的页面组件设置名称 */
|
|
export function setRouterCacheName(component: Component, name?: string) {
|
|
if (name) {
|
|
Object.assign(component, { name });
|
|
}
|
|
}
|
|
|
|
/** 获取登录后的重定向地址 */
|
|
export function getLoginRedirectUrl() {
|
|
const path = router.currentRoute.value.fullPath as EnumRoutePath;
|
|
const redirectUrl = path === EnumRoutePath.root ? undefined : path;
|
|
return redirectUrl;
|
|
}
|
|
|
|
/**
|
|
* 设置单个路由
|
|
* @param route - 路由
|
|
* @param notFoundName - 404未找到的路由名称
|
|
* @param container - 路由容器
|
|
*/
|
|
export function setSingleRoute(container: Component, route: CustomRoute) {
|
|
const routeItem: CustomRoute = {
|
|
name: `${route.name as string}_`,
|
|
path: `${route.path}_`,
|
|
component: container,
|
|
redirect: { name: ROUTE_NAME_MAP.get('not-found') },
|
|
meta: {
|
|
isNotMenu: true
|
|
},
|
|
children: [route]
|
|
};
|
|
|
|
return routeItem;
|
|
}
|