main.js 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. import Vue from 'vue'
  2. import { useAntd } from 'k-form-design/packages/core/useComponents'
  3. import KFormDesign from 'k-form-design/packages/use.js'
  4. import 'k-form-design/lib/k-form-design.css'
  5. // require('k-form-design/lib/k-form-design.css')
  6. import Cookies from 'js-cookie'
  7. import Element from 'element-ui'
  8. import './assets/styles/element-variables.scss'
  9. // require('./assets/styles/element-variables.scss')
  10. // 以下为bpmn工作流绘图工具的样式
  11. import 'bpmn-js/dist/assets/diagram-js.css' // 左边工具栏以及编辑节点的样式
  12. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn.css'
  13. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-codes.css'
  14. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css'
  15. // require('bpmn-js/dist/assets/diagram-js.css') // 左边工具栏以及编辑节点的样式
  16. // require('bpmn-js/dist/assets/bpmn-font/css/bpmn.css')
  17. // require('bpmn-js/dist/assets/bpmn-font/css/bpmn-codes.css')
  18. // require('bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css')
  19. // import 'bpmn-js-properties-panel/dist/assets/bpmn-js-properties-panel.css'
  20. // 左边工具栏以及编辑节点的样式
  21. // import 'bpmn-js-properties-panel/dist/assets/properties-panel.css'
  22. // bpmn样式结束
  23. // bpmnPro start
  24. import { vuePlugin } from "@packages/highlight";
  25. import "highlight.js/styles/atom-one-dark-reasonable.css";
  26. // require("highlight.js/styles/atom-one-dark-reasonable.css");
  27. Vue.use(vuePlugin);
  28. import Common from "@packages/common";
  29. Vue.use(Common);
  30. import ResetPopover from "@utils/resetPopover";
  31. Vue.directive("r-popover", ResetPopover);
  32. import "@packages/theme/index.scss";
  33. // require("@packages/theme/index.scss");
  34. // bpmnPro end
  35. import '@/assets/styles/index.scss' // global css
  36. import '@/assets/styles/zkqy.scss' // zkqy css
  37. // require('@/assets/styles/index.scss') // global css
  38. // require('@/assets/styles/zkqy.scss') // zkqy css
  39. import App from './App'
  40. import store from './store'
  41. import router from './router'
  42. import directive from './directive' // directive
  43. import plugins from './plugins' // plugins
  44. import { download } from '@/utils/request'
  45. import './assets/icons' // icon
  46. import './permission' // permission control
  47. // require('./assets/icons') // icon
  48. // require('./permission') // permission control
  49. import { getDicts } from "@/api/system/dict/data";
  50. import { getConfigKey } from "@/api/system/config";
  51. import { parseTime, resetForm, addDateRange, selectDictLabel, selectDictLabels, handleTree } from "@/utils/zkqy";
  52. // 分页组件
  53. import Pagination from "@/components/Pagination";
  54. // 自定义表格工具组件
  55. import RightToolbar from "@/components/RightToolbar"
  56. // 富文本组件
  57. import Editor from "@/components/Editor"
  58. // 文件上传组件
  59. import FileUpload from "@/components/FileUpload"
  60. // 图片上传组件
  61. import ImageUpload from "@/components/ImageUpload"
  62. // 图片预览组件
  63. import ImagePreview from "@/components/ImagePreview"
  64. // 字典标签组件
  65. import DictTag from '@/components/DictTag'
  66. // 头部标签组件
  67. import VueMeta from 'vue-meta'
  68. // 字典数据组件
  69. import DictData from '@/components/DictData'
  70. import JsonExcel from 'vue-json-excel'
  71. // 自定义指令
  72. import Directives from '@/utils/directives'
  73. // import './mock.js'
  74. // 全局方法挂载
  75. Vue.prototype.getDicts = getDicts
  76. Vue.prototype.getConfigKey = getConfigKey
  77. Vue.prototype.parseTime = parseTime
  78. Vue.prototype.resetForm = resetForm
  79. Vue.prototype.addDateRange = addDateRange
  80. Vue.prototype.selectDictLabel = selectDictLabel
  81. Vue.prototype.selectDictLabels = selectDictLabels
  82. Vue.prototype.download = download
  83. Vue.prototype.handleTree = handleTree
  84. // 全局组件挂载
  85. Vue.component('downloadExcel', JsonExcel)
  86. Vue.component('DictTag', DictTag)
  87. Vue.component('Pagination', Pagination)
  88. Vue.component('RightToolbar', RightToolbar)
  89. Vue.component('Editor', Editor)
  90. Vue.component('FileUpload', FileUpload)
  91. Vue.component('ImageUpload', ImageUpload)
  92. Vue.component('ImagePreview', ImagePreview)
  93. Vue.use(directive)
  94. Vue.use(plugins)
  95. Vue.use(VueMeta)
  96. DictData.install()
  97. useAntd(Vue)
  98. Vue.use(KFormDesign)
  99. Object.keys(Directives).forEach(item => {
  100. Vue.directive(item, Directives[item])
  101. })
  102. /**
  103. * If you don't want to use mock-server
  104. * you want to use MockJs for mock api
  105. * you can execute: mockXHR()
  106. *
  107. * Currently MockJs will be used in the production environment,
  108. * please remove it before going online! ! !
  109. */
  110. Vue.use(Element, {
  111. size: Cookies.get('size') || 'medium' // set element-ui default size
  112. })
  113. Vue.config.productionTip = false
  114. new Vue({
  115. el: '#app',
  116. router,
  117. store,
  118. render: h => h(App),
  119. beforeCreate() {
  120. Vue.prototype.$bus = this
  121. }
  122. })