Former-commit-id: c26def84038f9c6ef876bfaecfeda6ad960a7128 [formerly c26def84038f9c6ef876bfaecfeda6ad960a7128 [formerly c26def84038f9c6ef876bfaecfeda6ad960a7128 [formerly c26def84038f9c6ef876bfaecfeda6ad960a7128 [formerly ac51bf426398ead7798bc75e47c225d4e4373c01 [formerly d109b59405dd2496434eb6136b44ce1116c48fd7]]]]] Former-commit-id: 14287833957f8edd7f85c2b59cd0e52dc959d78c Former-commit-id: e477c4156173bd2927cbcc5a38e3163a57aa6286 Former-commit-id: 31689fdb97e62c2e954a39c8a08a3795c3ad239b [formerly 902e7338b00529afc1b34d6b8945a4778fc1d312] Former-commit-id: 55fd7e3549b2cc391aa15984a31b9817c4e849dd Former-commit-id: f26bd67675a2117554ff62633ce05c73d0e86c06 Former-commit-id: 7e834316ca05e6073fc05add9ff9086f014f5a81 Former-commit-id: b12837f121821961c7f9ecb52604308990875ced Former-commit-id: 2ea5c80ed0937d6d154cbc9f331e0cb4277523c9
77 lines
2.1 KiB
JavaScript
77 lines
2.1 KiB
JavaScript
// polyfill
|
|
import 'babel-polyfill'
|
|
// Vue
|
|
import Vue from 'vue'
|
|
import App from './App'
|
|
// store
|
|
import store from '@/store/index'
|
|
// 模拟数据
|
|
import '@/mock'
|
|
// 多国语
|
|
import i18n from './i18n'
|
|
// 核心插件
|
|
import d2Admin from '@/plugin/d2admin'
|
|
|
|
// [ 可选插件组件 ]D2-Crud
|
|
import D2Crud from '@d2-projects/d2-crud'
|
|
// [ 可选插件组件 ] 图表
|
|
import VCharts from 'v-charts'
|
|
// [ 可选插件组件 ] 右键菜单
|
|
import contentmenu from 'v-contextmenu'
|
|
import 'v-contextmenu/dist/index.css'
|
|
// [ 可选插件组件 ] JSON 树状视图
|
|
import vueJsonTreeView from 'vue-json-tree-view'
|
|
// [ 可选插件组件 ] 网格布局组件
|
|
import { GridLayout, GridItem } from 'vue-grid-layout'
|
|
// [ 可选插件组件 ] 区域划分组件
|
|
import SplitPane from 'vue-splitpane'
|
|
|
|
// 菜单和路由设置
|
|
import router from './router'
|
|
import { menuHeader, menuAside } from '@/menu'
|
|
import { frameInRoutes } from '@/router/routes'
|
|
|
|
// 核心插件
|
|
Vue.use(d2Admin)
|
|
|
|
// 可选插件组件
|
|
Vue.use(D2Crud)
|
|
Vue.use(VCharts)
|
|
Vue.use(contentmenu)
|
|
Vue.use(vueJsonTreeView)
|
|
Vue.component('d2-grid-layout', GridLayout)
|
|
Vue.component('d2-grid-item', GridItem)
|
|
Vue.component('SplitPane', SplitPane)
|
|
|
|
new Vue({
|
|
router,
|
|
store,
|
|
i18n,
|
|
render: h => h(App),
|
|
created () {
|
|
// 处理路由 得到每一级的路由设置
|
|
this.$store.commit('d2admin/page/init', frameInRoutes)
|
|
// 设置顶栏菜单
|
|
this.$store.commit('d2admin/menu/headerSet', menuHeader)
|
|
},
|
|
mounted () {
|
|
// 展示系统信息
|
|
this.$store.commit('d2admin/releases/versionShow')
|
|
// 检查最新版本
|
|
this.$store.dispatch('d2admin/releases/checkUpdate')
|
|
// 用户登陆后从数据库加载一系列的设置
|
|
this.$store.commit('d2admin/account/load')
|
|
// 获取并记录用户 UA
|
|
this.$store.commit('d2admin/ua/get')
|
|
// 初始化全屏监听
|
|
this.$store.commit('d2admin/fullscreen/listen')
|
|
},
|
|
watch: {
|
|
// 监听路由 控制侧边栏显示
|
|
'$route.matched' (val) {
|
|
const _side = menuAside.filter(menu => menu.path === val[0].path)
|
|
this.$store.commit('d2admin/menu/asideSet', _side.length > 0 ? _side[0].children : [])
|
|
}
|
|
}
|
|
}).$mount('#app')
|