main.js 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  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 Element from 'element-ui'
  9. import './assets/styles/element-variables.scss'
  10. // require('./assets/styles/element-variables.scss')
  11. import 'element-ui/lib/theme-chalk/index.css';
  12. import formCreate from "@form-create/element-ui";
  13. // import FcDesigner from '@form-create/designer';
  14. import FcDesigner from "../src/views/formCreate/index.js";
  15. // import FcDesignerMobile from '../src/fcDesignerMobile/dist/index.es.js'
  16. import zkqyTable from '../src/views/formCreate/components/zkqyMenu/zkqyTable.vue';
  17. // import Vant from 'vant';
  18. // import 'vant/lib/index.css';
  19. // 使用 form-create 和 designer
  20. // Vue.use(FcDesigner);
  21. // Vue.use(FcDesigner.formCreate);
  22. Vue.use(formCreate);
  23. Vue.use(ELEMENT);
  24. Vue.component("FcDesigner", FcDesigner);
  25. // 注册自定义组件到设计器
  26. FcDesigner.component('zkqyTable', zkqyTable);
  27. // 挂载 Vant
  28. // Vue.use(Vant)
  29. // 挂载 FcDesignerMobile 组件
  30. // Vue.use(FcDesignerMobile)
  31. // 挂载 formCreate
  32. // Vue.use(FcDesignerMobile.formCreate)
  33. // 以下为bpmn工作流绘图工具的样式
  34. import 'bpmn-js/dist/assets/diagram-js.css' // 左边工具栏以及编辑节点的样式
  35. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn.css'
  36. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-codes.css'
  37. import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css'
  38. // require('bpmn-js/dist/assets/diagram-js.css') // 左边工具栏以及编辑节点的样式
  39. // require('bpmn-js/dist/assets/bpmn-font/css/bpmn.css')
  40. // require('bpmn-js/dist/assets/bpmn-font/css/bpmn-codes.css')
  41. // require('bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css')
  42. // import 'bpmn-js-properties-panel/dist/assets/bpmn-js-properties-panel.css'
  43. // 左边工具栏以及编辑节点的样式
  44. // import 'bpmn-js-properties-panel/dist/assets/properties-panel.css'
  45. // bpmn样式结束
  46. // bpmnPro start
  47. import { vuePlugin } from "@packages/highlight";
  48. import "highlight.js/styles/atom-one-dark-reasonable.css";
  49. // require("highlight.js/styles/atom-one-dark-reasonable.css");
  50. Vue.use(vuePlugin);
  51. import Common from "@packages/common";
  52. Vue.use(Common);
  53. import ResetPopover from "@utils/resetPopover";
  54. Vue.directive("r-popover", ResetPopover);
  55. import "@packages/theme/index.scss";
  56. // require("@packages/theme/index.scss");
  57. // bpmnPro end
  58. import '@/assets/styles/index.scss' // global css
  59. import '@/assets/styles/zkqy.scss' // zkqy css
  60. // require('@/assets/styles/index.scss') // global css
  61. // require('@/assets/styles/zkqy.scss') // zkqy css
  62. import App from './App'
  63. import store from './store'
  64. import router from './router'
  65. import directive from './directive' // directive
  66. import plugins from './plugins' // plugins
  67. import { download } from '@/utils/request'
  68. import './assets/icons' // icon
  69. import './permission' // permission control
  70. // require('./assets/icons') // icon
  71. // require('./permission') // permission control
  72. import { getDicts } from "@/api/system/dict/data";
  73. import { getConfigKey } from "@/api/system/config";
  74. import { parseTime, resetForm, addDateRange, selectDictLabel, selectDictLabels, handleTree } from "@/utils/zkqy";
  75. // 分页组件
  76. import Pagination from "@/components/Pagination";
  77. // 自定义表格工具组件
  78. import RightToolbar from "@/components/RightToolbar"
  79. // 富文本组件
  80. import Editor from "@/components/Editor"
  81. // 文件上传组件
  82. import FileUpload from "@/components/FileUpload"
  83. // 图片上传组件
  84. import ImageUpload from "@/components/ImageUpload"
  85. // 图片预览组件
  86. import ImagePreview from "@/components/ImagePreview"
  87. // 字典标签组件
  88. import DictTag from '@/components/DictTag'
  89. // 头部标签组件
  90. import VueMeta from 'vue-meta'
  91. // 字典数据组件
  92. import DictData from '@/components/DictData'
  93. import JsonExcel from 'vue-json-excel'
  94. // 自定义指令
  95. import Directives from '@/utils/directives'
  96. // import './mock.js'
  97. // 引入字体图标
  98. import '@/assets/iconfont/iconfont.css'
  99. import '@/assets/iconfont/iconfont.js'
  100. // 引入 echarts
  101. import * as echarts from 'echarts'
  102. Vue.prototype.$echarts = echarts
  103. // 引入并挂载ant-design
  104. import Antd from 'ant-design-vue';
  105. import 'ant-design-vue/dist/antd.css';
  106. Vue.use(Antd);
  107. // 数据报表相关 start
  108. import mixins from '@/mixins'
  109. Vue.mixin(mixins)
  110. // 全局定义echarts
  111. import ECharts from 'vue-echarts'
  112. import 'echarts/lib/chart/bar'
  113. import 'echarts/lib/component/tooltip'
  114. Vue.component('v-chart', ECharts)
  115. import dataV from '@jiaminghi/data-view'
  116. Vue.use(dataV)
  117. import Avue from '@smallwei/avue';
  118. import '@smallwei/avue/lib/index.css';
  119. Vue.use(Avue);
  120. // 数据报表相关 end
  121. // luckySheet start
  122. // import '../static/luckysheet/plugins/css/pluginsCss.css'
  123. // import '../static/luckysheet/plugins/plugins.css'
  124. // import '../static/luckysheet/css/luckysheet.css'
  125. // import '../static/luckysheet/assets/iconfont/iconfont.css'
  126. // import '../static/luckysheet/plugins/js/plugin.js'
  127. // import '../static/luckysheet/luckysheet.umd.js'
  128. // luckySheet end
  129. // 全局方法挂载
  130. Vue.prototype.getDicts = getDicts
  131. Vue.prototype.getConfigKey = getConfigKey
  132. Vue.prototype.parseTime = parseTime
  133. Vue.prototype.resetForm = resetForm
  134. Vue.prototype.addDateRange = addDateRange
  135. Vue.prototype.selectDictLabel = selectDictLabel
  136. Vue.prototype.selectDictLabels = selectDictLabels
  137. Vue.prototype.download = download
  138. Vue.prototype.handleTree = handleTree
  139. // 全局组件挂载
  140. Vue.component('downloadExcel', JsonExcel)
  141. Vue.component('DictTag', DictTag)
  142. Vue.component('Pagination', Pagination)
  143. Vue.component('RightToolbar', RightToolbar)
  144. Vue.component('Editor', Editor)
  145. Vue.component('FileUpload', FileUpload)
  146. Vue.component('ImageUpload', ImageUpload)
  147. Vue.component('ImagePreview', ImagePreview)
  148. Vue.use(directive)
  149. Vue.use(plugins)
  150. Vue.use(VueMeta)
  151. DictData.install()
  152. useAntd(Vue)
  153. Vue.use(KFormDesign)
  154. Object.keys(Directives).forEach(item => {
  155. Vue.directive(item, Directives[item])
  156. })
  157. /**
  158. * If you don't want to use mock-server
  159. * you want to use MockJs for mock api
  160. * you can execute: mockXHR()
  161. *
  162. * Currently MockJs will be used in the production environment,
  163. * please remove it before going online! ! !
  164. */
  165. Vue.use(Element, {
  166. size: Cookies.get('size') || 'medium' // set element-ui default size
  167. })
  168. Vue.config.productionTip = false
  169. new Vue({
  170. el: '#app',
  171. router,
  172. store,
  173. render: h => h(App),
  174. beforeCreate() {
  175. Vue.prototype.$bus = this
  176. }
  177. })