mirror of
https://gitee.com/niucloud-team/niucloud-admin.git
synced 2025-12-26 08:30:17 +00:00
170 lines
4.3 KiB
TypeScript
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
|
|
}
|
|
}
|
|
}
|
|
} |