2018-08-22 10:24:02 +08:00
|
|
|
// polyfill
|
2018-07-16 22:22:55 +08:00
|
|
|
import 'babel-polyfill'
|
2018-08-22 10:24:02 +08:00
|
|
|
// Vue
|
2018-07-16 10:54:24 +08:00
|
|
|
import Vue from 'vue'
|
2018-07-16 22:22:55 +08:00
|
|
|
import App from './App'
|
2018-08-22 10:24:02 +08:00
|
|
|
// store
|
|
|
|
|
import store from '@/store/index'
|
|
|
|
|
// 模拟数据
|
|
|
|
|
import '@/mock'
|
|
|
|
|
// 多国语
|
2018-07-16 22:22:55 +08:00
|
|
|
import i18n from './i18n'
|
2018-08-22 10:24:02 +08:00
|
|
|
// 核心插件
|
|
|
|
|
import d2Admin from '@/plugin/d2admin'
|
2018-08-22 11:12:52 +08:00
|
|
|
|
2018-08-26 18:30:35 +08:00
|
|
|
// [ 可选插件组件 ]D2-Crud
|
|
|
|
|
import D2Crud from '@d2-projects/d2-crud'
|
2018-08-22 11:12:52 +08:00
|
|
|
// [ 可选插件组件 ] 图表
|
2018-08-22 10:57:59 +08:00
|
|
|
import VCharts from 'v-charts'
|
2018-08-22 11:12:52 +08:00
|
|
|
// [ 可选插件组件 ] 右键菜单
|
2018-08-22 10:57:59 +08:00
|
|
|
import contentmenu from 'v-contextmenu'
|
|
|
|
|
import 'v-contextmenu/dist/index.css'
|
2018-08-22 11:12:52 +08:00
|
|
|
// [ 可选插件组件 ] JSON 树状视图
|
2018-08-22 10:57:59 +08:00
|
|
|
import vueJsonTreeView from 'vue-json-tree-view'
|
2018-08-22 11:12:52 +08:00
|
|
|
// [ 可选插件组件 ] 网格布局组件
|
|
|
|
|
import { GridLayout, GridItem } from 'vue-grid-layout'
|
|
|
|
|
// [ 可选插件组件 ] 区域划分组件
|
|
|
|
|
import SplitPane from 'vue-splitpane'
|
|
|
|
|
|
2018-07-25 22:17:41 +08:00
|
|
|
// 菜单和路由设置
|
2018-07-16 10:54:24 +08:00
|
|
|
import router from './router'
|
2018-07-25 22:17:41 +08:00
|
|
|
import { menuHeader, menuAside } from '@/menu'
|
|
|
|
|
import { frameInRoutes } from '@/router/routes'
|
2018-07-16 22:22:55 +08:00
|
|
|
|
2018-08-22 10:24:02 +08:00
|
|
|
// 核心插件
|
|
|
|
|
Vue.use(d2Admin)
|
2018-08-22 11:12:52 +08:00
|
|
|
|
|
|
|
|
// 可选插件组件
|
2018-08-26 18:30:35 +08:00
|
|
|
Vue.use(D2Crud)
|
2018-07-16 22:22:55 +08:00
|
|
|
Vue.use(VCharts)
|
|
|
|
|
Vue.use(contentmenu)
|
|
|
|
|
Vue.use(vueJsonTreeView)
|
2018-08-22 11:12:52 +08:00
|
|
|
Vue.component('d2-grid-layout', GridLayout)
|
|
|
|
|
Vue.component('d2-grid-item', GridItem)
|
|
|
|
|
Vue.component('SplitPane', SplitPane)
|
2018-07-16 10:54:24 +08:00
|
|
|
|
|
|
|
|
new Vue({
|
|
|
|
|
router,
|
|
|
|
|
store,
|
2018-07-16 22:22:55 +08:00
|
|
|
i18n,
|
|
|
|
|
render: h => h(App),
|
|
|
|
|
created () {
|
|
|
|
|
// 处理路由 得到每一级的路由设置
|
2018-08-22 08:52:25 +08:00
|
|
|
this.$store.commit('d2admin/page/init', frameInRoutes)
|
2018-07-17 22:49:13 +08:00
|
|
|
// 设置顶栏菜单
|
2018-08-08 16:04:10 +08:00
|
|
|
this.$store.commit('d2admin/menu/headerSet', menuHeader)
|
2018-08-28 17:00:09 +08:00
|
|
|
// 初始化菜单搜索功能
|
|
|
|
|
this.$store.commit('d2admin/search/init', menuHeader)
|
2018-07-16 22:22:55 +08:00
|
|
|
},
|
|
|
|
|
mounted () {
|
2018-07-17 23:59:20 +08:00
|
|
|
// 展示系统信息
|
2018-08-21 23:25:57 +08:00
|
|
|
this.$store.commit('d2admin/releases/versionShow')
|
|
|
|
|
// 检查最新版本
|
|
|
|
|
this.$store.dispatch('d2admin/releases/checkUpdate')
|
2018-08-31 16:23:47 +08:00
|
|
|
// 用户登录后从数据库加载一系列的设置
|
2018-08-09 14:12:34 +08:00
|
|
|
this.$store.commit('d2admin/account/load')
|
2018-08-21 23:25:57 +08:00
|
|
|
// 获取并记录用户 UA
|
|
|
|
|
this.$store.commit('d2admin/ua/get')
|
2018-07-16 22:22:55 +08:00
|
|
|
// 初始化全屏监听
|
2018-08-22 08:34:16 +08:00
|
|
|
this.$store.commit('d2admin/fullscreen/listen')
|
2018-07-16 22:22:55 +08:00
|
|
|
},
|
2018-07-17 22:49:13 +08:00
|
|
|
watch: {
|
|
|
|
|
// 监听路由 控制侧边栏显示
|
|
|
|
|
'$route.matched' (val) {
|
2018-07-23 23:05:14 +08:00
|
|
|
const _side = menuAside.filter(menu => menu.path === val[0].path)
|
2018-08-08 16:04:10 +08:00
|
|
|
this.$store.commit('d2admin/menu/asideSet', _side.length > 0 ? _side[0].children : [])
|
2018-07-17 22:49:13 +08:00
|
|
|
}
|
2018-07-16 22:22:55 +08:00
|
|
|
}
|
2018-07-16 10:54:24 +08:00
|
|
|
}).$mount('#app')
|