| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378 |
- import Vue from 'vue'
- import Router from 'vue-router'
- Vue.use(Router)
- /* Layout */
- import Layout from '@/layout'
- /* Router Modules */
- //import componentsRouter from './modules/components'
- /**
- * Note: sub-menu only appear when route children.length >= 1
- * Detail see: https://panjiachen.github.io/vue-element-admin-site/guide/essentials/router-and-nav.html
- *
- * hidden: true if set true, item will not show in the sidebar(default is false)
- * alwaysShow: true if set true, will always show the root menu
- * if not set alwaysShow, when item has more than one children route,
- * it will becomes nested mode, otherwise not show the root menu
- * redirect: noRedirect if set noRedirect will no redirect in the breadcrumb
- * name:'router-name' the name is used by <keep-alive> (must set!!!)
- * meta : {
- roles: ['admin','editor'] control the page roles (you can set multiple roles)
- title: 'title' the name show in sidebar and breadcrumb (recommend set)
- icon: 'svg-name' the icon show in the sidebar
- noCache: true if set true, the page will no be cached(default is false)
- affix: true if set true, the tag will affix in the tags-view
- breadcrumb: false if set false, the item will hidden in breadcrumb(default is true)
- activeMenu: '/example/list' if set path, the sidebar will highlight the path you set
- }
- */
- /**
- * constantRoutes
- * a base page that does not have permission requirements
- * all roles can be accessed
- */
- export const constantRoutes = [{
- path: '/redirect',
- component: Layout,
- hidden: true,
- children: [{
- path: '/redirect/:path*',
- component: () => import('@/views/redirect/index')
- }]
- },
- {
- path: '/login',
- component: () => import('@/views/login/index'),
- hidden: true
- },
- {
- path: '/auth-redirect',
- component: () => import('@/views/login/auth-redirect'),
- hidden: true
- },
- {
- path: '/404',
- component: () => import('@/views/error-page/404'),
- hidden: true
- },
- {
- path: '/401',
- component: () => import('@/views/error-page/401'),
- hidden: true
- },
- {
- path: '/',
- component: Layout,
- redirect: '/dashboard',
- children: [{
- path: 'dashboard',
- component: () => import('@/views/dashboard/index'),
- name: 'Dashboard',
- meta: {
- title: 'dashboard',
- icon: 'dashboard',
- affix: true
- }
- }]
- },
- {
- path: '/profile',
- component: Layout,
- redirect: '/profile/index',
- hidden: true,
- children: [{
- path: 'index',
- component: () => import('@/views/profile/index'),
- name: 'Profile',
- meta: {
- title: 'profile',
- icon: 'user',
- noCache: true
- }
- }]
- }
- ]
- /**
- * asyncRoutes
- * the routes that need to be dynamically loaded based on user roles
- */
- // export const asyncRoutes = [{
- // path: '/saas',
- // component: Layout,
- // redirect: '/saas/tenant',
- // alwaysShow: true,
- // name: 'SAAS',
- // meta: {
- // title: 'SaaS',
- // icon: 'cloud',
- // roles: ['AbpTenantManagement.Tenants'],
- // },
- // children: [{
- // path: 'tenant',
- // component: () => import('@/views/tenant/index'),
- // name: 'Tenant',
- // meta: {
- // title: 'tenant',
- // roles: ['AbpTenantManagement.Tenants'],
- // icon: 'users'
- // }
- // }]
- // },
- // {
- // path: '/system',
- // component: Layout,
- // redirect: '/system/user',
- // alwaysShow: true,
- // name: 'SystemManagement',
- // meta: {
- // title: 'systemManagement',
- // icon: 'system'
- // },
- // children: [
- // {
- // path: 'menu',
- // component: () => import('@/views/menu/index'),
- // name: 'Menu',
- // meta: {
- // title: 'menu',
- // icon: 'menu'
- // }
- // },
- // {
- // path: 'user',
- // component: () => import('@/views/user/index'),
- // name: 'User',
- // meta: {
- // title: 'user',
- // roles: ['AbpIdentity.Users'],
- // icon: 'user'
- // }
- // },
- // {
- // path: 'role',
- // component: () => import('@/views/role/index'),
- // name: 'Role',
- // meta: {
- // title: 'role',
- // roles: ['AbpIdentity.Roles'],
- // icon: 'role'
- // }
- // },
- // {
- // path: 'org',
- // component: () => import('@/views/org/index'),
- // name: 'Organization',
- // meta: {
- // title: 'org',
- // roles: ['BaseService.Organization'],
- // icon: 'org'
- // }
- // },
- // {
- // path: 'dict',
- // component: () => import('@/views/dict/index'),
- // name: 'Dictionary',
- // meta: {
- // title: 'dict',
- // roles: ['BaseService.DataDictionary'],
- // icon: 'data'
- // }
- // },
- // {
- // path: 'job',
- // component: () => import('@/views/job/index'),
- // name: 'Job',
- // meta: {
- // title: 'job',
- // roles: ['BaseService.Job'],
- // icon: 'job'
- // }
- // },
- // {
- // path: 'log',
- // component: () => import('@/views/log/index'),
- // name: 'Log',
- // meta: {
- // title: 'log',
- // roles: ['BaseService.AuditLogging'],
- // icon: 'log'
- // }
- // },
- // ]
- // },
- // {
- // path: '/base',
- // component: Layout,
- // redirect: '/base/book',
- // alwaysShow: true,
- // name: 'BASE',
- // meta: {
- // title: 'base',
- // icon: 'base'
- // },
- // children: [{
- // path: 'book',
- // component: () => import('@/views/book/index'),
- // name: 'Book',
- // meta: {
- // title: 'book',
- // icon: 'book'
- // }
- // }]
- // },
- // {
- // path: '/tool',
- // component: Layout,
- // redirect: '/tool/form',
- // alwaysShow: true,
- // name: 'Tool',
- // meta: {
- // title: 'tool',
- // icon: 'tool',
- // roles: ['FormManagement.Form','FlowManagement.Flow','FormManagement.FormBuild','StorageManagement.File']
- // },
- // children: [{
- // path: 'form',
- // component: () => import('@/views/form/index'),
- // name: 'Forms',
- // meta: {
- // title: 'form',
- // roles: ['FormManagement.Form'],
- // icon: 'control'
- // }
- // },
- // // {
- // // path: 'dynamic',
- // // component: () => import('@/views/form/dynamic'),
- // // name: 'Dynamic',
- // // meta: {
- // // title: 'dynamic',
- // // icon: 'control'
- // // }
- // // },
- // {
- // path: 'formCreate',
- // component: () => import('@/views/form/create'),
- // name: 'FormCreate',
- // meta: {
- // roles: ['FormManagement.Form.Create'],
- // title: 'formCreate'
- // },
- // hidden: true
- // },
- // {
- // path: 'formEdit/:id',
- // component: () => import('@/views/form/edit'),
- // name: 'FormEdit',
- // meta: {
- // roles: ['FormManagement.Form.Update'],
- // title: 'formEdit'
- // },
- // hidden: true
- // },
- // {
- // path: 'flow',
- // component: () => import('@/views/flow-design/index'),
- // name: 'Flows',
- // meta: {
- // title: 'flows',
- // roles: ['FlowManagement.Flow'],
- // icon: 'flow'
- // },
- // },
- // {
- // path: 'flowDisplay/:id',
- // component: () => import('@/views/flow/display'),
- // name: 'FlowDisplay',
- // meta: {
- // title: 'flowDisplay',
- // roles: ['FlowManagement.Flow'],
- // },
- // hidden: true
- // },
- // {
- // path: 'flowCreate',
- // component: () => import('@/views/flow-design/create'),
- // name: 'FlowDesignCreate',
- // meta: {
- // roles: ['FlowManagement.Flow.Create'],
- // title: 'flowDesignCreate'
- // },
- // hidden: true
- // },
- // {
- // path: 'flowEdit/:id',
- // component: () => import('@/views/flow-design/edit'),
- // name: 'FlowDesignEdit',
- // meta: {
- // roles: ['FlowManagement.Flow.Update'],
- // title: 'flowDesignEdit'
- // },
- // hidden: true
- // },
- // {
- // path: 'build',
- // component: () => import('@/views/build/index'),
- // name: 'Builds',
- // meta: {
- // title: 'build',
- // roles: ['FormManagement.FormBuild'],
- // icon: 'code'
- // }
- // },
- // {
- // path: 'buildEdit/:id',
- // component: () => import('@/views/build/components/index'),
- // name: 'BuildEdit',
- // meta: {
- // roles: ['FormManagement.FormBuild.Update'],
- // title: 'buildEdit'
- // },
- // hidden: true
- // },
- // {
- // path:'storage',
- // component: () => import('@/views/storage/index'),
- // name: 'Storage',
- // meta: {
- // title: 'storage',
- // roles: ['StorageManagement.File'],
- // icon: 'storage'
- // },
- // }
- // ]
- // },
- // /** when your routing map is too long, you can split it into small modules **/
- // componentsRouter,
- // // 404 page must be placed at the end !!!
- // {
- // path: '*',
- // redirect: '/404',
- // hidden: true
- // }
- // ]
- const createRouter = () => new Router({
- // mode: 'history', // require service support
- scrollBehavior: () => ({
- y: 0
- }),
- routes: constantRoutes
- })
- const router = createRouter()
- // Detail see: https://github.com/vuejs/vue-router/issues/1234#issuecomment-357941465
- export function resetRouter() {
- const newRouter = createRouter()
- router.matcher = newRouter.matcher // reset router
- }
- export default router
|