main.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /** init domain config */
  2. import './config'
  3. import Vue from 'vue'
  4. import App from './App.vue'
  5. import Storage from 'vue-ls'
  6. import router from './router'
  7. import store from './store/'
  8. import { VueAxios } from "@/utils/request"
  9. require('@jeecg/antd-online-mini')
  10. require('@jeecg/antd-online-mini/dist/OnlineForm.css')
  11. import Antd, { version } from 'ant-design-vue'
  12. console.log('ant-design-vue version:', version)
  13. import Viser from 'viser-vue'
  14. import 'ant-design-vue/dist/antd.less'; // or 'ant-design-vue/dist/antd.less'
  15. import '@/permission' // permission control
  16. import '@/utils/filter' // base filter
  17. import Print from 'vue-print-nb-jeecg'
  18. /*import '@babel/polyfill'*/
  19. import preview from 'vue-photo-preview'
  20. import 'vue-photo-preview/dist/skin.css'
  21. import SSO from '@/cas/sso.js'
  22. import {
  23. ACCESS_TOKEN,
  24. DEFAULT_COLOR,
  25. DEFAULT_THEME,
  26. DEFAULT_LAYOUT_MODE,
  27. DEFAULT_COLOR_WEAK,
  28. SIDEBAR_TYPE,
  29. DEFAULT_FIXED_HEADER,
  30. DEFAULT_FIXED_HEADER_HIDDEN,
  31. DEFAULT_FIXED_SIDEMENU,
  32. DEFAULT_CONTENT_WIDTH_TYPE,
  33. DEFAULT_MULTI_PAGE
  34. } from "@/store/mutation-types"
  35. import config from '@/defaultSettings'
  36. import JDictSelectTag from './components/dict/index.js'
  37. import hasPermission from '@/utils/hasPermission'
  38. import vueBus from '@/utils/vueBus';
  39. import JeecgComponents from '@/components/jeecg/index'
  40. // 修改框架:新增递归树全局方法
  41. import { handleTree } from "@/utils/ems";
  42. // 修改框架:新增全新弹窗全局组件
  43. import UComponents from '@/components/module_ems/index'
  44. import '@/assets/less/JAreaLinkage.less'
  45. import VueAreaLinkage from 'vue-area-linkage'
  46. import '@/components/jeecg/JVxeTable/install'
  47. import '@/components/JVxeCells/install'
  48. //表单验证
  49. import { rules } from '@/utils/rules'
  50. Vue.prototype.rules = rules
  51. Vue.config.productionTip = false
  52. // 修改框架:全局挂载方法递归树
  53. Vue.prototype.handleTree = handleTree
  54. Vue.use(Storage, config.storageOptions)
  55. Vue.use(Antd)
  56. Vue.use(VueAxios, router)
  57. Vue.use(Viser)
  58. Vue.use(hasPermission)
  59. Vue.use(JDictSelectTag)
  60. Vue.use(Print)
  61. Vue.use(preview)
  62. Vue.use(vueBus);
  63. Vue.use(JeecgComponents);
  64. // 修改框架:新增全新弹窗全局组件
  65. Vue.use(UComponents);
  66. Vue.use(VueAreaLinkage);
  67. SSO.init(() => {
  68. main()
  69. })
  70. function main() {
  71. new Vue({
  72. router,
  73. store,
  74. mounted () {
  75. store.commit('SET_SIDEBAR_TYPE', Vue.ls.get(SIDEBAR_TYPE, true))
  76. store.commit('TOGGLE_THEME', Vue.ls.get(DEFAULT_THEME, config.navTheme))
  77. store.commit('TOGGLE_LAYOUT_MODE', Vue.ls.get(DEFAULT_LAYOUT_MODE, config.layout))
  78. store.commit('TOGGLE_FIXED_HEADER', Vue.ls.get(DEFAULT_FIXED_HEADER, config.fixedHeader))
  79. store.commit('TOGGLE_FIXED_SIDERBAR', Vue.ls.get(DEFAULT_FIXED_SIDEMENU, config.fixSiderbar))
  80. store.commit('TOGGLE_CONTENT_WIDTH', Vue.ls.get(DEFAULT_CONTENT_WIDTH_TYPE, config.contentWidth))
  81. store.commit('TOGGLE_FIXED_HEADER_HIDDEN', Vue.ls.get(DEFAULT_FIXED_HEADER_HIDDEN, config.autoHideHeader))
  82. store.commit('TOGGLE_WEAK', Vue.ls.get(DEFAULT_COLOR_WEAK, config.colorWeak))
  83. store.commit('TOGGLE_COLOR', Vue.ls.get(DEFAULT_COLOR, config.primaryColor))
  84. store.commit('SET_TOKEN', Vue.ls.get(ACCESS_TOKEN))
  85. store.commit('SET_MULTI_PAGE',Vue.ls.get(DEFAULT_MULTI_PAGE,config.multipage))
  86. },
  87. render: h => h(App)
  88. }).$mount('#app')
  89. }