870 lines
22 KiB
TypeScript
870 lines
22 KiB
TypeScript
import { RouteRecordRaw } from 'vue-router';
|
||
|
||
/**
|
||
* 路由meta对象参数说明
|
||
* meta: {
|
||
* title: 菜单栏及 tagsView 栏、菜单搜索名称(国际化)
|
||
* isLink: 是否超链接菜单,开启外链条件,`1、isLink:true 2、链接地址不为空`
|
||
* isHide: 是否隐藏此路由
|
||
* isKeepAlive: 是否缓存组件状态
|
||
* isAffix: 是否固定在 tagsView 栏上
|
||
* isIframe: 是否内嵌窗口,,开启条件,`1、isIframe:true 2、链接地址不为空`
|
||
* auth: 当前路由权限标识(多个请用逗号隔开),最后转成数组格式,用于与当前用户权限进行对比,控制路由显示、隐藏
|
||
* icon: 菜单、tagsView 图标,阿里:加 `iconfont xxx`,fontawesome:加 `fa xxx`
|
||
* }
|
||
*/
|
||
|
||
/**
|
||
* 定义动态路由
|
||
* @description 未开启 isRequestRoutes 为 true 时使用(前端控制路由),开启时第一个顶级 children 的路由将被替换成接口请求回来的路由数据
|
||
* @description 各字段请查看 `/@/views/system/menu/component/addMenu.vue 下的 ruleForm`
|
||
* @returns 返回路由菜单数据
|
||
*/
|
||
export const dynamicRoutes: Array<RouteRecordRaw> = [
|
||
{
|
||
path: '/',
|
||
name: '/',
|
||
component: () => import('/@/layout/index.vue'),
|
||
redirect: '/home',
|
||
meta: {
|
||
isKeepAlive: true,
|
||
},
|
||
children: [
|
||
{
|
||
path: '/home',
|
||
name: 'home',
|
||
component: () => import('/@/views/home/index.vue'),
|
||
meta: {
|
||
title: 'message.router.home',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: true,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-shouye',
|
||
},
|
||
},
|
||
{
|
||
path: '/system',
|
||
name: 'system',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
redirect: '/system/menu',
|
||
meta: {
|
||
title: 'message.router.system',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin'],
|
||
icon: 'iconfont icon-xitongshezhi',
|
||
},
|
||
children: [
|
||
{
|
||
path: '/system/menu',
|
||
name: 'systemMenu',
|
||
component: () => import('/@/views/system/menu/index.vue'),
|
||
meta: {
|
||
title: 'message.router.systemMenu',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
},
|
||
{
|
||
path: '/system/user',
|
||
name: 'systemUser',
|
||
component: () => import('/@/views/system/user/index.vue'),
|
||
meta: {
|
||
title: 'message.router.systemUser',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin'],
|
||
icon: 'iconfont icon-icon-',
|
||
},
|
||
},
|
||
],
|
||
},
|
||
|
||
{
|
||
path: '/limits',
|
||
name: 'limits',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
redirect: '/limits/frontEnd',
|
||
meta: {
|
||
title: 'message.router.limits',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-quanxian',
|
||
},
|
||
children: [
|
||
{
|
||
path: '/limits/frontEnd',
|
||
name: 'limitsFrontEnd',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
redirect: '/limits/frontEnd/page',
|
||
meta: {
|
||
title: 'message.router.limitsFrontEnd',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
},
|
||
children: [
|
||
{
|
||
path: '/limits/frontEnd/page',
|
||
name: 'limitsFrontEndPage',
|
||
component: () => import('/@/views/limits/frontEnd/page/index.vue'),
|
||
meta: {
|
||
title: 'message.router.limitsFrontEndPage',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
},
|
||
},
|
||
{
|
||
path: '/limits/frontEnd/btn',
|
||
name: 'limitsFrontEndBtn',
|
||
component: () => import('/@/views/limits/frontEnd/btn/index.vue'),
|
||
meta: {
|
||
title: 'message.router.limitsFrontEndBtn',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
},
|
||
},
|
||
],
|
||
},
|
||
{
|
||
path: '/limits/backEnd',
|
||
name: 'limitsBackEnd',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
meta: {
|
||
title: 'message.router.limitsBackEnd',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
},
|
||
children: [
|
||
{
|
||
path: '/limits/backEnd/page',
|
||
name: 'limitsBackEndEndPage',
|
||
component: () => import('/@/views/limits/backEnd/page/index.vue'),
|
||
meta: {
|
||
title: 'message.router.limitsBackEndEndPage',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
},
|
||
},
|
||
],
|
||
},
|
||
],
|
||
},
|
||
{
|
||
path: '/menu',
|
||
name: 'menu',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
redirect: '/menu/menu1',
|
||
meta: {
|
||
title: 'message.router.menu',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
children: [
|
||
{
|
||
path: '/menu/menu1',
|
||
name: 'menu1',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
redirect: '/menu/menu1/menu11',
|
||
meta: {
|
||
title: 'message.router.menu1',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
children: [
|
||
{
|
||
path: '/menu/menu1/menu11',
|
||
name: 'menu11',
|
||
component: () => import('/@/views/menu/menu1/menu11/index.vue'),
|
||
meta: {
|
||
title: 'message.router.menu11',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
},
|
||
{
|
||
path: '/menu/menu1/menu12',
|
||
name: 'menu12',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
redirect: '/menu/menu1/menu12/menu121',
|
||
meta: {
|
||
title: 'message.router.menu12',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
children: [
|
||
{
|
||
path: '/menu/menu1/menu12/menu121',
|
||
name: 'menu121',
|
||
component: () => import('/@/views/menu/menu1/menu12/menu121/index.vue'),
|
||
meta: {
|
||
title: 'message.router.menu121',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
},
|
||
{
|
||
path: '/menu/menu1/menu12/menu122',
|
||
name: 'menu122',
|
||
component: () => import('/@/views/menu/menu1/menu12/menu122/index.vue'),
|
||
meta: {
|
||
title: 'message.router.menu122',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
},
|
||
],
|
||
},
|
||
{
|
||
path: '/menu/menu1/menu13',
|
||
name: 'menu13',
|
||
component: () => import('/@/views/menu/menu1/menu13/index.vue'),
|
||
meta: {
|
||
title: 'message.router.menu13',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
},
|
||
],
|
||
},
|
||
{
|
||
path: '/menu/menu2',
|
||
name: 'menu2',
|
||
component: () => import('/@/views/menu/menu2/index.vue'),
|
||
meta: {
|
||
title: 'message.router.menu2',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caidan',
|
||
},
|
||
},
|
||
],
|
||
},
|
||
{
|
||
path: '/fun',
|
||
name: 'funIndex',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
redirect: '/fun/tagsView',
|
||
meta: {
|
||
title: 'message.router.funIndex',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-crew_feature',
|
||
},
|
||
children: [
|
||
{
|
||
path: '/fun/tagsView',
|
||
name: 'funTagsView',
|
||
component: () => import('/@/views/fun/tagsView/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funTagsView',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-thumb',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/countup',
|
||
name: 'funCountup',
|
||
component: () => import('/@/views/fun/countup/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funCountup',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-odometer',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/echartsTree',
|
||
name: 'funEchartsTree',
|
||
component: () => import('/@/views/fun/tree/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funEchartsTree',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-connection',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/selector',
|
||
name: 'funSelector',
|
||
component: () => import('/@/views/fun/selector/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funSelector',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-xuanzeqi',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/wangEditor',
|
||
name: 'funWangEditor',
|
||
component: () => import('/@/views/fun/wangEditor/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funWangEditor',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-fuwenbenkuang',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/cropper',
|
||
name: 'funCropper',
|
||
component: () => import('/@/views/fun/cropper/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funCropper',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-caijian',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/qrcode',
|
||
name: 'funQrcode',
|
||
component: () => import('/@/views/fun/qrcode/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funQrcode',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-ico',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/echartsMap',
|
||
name: 'funEchartsMap',
|
||
component: () => import('/@/views/fun/echartsMap/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funEchartsMap',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-ditu',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/printJs',
|
||
name: 'funPrintJs',
|
||
component: () => import('/@/views/fun/printJs/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funPrintJs',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-printer',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/clipboard',
|
||
name: 'funClipboard',
|
||
component: () => import('/@/views/fun/clipboard/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funClipboard',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-document-copy',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/screenShort',
|
||
name: 'funScreenShort',
|
||
component: () => import('/@/views/fun/screenShort/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funScreenShort',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-crop',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/gridLayout',
|
||
name: 'funGridLayout',
|
||
component: () => import('/@/views/fun/gridLayout/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funGridLayout',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-tuodong',
|
||
},
|
||
},
|
||
{
|
||
path: '/fun/splitpanes',
|
||
name: 'funSplitpanes',
|
||
component: () => import('/@/views/fun/splitpanes/index.vue'),
|
||
meta: {
|
||
title: 'message.router.funSplitpanes',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon--chaifenlie',
|
||
},
|
||
},
|
||
],
|
||
},
|
||
{
|
||
path: '/pages',
|
||
name: 'pagesIndex',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
redirect: '/pages/filtering',
|
||
meta: {
|
||
title: 'message.router.pagesIndex',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-fuzhiyemian',
|
||
},
|
||
children: [
|
||
{
|
||
path: '/pages/filtering',
|
||
name: 'pagesFiltering',
|
||
component: () => import('/@/views/pages/filtering/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesFiltering',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-sell',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/filteringDetails',
|
||
name: 'pagesFilteringDetails',
|
||
component: () => import('/@/views/pages/filtering/details.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesFilteringDetails',
|
||
isLink: '',
|
||
isHide: true,
|
||
isKeepAlive: false,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-s-order',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/filteringDetails1',
|
||
name: 'pagesFilteringDetails1',
|
||
component: () => import('/@/views/pages/filtering/details1.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesFilteringDetails1',
|
||
isLink: '',
|
||
isHide: true,
|
||
isKeepAlive: false,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-s-order',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/iocnfont',
|
||
name: 'pagesIocnfont',
|
||
component: () => import('/@/views/pages/iocnfont/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesIocnfont',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-present',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/element',
|
||
name: 'pagesElement',
|
||
component: () => import('/@/views/pages/element/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesElement',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-platform-eleme',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/awesome',
|
||
name: 'pagesAwesome',
|
||
component: () => import('/@/views/pages/awesome/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesAwesome',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'el-icon-set-up',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/cityLinkage',
|
||
name: 'pagesCityLinkage',
|
||
component: () => import('/@/views/pages/cityLinkage/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesCityLinkage',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-jiliandongxuanzeqi',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/formAdapt',
|
||
name: 'pagesFormAdapt',
|
||
component: () => import('/@/views/pages/formAdapt/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesFormAdapt',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-biaodan',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/listAdapt',
|
||
name: 'pagesListAdapt',
|
||
component: () => import('/@/views/pages/listAdapt/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesListAdapt',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-chazhaobiaodanliebiao',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/waterfall',
|
||
name: 'pagesWaterfall',
|
||
component: () => import('/@/views/pages/waterfall/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesWaterfall',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-zidingyibuju',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/steps',
|
||
name: 'pagesSteps',
|
||
component: () => import('/@/views/pages/steps/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesSteps',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-step',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/preview',
|
||
name: 'pagesPreview',
|
||
component: () => import('/@/views/pages/preview/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesPreview',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-15tupianyulan',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/waves',
|
||
name: 'pagesWaves',
|
||
component: () => import('/@/views/pages/waves/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesWaves',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-bolangneng',
|
||
},
|
||
},
|
||
{
|
||
path: '/pages/tree',
|
||
name: 'pagesTree',
|
||
component: () => import('/@/views/pages/tree/index.vue'),
|
||
meta: {
|
||
title: 'message.router.pagesTree',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-shuxingtu',
|
||
},
|
||
},
|
||
],
|
||
},
|
||
{
|
||
path: '/chart',
|
||
name: 'chartIndex',
|
||
component: () => import('/@/views/chart/index.vue'),
|
||
meta: {
|
||
title: 'message.router.chartIndex',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-ico_shuju',
|
||
},
|
||
},
|
||
{
|
||
path: '/personal',
|
||
name: 'personal',
|
||
component: () => import('/@/views/personal/index.vue'),
|
||
meta: {
|
||
title: 'message.router.personal',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-gerenzhongxin',
|
||
},
|
||
},
|
||
{
|
||
path: '/tools',
|
||
name: 'tools',
|
||
component: () => import('/@/views/tools/index.vue'),
|
||
meta: {
|
||
title: 'message.router.tools',
|
||
isLink: '',
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin', 'test'],
|
||
icon: 'iconfont icon-gongju',
|
||
},
|
||
},
|
||
{
|
||
path: '/link',
|
||
name: 'layoutLinkView',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
meta: {
|
||
title: 'message.router.layoutLinkView',
|
||
isLink: 'https://element-plus.gitee.io/#/zh-CN/component/installation',
|
||
isHide: false,
|
||
isKeepAlive: false,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
auth: ['admin'],
|
||
icon: 'iconfont icon-caozuo-wailian',
|
||
},
|
||
},
|
||
{
|
||
path: '/iframes',
|
||
name: 'layoutIfameView',
|
||
component: () => import('/@/layout/routerView/parent.vue'),
|
||
meta: {
|
||
title: 'message.router.layoutIfameView',
|
||
isLink: 'https://gitee.com/lyt-top/vue-next-admin',
|
||
isHide: false,
|
||
isKeepAlive: false,
|
||
isAffix: true,
|
||
isIframe: true,
|
||
auth: ['admin'],
|
||
icon: 'iconfont icon-neiqianshujuchucun',
|
||
},
|
||
},
|
||
],
|
||
},
|
||
];
|
||
|
||
/**
|
||
* 定义静态路由
|
||
* @description 前端控制直接改 dynamicRoutes 中的路由,后端控制不需要修改,请求接口路由数据时,会覆盖 dynamicRoutes 第一个顶级 children 的内容(全屏,不包含 layout 中的路由出口)
|
||
* @returns 返回路由菜单数据
|
||
*/
|
||
export const staticRoutes: Array<RouteRecordRaw> = [
|
||
{
|
||
path: '/login',
|
||
name: 'login',
|
||
component: () => import('/@/views/login/index.vue'),
|
||
meta: {
|
||
title: '登陆',
|
||
},
|
||
},
|
||
{
|
||
path: '/404',
|
||
name: 'notFound',
|
||
component: () => import('/@/views/error/404.vue'),
|
||
meta: {
|
||
title: '找不到此页面',
|
||
},
|
||
},
|
||
{
|
||
path: '/401',
|
||
name: 'noPower',
|
||
component: () => import('/@/views/error/401.vue'),
|
||
meta: {
|
||
title: '没有权限',
|
||
},
|
||
},
|
||
];
|