2018-01-14 22:51:12 +08:00
|
|
|
import Vue from 'vue'
|
|
|
|
|
import VueRouter from 'vue-router'
|
2018-01-27 10:25:59 +08:00
|
|
|
import Cookies from 'js-cookie'
|
2018-01-14 22:51:12 +08:00
|
|
|
|
2018-06-16 19:12:54 +08:00
|
|
|
const meta = { requiresAuth: true }
|
|
|
|
|
|
2018-06-05 16:21:06 +08:00
|
|
|
Vue.use(VueRouter)
|
2018-06-05 15:33:21 +08:00
|
|
|
|
2018-06-05 16:21:06 +08:00
|
|
|
const routes = [
|
|
|
|
|
// 首页
|
|
|
|
|
{
|
|
|
|
|
path: '/',
|
|
|
|
|
redirect: { name: 'index' },
|
2018-06-10 08:58:44 +08:00
|
|
|
component: () => import('@/components/core/d2-layout-main/index.vue'),
|
2018-06-05 16:21:06 +08:00
|
|
|
children: [
|
|
|
|
|
{
|
|
|
|
|
path: 'index',
|
|
|
|
|
name: 'index',
|
2018-06-16 19:12:54 +08:00
|
|
|
meta,
|
2018-06-06 23:00:11 +08:00
|
|
|
component: () => import('@/pages/core/index/index.vue')
|
2018-06-05 16:21:06 +08:00
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
2018-06-08 23:52:13 +08:00
|
|
|
{
|
2018-06-17 07:33:45 +08:00
|
|
|
path: '/demo/business',
|
|
|
|
|
name: 'demo-business',
|
2018-06-16 19:12:54 +08:00
|
|
|
meta,
|
2018-06-17 07:33:45 +08:00
|
|
|
redirect: { name: 'demo-business-index' },
|
2018-06-10 08:58:44 +08:00
|
|
|
component: () => import('@/components/core/d2-layout-main/index.vue'),
|
2018-06-09 20:00:01 +08:00
|
|
|
children: (pre => [
|
2018-06-17 07:33:45 +08:00
|
|
|
{ path: 'index', name: `${pre}index`, component: () => import('@/pages/demo/business/index/index.vue'), meta }
|
|
|
|
|
])('demo-business-')
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: '/demo/chart',
|
|
|
|
|
name: 'demo-chart',
|
|
|
|
|
meta,
|
|
|
|
|
redirect: { name: 'demo-chart-index' },
|
|
|
|
|
component: () => import('@/components/core/d2-layout-main/index.vue'),
|
|
|
|
|
children: (pre => [
|
|
|
|
|
{ path: 'all', name: `${pre}all`, component: () => import('@/pages/demo/chart/all/index.vue'), meta },
|
|
|
|
|
{ path: 'demo/areaBase', name: `${pre}demo-areaBase`, component: () => import('@/pages/demo/chart/demo/areaBase.vue'), meta },
|
|
|
|
|
{ path: 'demo/barBase', name: `${pre}demo-barBase`, component: () => import('@/pages/demo/chart/demo/barBase.vue'), meta },
|
|
|
|
|
{ path: 'demo/columnBase', name: `${pre}demo-columnBase`, component: () => import('@/pages/demo/chart/demo/columnBase.vue'), meta },
|
|
|
|
|
{ path: 'demo/lineBase', name: `${pre}demo-lineBase`, component: () => import('@/pages/demo/chart/demo/lineBase.vue'), meta },
|
|
|
|
|
{ path: 'demo/lineStep', name: `${pre}demo-lineStep`, component: () => import('@/pages/demo/chart/demo/lineStep.vue'), meta },
|
|
|
|
|
{ path: 'demo/nightingaleRoseBase', name: `${pre}demo-nightingaleRoseBase`, component: () => import('@/pages/demo/chart/demo/nightingaleRoseBase.vue'), meta },
|
|
|
|
|
{ path: 'demo/PieBase', name: `${pre}demo-PieBase`, component: () => import('@/pages/demo/chart/demo/PieBase.vue'), meta },
|
|
|
|
|
{ path: 'demo/radarBase', name: `${pre}demo-radarBase`, component: () => import('@/pages/demo/chart/demo/radarBase.vue'), meta },
|
|
|
|
|
{ path: 'dynamicSize', name: `${pre}dynamicSize`, component: () => import('@/pages/demo/chart/dynamicSize/index.vue'), meta },
|
|
|
|
|
{ path: 'index', name: `${pre}index`, component: () => import('@/pages/demo/chart/index/index.vue'), meta }
|
|
|
|
|
])('demo-chart-')
|
2018-06-08 23:52:13 +08:00
|
|
|
},
|
2018-06-05 16:21:06 +08:00
|
|
|
{
|
|
|
|
|
path: '/demo/plugins',
|
|
|
|
|
name: 'demo-plugins',
|
2018-06-16 19:12:54 +08:00
|
|
|
meta,
|
2018-06-05 16:21:06 +08:00
|
|
|
redirect: { name: 'demo-plugins-index' },
|
2018-06-10 08:58:44 +08:00
|
|
|
component: () => import('@/components/core/d2-layout-main/index.vue'),
|
2018-06-09 20:00:01 +08:00
|
|
|
children: (pre => [
|
2018-06-16 19:12:54 +08:00
|
|
|
{ path: 'build', name: `${pre}build`, component: () => import('@/pages/demo/plugins/build/index.vue'), meta },
|
|
|
|
|
{ path: 'clipboard-polyfill', name: `${pre}clipboard-polyfill`, component: () => import('@/pages/demo/plugins/clipboard-polyfill/index.vue'), meta },
|
|
|
|
|
{ path: 'day', name: `${pre}day`, component: () => import('@/pages/demo/plugins/day/index.vue'), meta },
|
|
|
|
|
{ path: 'export/table', name: `${pre}export-table`, component: () => import('@/pages/demo/plugins/export/table.vue'), meta },
|
|
|
|
|
{ path: 'export/txt', name: `${pre}export-txt`, component: () => import('@/pages/demo/plugins/export/txt.vue'), meta },
|
|
|
|
|
{ path: 'i18n/demo1', name: `${pre}i18n-demo1`, component: () => import('@/pages/demo/plugins/i18n/demo1.vue'), meta },
|
|
|
|
|
{ path: 'i18n/demo2', name: `${pre}i18n-demo2`, component: () => import('@/pages/demo/plugins/i18n/demo2.vue'), meta },
|
|
|
|
|
{ path: 'import/csv', name: `${pre}import-csv`, component: () => import('@/pages/demo/plugins/import/csv.vue'), meta },
|
|
|
|
|
{ path: 'import/xlsx', name: `${pre}import-xlsx`, component: () => import('@/pages/demo/plugins/import/xlsx.vue'), meta },
|
|
|
|
|
{ path: 'index', name: `${pre}index`, component: () => import('@/pages/demo/plugins/index/index.vue'), meta },
|
|
|
|
|
{ path: 'js-cookie', name: `${pre}js-cookie`, component: () => import('@/pages/demo/plugins/js-cookie/index.vue'), meta },
|
|
|
|
|
{ path: 'mock/ajax', name: `${pre}mock-ajax`, component: () => import('@/pages/demo/plugins/mock/ajax.vue'), meta },
|
|
|
|
|
{ path: 'mock/dpd', name: `${pre}mock-dpd`, component: () => import('@/pages/demo/plugins/mock/dpd.vue'), meta },
|
|
|
|
|
{ path: 'mock/dtd', name: `${pre}mock-dtd`, component: () => import('@/pages/demo/plugins/mock/dtd.vue'), meta }
|
2018-06-06 23:00:11 +08:00
|
|
|
])('demo-plugins-')
|
2018-06-05 16:21:06 +08:00
|
|
|
},
|
2018-06-09 20:00:01 +08:00
|
|
|
{
|
2018-06-17 07:33:45 +08:00
|
|
|
path: '/demo/components',
|
|
|
|
|
name: 'demo-components',
|
2018-06-16 19:12:54 +08:00
|
|
|
meta,
|
2018-06-17 07:33:45 +08:00
|
|
|
redirect: { name: 'demo-components-index' },
|
2018-06-10 08:58:44 +08:00
|
|
|
component: () => import('@/components/core/d2-layout-main/index.vue'),
|
2018-06-09 20:35:03 +08:00
|
|
|
children: (pre => [
|
2018-06-17 07:33:45 +08:00
|
|
|
{ path: 'bigdata-table', name: `${pre}bigdata-table`, component: () => import('@/pages/demo/components/bigdata-table/index.vue'), meta },
|
|
|
|
|
{ path: 'container/full', name: `${pre}container-full`, component: () => import('@/pages/demo/components/container/full.vue'), meta },
|
|
|
|
|
{ path: 'container/ghost', name: `${pre}container-ghost`, component: () => import('@/pages/demo/components/container/ghost.vue'), meta },
|
|
|
|
|
{ path: 'container/card', name: `${pre}container-card`, component: () => import('@/pages/demo/components/container/card.vue'), meta },
|
|
|
|
|
{ path: 'countup', name: `${pre}countup`, component: () => import('@/pages/demo/components/countup/index.vue'), meta },
|
|
|
|
|
{ path: 'editor-quill', name: `${pre}editor-quill`, component: () => import('@/pages/demo/components/editor-quill/index.vue'), meta },
|
|
|
|
|
{ path: 'editor-simpleMDE', name: `${pre}editor-simpleMDE`, component: () => import('@/pages/demo/components/editor-simpleMDE/index.vue'), meta },
|
|
|
|
|
{ path: 'highlight', name: `${pre}highlight`, component: () => import('@/pages/demo/components/highlight/index.vue'), meta },
|
|
|
|
|
{ path: 'icon/icon', name: `${pre}icon-icon`, component: () => import('@/pages/demo/components/icon/icon.vue'), meta },
|
|
|
|
|
{ path: 'icon/list', name: `${pre}icon-list`, component: () => import('@/pages/demo/components/icon/list.vue'), meta },
|
|
|
|
|
{ path: 'icon/select', name: `${pre}icon-select`, component: () => import('@/pages/demo/components/icon/select.vue'), meta },
|
|
|
|
|
{ path: 'icon/svg', name: `${pre}icon-svg`, component: () => import('@/pages/demo/components/icon/svg.vue'), meta },
|
|
|
|
|
{ path: 'index', name: `${pre}index`, component: () => import('@/pages/demo/components/index/index.vue'), meta },
|
|
|
|
|
{ path: 'layout/grid', name: `${pre}layout-grid`, component: () => import('@/pages/demo/components/layout/grid.vue'), meta },
|
|
|
|
|
{ path: 'layout/splitpane', name: `${pre}layout-splitpane`, component: () => import('@/pages/demo/components/layout/splitpane.vue'), meta },
|
|
|
|
|
{ path: 'markdown/source', name: `${pre}markdown-source`, component: () => import('@/pages/demo/components/markdown/source.vue'), meta },
|
|
|
|
|
{ path: 'markdown/url', name: `${pre}markdown-url`, component: () => import('@/pages/demo/components/markdown/url.vue'), meta },
|
|
|
|
|
{ path: 'scrollbar', name: `${pre}scrollbar`, component: () => import('@/pages/demo/components/scrollbar/index.vue'), meta }
|
|
|
|
|
])('demo-components-')
|
2018-06-09 20:35:03 +08:00
|
|
|
},
|
2018-06-17 07:49:23 +08:00
|
|
|
{
|
|
|
|
|
path: '/demo/element',
|
|
|
|
|
name: 'demo-element',
|
|
|
|
|
meta,
|
|
|
|
|
redirect: { name: 'demo-element-index' },
|
|
|
|
|
component: () => import('@/components/core/d2-layout-main/index.vue'),
|
|
|
|
|
children: (pre => [
|
2018-06-17 08:18:58 +08:00
|
|
|
{ path: 'basic-layout', name: `${pre}basic-layout`, component: () => import('@/pages/demo/element/basic-layout/index.vue'), meta },
|
|
|
|
|
{ path: 'basic-container', name: `${pre}basic-container`, component: () => import('@/pages/demo/element/basic-container/index.vue'), meta },
|
2018-06-17 08:35:38 +08:00
|
|
|
{ path: 'basic-color', name: `${pre}basic-color`, component: () => import('@/pages/demo/element/basic-color/index.vue'), meta },
|
2018-06-17 21:42:42 +08:00
|
|
|
{ path: 'basic-button', name: `${pre}basic-button`, component: () => import('@/pages/demo/element/basic-button/index.vue'), meta },
|
2018-06-17 07:49:23 +08:00
|
|
|
{ path: 'index', name: `${pre}index`, component: () => import('@/pages/demo/element/index/index.vue'), meta }
|
|
|
|
|
])('demo-element-')
|
|
|
|
|
},
|
2018-06-05 16:21:06 +08:00
|
|
|
// 登陆
|
|
|
|
|
{
|
|
|
|
|
path: '/login',
|
|
|
|
|
name: 'login',
|
2018-06-06 23:00:11 +08:00
|
|
|
component: () => import('@/pages/core/login/index.vue')
|
2018-06-05 16:21:06 +08:00
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
|
2018-06-06 22:42:53 +08:00
|
|
|
let router = new VueRouter({ routes })
|
2018-01-27 10:25:59 +08:00
|
|
|
|
|
|
|
|
router.beforeEach((to, from, next) => {
|
2018-06-16 19:19:08 +08:00
|
|
|
// 验证当前路由所有的匹配中是否需要有登陆验证的
|
|
|
|
|
if (to.matched.some(r => r.meta.requiresAuth)) {
|
2018-03-21 21:59:10 +08:00
|
|
|
// 这里暂时将cookie里是否存有token作为验证是否登陆的条件
|
|
|
|
|
// 请根据自身业务需要修改
|
2018-01-27 10:25:59 +08:00
|
|
|
if (Cookies.get('token')) {
|
|
|
|
|
next()
|
|
|
|
|
} else {
|
|
|
|
|
// 没有登陆的时候跳转到登陆界面
|
|
|
|
|
next({
|
|
|
|
|
name: 'login'
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
// 不需要身份校验 直接通过
|
|
|
|
|
next()
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
export default router
|