chore: optimize the code of system layout; 🌟

master
chenghongxing 5 years ago
parent fd3c79493f
commit b78cf5c6e1
  1. 6
      src/layouts/PageLayout.vue
  2. 2
      src/layouts/tabs/TabsView.vue
  3. 5
      src/pages/exception/403.vue
  4. 8
      src/pages/exception/404.vue
  5. 5
      src/pages/exception/500.vue
  6. 215
      src/router/config.js
  7. 202
      src/router/index.js
  8. 10
      src/store/index.js
  9. 4
      src/store/modules/index.js

@ -1,6 +1,6 @@
<template> <template>
<div class="page-layout"> <div class="page-layout">
<page-header :breadcrumb="breadcrumb" :title="pageTitle" :logo="logo" :avatar="avatar"> <page-header :style="`margin-top: ${multiPage ? 0 : -24}px`" :breadcrumb="breadcrumb" :title="pageTitle" :logo="logo" :avatar="avatar">
<slot name="action" slot="action"></slot> <slot name="action" slot="action"></slot>
<slot slot="content" name="headerContent"></slot> <slot slot="content" name="headerContent"></slot>
<div slot="content" v-if="!this.$slots.headerContent && desc"> <div slot="content" v-if="!this.$slots.headerContent && desc">
@ -40,7 +40,7 @@ export default {
this.page = this.$route.meta.page this.page = this.$route.meta.page
}, },
computed: { computed: {
...mapState('setting', ['layout']), ...mapState('setting', ['layout', 'multiPage']),
pageTitle() { pageTitle() {
let pageTitle = this.page && this.page.title let pageTitle = this.page && this.page.title
return this.title || this.$t(pageTitle) || this.routeName return this.title || this.$t(pageTitle) || this.routeName
@ -79,7 +79,7 @@ export default {
<style lang="less"> <style lang="less">
.page-header{ .page-header{
margin: -24px -24px 0; margin: 0 -24px 0;
} }
.link{ .link{
/*margin-top: 16px;*/ /*margin-top: 16px;*/

@ -15,7 +15,7 @@
<span slot="tab" :pagekey="page.fullPath">{{pageName(page.path)}}</span> <span slot="tab" :pagekey="page.fullPath">{{pageName(page.path)}}</span>
</a-tab-pane> </a-tab-pane>
</a-tabs> </a-tabs>
<div class="tabs-view-content"> <div class="tabs-view-content" :style="`margin-top: ${multiPage ? -24 : 0}px`">
<page-toggle-transition :disabled="animate.disabled" :animate="animate.name" :direction="animate.direction"> <page-toggle-transition :disabled="animate.disabled" :animate="animate.name" :direction="animate.direction">
<keep-alive :exclude="dustbins" v-if="multiPage"> <keep-alive :exclude="dustbins" v-if="multiPage">
<router-view /> <router-view />

@ -1,5 +1,5 @@
<template> <template>
<exception-page :style="`margin-top: ${marginTop}px; min-height: ${minHeight}px`" type="403" /> <exception-page :style="`min-height: ${minHeight}px`" type="403" />
</template> </template>
<script> <script>
@ -11,9 +11,6 @@ export default {
inject: ['layoutMinHeight'], inject: ['layoutMinHeight'],
computed: { computed: {
...mapState('setting', ['multiPage']), ...mapState('setting', ['multiPage']),
marginTop() {
return this.multiPage ? -24 : 0
},
minHeight() { minHeight() {
return this.multiPage ? this.layoutMinHeight - 32 : this.layoutMinHeight return this.multiPage ? this.layoutMinHeight - 32 : this.layoutMinHeight
} }

@ -1,5 +1,5 @@
<template> <template>
<exception-page :style="`margin-top: ${marginTop}px; min-height: ${minHeight}px`" type="404" /> <exception-page :style="`min-height: ${minHeight}px`" type="404" />
</template> </template>
<script> <script>
@ -11,11 +11,9 @@ export default {
inject: ['layoutMinHeight'], inject: ['layoutMinHeight'],
computed: { computed: {
...mapState('setting', ['multiPage']), ...mapState('setting', ['multiPage']),
marginTop() {
return this.multiPage ? -24 : 0
},
minHeight() { minHeight() {
return this.multiPage ? this.layoutMinHeight - 32 : this.layoutMinHeight let layoutMinHeight = this.layoutMinHeight || window.innerHeight
return this.multiPage ? layoutMinHeight - 32 : layoutMinHeight
} }
} }
} }

@ -1,5 +1,5 @@
<template> <template>
<exception-page :style="`margin-top: ${marginTop}px; min-height: ${minHeight}px`" type="500" /> <exception-page :style="`min-height: ${minHeight}px`" type="500" />
</template> </template>
<script> <script>
@ -11,9 +11,6 @@ export default {
inject: ['layoutMinHeight'], inject: ['layoutMinHeight'],
computed: { computed: {
...mapState('setting', ['multiPage']), ...mapState('setting', ['multiPage']),
marginTop() {
return this.multiPage ? -24 : 0
},
minHeight() { minHeight() {
return this.multiPage ? this.layoutMinHeight - 24 : this.layoutMinHeight return this.multiPage ? this.layoutMinHeight - 24 : this.layoutMinHeight
} }

@ -0,0 +1,215 @@
import Login from '@/pages/login/Login'
import TabsView from '@/layouts/tabs/TabsView'
import BlankView from '@/layouts/BlankView'
import PageView from '@/layouts/PageView'
const options = {
routes: [
{
path: '/login',
name: '登录页',
component: Login
},
{
path: '/',
name: '首页',
component: TabsView,
redirect: '/login',
children: [
{
path: 'dashboard',
name: 'Dashboard',
meta: {
icon: 'dashboard'
},
component: BlankView,
children: [
{
path: 'workplace',
name: '工作台',
component: () => import('@/pages/dashboard/workplace/WorkPlace'),
},
{
path: 'analysis',
name: '分析页',
component: () => import('@/pages/dashboard/analysis/Analysis'),
}
]
},
{
path: 'form',
name: '表单页',
meta: {
icon: 'form',
},
component: PageView,
children: [
{
path: 'basic',
name: '基础表单',
component: () => import('@/pages/form/basic/BasicForm'),
},
{
path: 'step',
name: '分步表单',
component: () => import('@/pages/form/step/StepForm'),
},
{
path: 'advance',
name: '高级表单',
component: () => import('@/pages/form/advance/AdvancedForm'),
}
]
},
{
path: 'list',
name: '列表页',
meta: {
icon: 'table'
},
component: PageView,
children: [
{
path: 'query',
name: '查询表格',
component: () => import('@/pages/list/QueryList'),
},
{
path: 'primary',
name: '标准列表',
component: () => import('@/pages/list/StandardList'),
},
{
path: 'card',
name: '卡片列表',
component: () => import('@/pages/list/CardList'),
},
{
path: 'search',
name: '搜索列表',
component: () => import('@/pages/list/search/SearchLayout'),
children: [
{
path: 'article',
name: '文章',
component: () => import('@/pages/list/search/ArticleList'),
},
{
path: 'application',
name: '应用',
component: () => import('@/pages/list/search/ApplicationList'),
},
{
path: 'project',
name: '项目',
component: () => import('@/pages/list/search/ProjectList'),
}
]
}
]
},
{
path: 'details',
name: '详情页',
meta: {
icon: 'profile'
},
component: BlankView,
children: [
{
path: 'basic',
name: '基础详情页',
component: () => import('@/pages/detail/BasicDetail')
},
{
path: 'advance',
name: '高级详情页',
component: () => import('@/pages/detail/AdvancedDetail')
}
]
},
{
path: 'result',
name: '结果页',
meta: {
icon: 'check-circle-o',
},
component: PageView,
children: [
{
path: 'success',
name: '成功',
component: () => import('@/pages/result/Success')
},
{
path: 'error',
name: '失败',
component: () => import('@/pages/result/Error')
}
]
},
{
path: 'exception',
name: '异常页',
meta: {
icon: 'warning',
},
component: BlankView,
children: [
{
path: '404',
name: '404',
component: () => import('@/pages/exception/404')
},
{
path: '403',
name: '403',
component: () => import('@/pages/exception/403')
},
{
path: '500',
name: '500',
component: () => import('@/pages/exception/500')
}
]
},
{
path: 'components',
name: '小组件',
meta: {
icon: 'appstore-o'
},
component: PageView,
children: [
{
path: 'taskCard',
name: '任务卡片',
component: () => import('@/pages/components/TaskCard')
},
{
path: 'palette',
name: '颜色复选框',
component: () => import('@/pages/components/Palette')
}
]
}
]
}
]
}
// 不需要登录拦截的路由配置
const loginIgnore = {
names: ['404'], //根据路由名称匹配
paths: ['/login'], //根据路由fullPath匹配
/**
* 判断路由是否包含在该配置中
* @param route vue-router route 对象
* @returns {boolean}
*/
includes(route) {
return this.names.includes(route.name) || this.paths.includes(route.path)
}
}
export {options, loginIgnore}

@ -1,211 +1,15 @@
import Vue from 'vue' import Vue from 'vue'
import {checkAuthorization} from '@/utils/request' import {checkAuthorization} from '@/utils/request'
import Router from 'vue-router' import Router from 'vue-router'
import PageView from '@/layouts/PageView' import {options, loginIgnore} from './config'
import BlankView from '@/layouts/BlankView'
import TabsView from '@/layouts/tabs/TabsView'
import Login from '@/pages/login/Login'
Vue.use(Router) Vue.use(Router)
const router = new Router({ const router = new Router(options)
routes: [
{
path: '/login',
name: '登录页',
component: Login
},
{
path: '/',
name: '首页',
component: TabsView,
redirect: '/login',
children: [
{
path: 'dashboard',
name: 'Dashboard',
meta: {
icon: 'dashboard'
},
component: BlankView,
children: [
{
path: 'workplace',
name: '工作台',
component: () => import('@/pages/dashboard/workplace/WorkPlace'),
},
{
path: 'analysis',
name: '分析页',
component: () => import('@/pages/dashboard/analysis/Analysis'),
}
]
},
{
path: 'form',
name: '表单页',
meta: {
icon: 'form',
},
component: PageView,
children: [
{
path: 'basic',
name: '基础表单',
component: () => import('@/pages/form/basic/BasicForm'),
},
{
path: 'step',
name: '分步表单',
component: () => import('@/pages/form/step/StepForm'),
},
{
path: 'advance',
name: '高级表单',
component: () => import('@/pages/form/advance/AdvancedForm'),
}
]
},
{
path: 'list',
name: '列表页',
meta: {
icon: 'table'
},
component: PageView,
children: [
{
path: 'query',
name: '查询表格',
component: () => import('@/pages/list/QueryList'),
},
{
path: 'primary',
name: '标准列表',
component: () => import('@/pages/list/StandardList'),
},
{
path: 'card',
name: '卡片列表',
component: () => import('@/pages/list/CardList'),
},
{
path: 'search',
name: '搜索列表',
component: () => import('@/pages/list/search/SearchLayout'),
children: [
{
path: 'article',
name: '文章',
component: () => import('@/pages/list/search/ArticleList'),
},
{
path: 'application',
name: '应用',
component: () => import('@/pages/list/search/ApplicationList'),
},
{
path: 'project',
name: '项目',
component: () => import('@/pages/list/search/ProjectList'),
}
]
}
]
},
{
path: 'details',
name: '详情页',
meta: {
icon: 'profile'
},
component: BlankView,
children: [
{
path: 'basic',
name: '基础详情页',
component: () => import('@/pages/detail/BasicDetail')
},
{
path: 'advance',
name: '高级详情页',
component: () => import('@/pages/detail/AdvancedDetail')
}
]
},
{
path: 'result',
name: '结果页',
meta: {
icon: 'check-circle-o',
},
component: PageView,
children: [
{
path: 'success',
name: '成功',
component: () => import('@/pages/result/Success')
},
{
path: 'error',
name: '失败',
component: () => import('@/pages/result/Error')
}
]
},
{
path: 'exception',
name: '异常页',
meta: {
icon: 'warning',
},
component: BlankView,
children: [
{
path: '404',
name: '404',
component: () => import('@/pages/exception/404')
},
{
path: '403',
name: '403',
component: () => import('@/pages/exception/403')
},
{
path: '500',
name: '500',
component: () => import('@/pages/exception/500')
}
]
},
{
path: 'components',
name: '小组件',
meta: {
icon: 'appstore-o'
},
component: PageView,
children: [
{
path: 'taskCard',
name: '任务卡片',
component: () => import('@/pages/components/TaskCard')
},
{
path: 'palette',
name: '颜色复选框',
component: () => import('@/pages/components/Palette')
}
]
}
]
}
]
})
// 登录拦截 // 登录拦截
router.beforeEach((to, from, next) => { router.beforeEach((to, from, next) => {
if (to.path !== '/login' && !checkAuthorization()) { if (!loginIgnore.includes(to) && !checkAuthorization()) {
next({path: '/login'}) next({path: '/login'})
} else { } else {
next() next()

@ -1,19 +1,13 @@
import Vue from 'vue' import Vue from 'vue'
import Vuex from 'vuex' import Vuex from 'vuex'
import account from './modules/account' import modules from './modules'
import setting from './modules/setting'
import PouchDB from 'pouchdb' import PouchDB from 'pouchdb'
const db = new PouchDB('adminDb') const db = new PouchDB('adminDb')
Vue.use(Vuex) Vue.use(Vuex)
const store = new Vuex.Store({ const store = new Vuex.Store({modules})
modules: {
account,
setting
}
})
// 读取用户信息 // 读取用户信息
db.get('currUser') db.get('currUser')
.then(doc => store.commit('account/setUser', doc.user)) .then(doc => store.commit('account/setUser', doc.user))

@ -0,0 +1,4 @@
import account from './account'
import setting from './setting'
export default {account, setting}
Loading…
Cancel
Save