Compare commits

...

5 Commits

Author SHA1 Message Date
Pan
96032becf9 update version && release 2017-05-31 16:12:53 +08:00
Pan
9da96e2083 refine code 2017-05-31 16:06:41 +08:00
Pan
44166278ff update readme 2017-05-31 15:55:56 +08:00
Pan
327ed42e24 sidebar accept Nested Routes 2017-05-31 15:52:27 +08:00
Pan
677ef6dbe3 router Code Splitting use import replace require.ensure 2017-05-29 13:19:05 +08:00
11 changed files with 133 additions and 99 deletions

View File

@@ -50,7 +50,7 @@ Join the group on QQ 591724180.
- Multi-environments distribution - Multi-environments distribution
- Dashboard - Dashboard
- Two-factor authentication - Two-factor authentication
- Collapsing sidebar - Collapsing sidebar (support nested routes)
- Mock data - Mock data
## Development ## Development

View File

@@ -46,7 +46,7 @@
- 多环境发布 - 多环境发布
- dashboard - dashboard
- 二次登录 - 二次登录
- 动态侧边栏 - 动态侧边栏(支持多级路由)
- mock数据 - mock数据

View File

@@ -1,6 +1,6 @@
{ {
"name": "juicy", "name": "juicy",
"version": "1.0.0", "version": "1.0.1",
"description": "A Vue.js admin", "description": "A Vue.js admin",
"author": "Pan <panfree23@gmail.com>", "author": "Pan <panfree23@gmail.com>",
"license": "MIT", "license": "MIT",

View File

@@ -4,61 +4,62 @@ import Router from 'vue-router';
/* layout */ /* layout */
import Layout from '../views/layout/Layout'; import Layout from '../views/layout/Layout';
// dashboard
const dashboard = resolve => require(['../views/dashboard/index'], resolve);
/* error page*/
const Err404 = resolve => require(['../views/error/404'], resolve);
const Err401 = resolve => require(['../views/error/401'], resolve);
/* login */ /* login */
import Login from '../views/login/'; import Login from '../views/login/';
import authRedirect from '../views/login/authredirect'; const authRedirect = () => import('../views/login/authredirect');
import sendPWD from '../views/login/sendpwd'; const sendPWD = () => import('../views/login/sendpwd');
import reset from '../views/login/reset'; const reset = () => import('../views/login/reset');
/* dashboard */
const dashboard = () => import('../views/dashboard/index');
/* Introduction */ /* Introduction */
const Introduction = resolve => require(['../views/introduction/index'], resolve); const Introduction = () => import('../views/introduction/index');
/* components */ /* components */
const componentsIndex = resolve => require(['../views/components/index'], resolve); const componentsIndex = () => import('../views/components/index');
const Tinymce = resolve => require(['../views/components/tinymce'], resolve); const Tinymce = () => import('../views/components/tinymce');
const Markdown = resolve => require(['../views/components/markdown'], resolve); const Markdown = () => import('../views/components/markdown');
const JsonEditor = resolve => require(['../views/components/jsoneditor'], resolve); const JsonEditor = () => import('../views/components/jsoneditor');
const DndList = resolve => require(['../views/components/dndlist'], resolve); const DndList = () => import('../views/components/dndlist');
const AvatarUpload = resolve => require(['../views/components/avatarUpload'], resolve); const AvatarUpload = () => import('../views/components/avatarUpload');
const Dropzone = resolve => require(['../views/components/dropzone'], resolve); const Dropzone = () => import('../views/components/dropzone');
const Sticky = resolve => require(['../views/components/sticky'], resolve); const Sticky = () => import('../views/components/sticky');
const SplitPane = resolve => require(['../views/components/splitpane'], resolve); const SplitPane = () => import('../views/components/splitpane');
const CountTo = resolve => require(['../views/components/countTo'], resolve); const CountTo = () => import('../views/components/countTo');
const Mixin = resolve => require(['../views/components/mixin'], resolve); const Mixin = () => import('../views/components/mixin');
/* charts */ /* charts */
const chartIndex = resolve => require(['../views/charts/index'], resolve); const chartIndex = () => import('../views/charts/index');
const KeyboardChart = resolve => require(['../views/charts/keyboard'], resolve); const KeyboardChart = () => import('../views/charts/keyboard');
const KeyboardChart2 = resolve => require(['../views/charts/keyboard2'], resolve); const KeyboardChart2 = () => import('../views/charts/keyboard2');
const LineMarker = resolve => require(['../views/charts/line'], resolve); const LineMarker = () => import('../views/charts/line');
const MixChart = resolve => require(['../views/charts/mixchart'], resolve); const MixChart = () => import('../views/charts/mixchart');
/* error page */
const Err404 = () => import('../views/error/404');
const Err401 = () => import('../views/error/401');
/* error log */ /* error log */
const ErrorLog = resolve => require(['../views/errlog/index'], resolve); const ErrorLog = () => import('../views/errlog/index');
/* excel */ /* excel */
const ExcelDownload = resolve => require(['../views/excel/index'], resolve); const ExcelDownload = () => import('../views/excel/index');
/* theme */ /* theme */
const Theme = resolve => require(['../views/theme/index'], resolve); const Theme = () => import('../views/theme/index');
/* example*/ /* example*/
const DynamicTable = resolve => require(['../views/example/dynamictable'], resolve); const TableLayout = () => import('../views/example/table/index');
const Table = resolve => require(['../views/example/table'], resolve); const DynamicTable = () => import('../views/example/table/dynamictable');
const DragTable = resolve => require(['../views/example/dragTable'], resolve); const Table = () => import('../views/example/table/table');
const InlineEditTable = resolve => require(['../views/example/inlineEditTable'], resolve); const DragTable = () => import('../views/example/table/dragTable');
const Form1 = resolve => require(['../views/example/form1'], resolve); const InlineEditTable = () => import('../views/example/table/inlineEditTable');
const Form1 = () => import('../views/example/form1');
/* permission */ /* permission */
const Permission = resolve => require(['../views/permission/index'], resolve); const Permission = () => import('../views/permission/index');
Vue.use(Router); Vue.use(Router);
@@ -69,7 +70,7 @@ Vue.use(Router);
* redirect : if redirect:noredirect will not redirct in the levelbar * redirect : if redirect:noredirect will not redirct in the levelbar
* noDropdown : if noDropdown:true will not has submenu * noDropdown : if noDropdown:true will not has submenu
* meta : { role: ['admin'] } will control the page role * meta : { role: ['admin'] } will control the page role
*/ **/
export const constantRouterMap = [ export const constantRouterMap = [
{ path: '/login', component: Login, hidden: true }, { path: '/login', component: Login, hidden: true },
@@ -191,11 +192,19 @@ export const asyncRouterMap = [
redirect: 'noredirect', redirect: 'noredirect',
name: '综合实例', name: '综合实例',
icon: 'zonghe', icon: 'zonghe',
children: [
{
path: '/table',
component: TableLayout,
redirect: '/table/table',
name: 'table',
children: [ children: [
{ path: 'dynamictable', component: DynamicTable, name: '动态table' }, { path: 'dynamictable', component: DynamicTable, name: '动态table' },
{ path: 'dragtable', component: DragTable, name: '拖拽table' }, { path: 'dragtable', component: DragTable, name: '拖拽table' },
{ path: 'inline_edit_table', component: InlineEditTable, name: 'table内编辑' }, { path: 'inline_edit_table', component: InlineEditTable, name: 'table内编辑' },
{ path: 'table', component: Table, name: '综合table' }, { path: 'table', component: Table, name: '综合table' }
]
},
{ path: 'form1', component: Form1, name: '综合form1' } { path: 'form1', component: Form1, name: '综合form1' }
] ]
}, },

View File

@@ -0,0 +1,3 @@
<template>
<router-view></router-view>
</template>

View File

@@ -1,30 +1,14 @@
<template> <template>
<el-menu :unique-opened='true' mode="vertical" theme="dark" :default-active="$route.path"> <el-menu mode="vertical" theme="dark" :default-active="$route.path">
<template v-for="item in permission_routers" v-if="!item.hidden"> <sidebar-item :routes='permission_routers'></sidebar-item>
<el-submenu :index="item.name" v-if="!item.noDropdown">
<template slot="title">
<wscn-icon-svg :icon-class="item.icon||'wenzhang1'" /> {{item.name}}
</template>
<router-link v-for="child in item.children" :key="child.path" v-if="!child.hidden" class="title-link" :to="item.path+'/'+child.path">
<el-menu-item :index="item.path+'/'+child.path">
{{child.name}}
</el-menu-item>
</router-link>
</el-submenu>
<router-link v-if="item.noDropdown&&item.children.length>0" :to="item.path+'/'+item.children[0].path">
<el-menu-item :index="item.path+'/'+item.children[0].path">
<wscn-icon-svg :icon-class="item.icon||'geren1'" /> {{item.children[0].name}}
</el-menu-item>
</router-link>
</template>
</el-menu> </el-menu>
</template> </template>
<script> <script>
import { mapGetters } from 'vuex'; import { mapGetters } from 'vuex';
import SidebarItem from './SidebarItem';
export default { export default {
name: 'Sidebar', components:{SidebarItem},
computed: { computed: {
...mapGetters([ ...mapGetters([
'permission_routers' 'permission_routers'
@@ -32,16 +16,8 @@
} }
} }
</script> </script>
<style rel="stylesheet/scss" lang="scss" scoped> <style rel="stylesheet/scss" lang="scss" scoped>
.el-menu { .el-menu {
min-height: 100%; min-height: 100%;
} }
.wscn-icon {
margin-right: 10px;
}
.hideSidebar .title-link{
display: block;
text-indent: 10px;
}
</style> </style>

View File

@@ -0,0 +1,46 @@
<template>
<div>
<template v-for="item in routes">
<router-link v-if="!item.hidden&&item.noDropdown&&item.children.length>0" :to="item.path+'/'+item.children[0].path">
<el-menu-item :index="item.path+'/'+item.children[0].path">
<wscn-icon-svg v-if='item.icon' :icon-class="item.icon" /> {{item.children[0].name}}
</el-menu-item>
</router-link>
<el-submenu :index="item.name" v-if="!item.noDropdown&&!item.hidden">
<template slot="title">
<wscn-icon-svg v-if='item.icon' :icon-class="item.icon" /> {{item.name}}
</template>
<template v-for="child in item.children" v-if='!child.hidden'>
<sidebar-item class='menu-indent' v-if='child.children&&child.children.length>0' :routes='[child]'> </sidebar-item>
<router-link v-else class="menu-indent" :to="item.path+'/'+child.path">
<el-menu-item :index="item.path+'/'+child.path">
{{child.name}}
</el-menu-item>
</router-link>
</template>
</el-submenu>
</template>
</div>
</template>
<script>
export default {
name: 'SidebarItem',
props: {
routes: {
type: Array
}
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
.wscn-icon {
margin-right: 10px;
}
.hideSidebar .menu-indent{
display: block;
text-indent: 10px;
}
</style>