2023-08-12 15:53:05 +08:00

170 lines
4.3 KiB
TypeScript

import { RouteRecordRaw, RouterView } from 'vue-router'
import Default from '@/layout/index.vue'
import Decorate from '@/layout/decorate/index.vue'
// 静态路由
export const STATIC_ROUTES: Array<RouteRecordRaw> = [
{
path: '/:pathMatch(.*)*',
component: () => import('@/views/error/404.vue')
}
]
// 免登录路由
export const NO_LOGIN_ROUTES: string[] = [
'/404'
]
// 根路由
export const ROOT_ROUTER: RouteRecordRaw = {
path: '/',
component: Default,
name: Symbol()
}
// 平台端根路由
export const ADMIN_ROUTE: RouteRecordRaw = {
path: '/admin',
name: Symbol('admin'),
children: [
{
path: '',
name: Symbol('adminRoot'),
component: Default
},
{
path: 'login',
component: () => import('@/views/login/index.vue')
},
{
path: 'user',
component: Default,
children: [
{
path: 'center',
meta: {
type: 1,
title: '个人中心'
},
component: () => import('@/views/index/personal.vue')
}
]
}
]
}
// 站点端路由
export const SITE_ROUTE: RouteRecordRaw = {
path: '/site',
name: Symbol('site'),
children: [
{
path: '',
name: Symbol('siteRoot'),
component: Default
},
{
path: 'login',
component: () => import('@/views/login/index.vue')
},
{
path: 'user',
component: Default,
children: [
{
path: 'center',
meta: {
type: 1,
title: '个人中心'
},
component: () => import('@/views/index/personal.vue')
}
]
}
]
}
// 装修路由
export const DECORATE_ROUTER: RouteRecordRaw = {
path: '/decorate',
component: Decorate,
name: Symbol('decorate'),
children: []
}
const modules = import.meta.glob('@/views/**/*.vue')
interface Route {
menu_name: string,
router_path: string,
view_path: string
menu_type: number,
icon?: {
name: string,
type: string
},
children?: [],
is_show: boolean,
app_type: string
}
/**
* 创建路由
* @param data
* @returns
*/
const createRoute = function (route: Route, parentRoute: RouteRecordRaw | null = null): RouteRecordRaw {
const record: RouteRecordRaw = {
path: parentRoute ? route.router_path : route.router_path != 'decorate' ? `/${route.app_type}/${route.router_path}` : `/${route.router_path}`,
name: parentRoute ? Symbol(`${parentRoute.path}/${route.router_path}`) : Symbol(`/${route.router_path}`),
meta: {
title: route.menu_name,
icon: route.icon,
type: route.menu_type,
show: route.is_show,
app: route.app_type,
view: route.view_path
}
}
if (route.menu_type == 0) {
record.component = parentRoute ? RouterView : () => Promise.resolve(Default)
if (!route.children) record.component = RouterView
} else {
record.component = modules[`/src/views/${route.view_path}.vue`]
}
return record
}
/**
* 格式化路由
* @param routes
* @returns
*/
export function formatRouters(routes: Route[], parentRoute: RouteRecordRaw | null = null) {
return routes.map((route) => {
const routeRecord = createRoute(route, parentRoute)
if (route.children != null && route.children && route.children.length) {
routeRecord.children = formatRouters(route.children, routeRecord)
}
return routeRecord
})
}
/**
* 获取首条有效路由
* @param routes
* @returns
*/
export function findFirstValidRoute(routes: RouteRecordRaw[]): string | undefined {
for (const route of routes) {
if (route.meta?.type == 1) {
return route.name as string
}
if (route.children) {
const name = findFirstValidRoute(route.children)
if (name) {
return name
}
}
}
}