main.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. import Vue from 'vue'
  2. import Cookies from 'js-cookie'
  3. import Element from 'element-ui'
  4. import './assets/styles/element-variables.scss'
  5. // import waterfall from 'vue-masonry'
  6. import '@/assets/styles/index.scss' // global css
  7. import '@/assets/styles/ruoyi.scss' // ruoyi css
  8. import App from './App'
  9. import store from './store'
  10. import router from './router'
  11. import directive from './directive' // directive
  12. import plugins from './plugins' // plugins
  13. import { download } from '@/utils/request'
  14. // 全局引用样式
  15. import 'vue-area-linkage/dist/index.css'
  16. import './assets/icons' // icon
  17. import './permission' // permission control
  18. import { getDicts } from "@/api/system/dict/data"
  19. import { getConfigKey } from "@/api/system/config"
  20. import { parseTime, resetForm, addDateRange, selectDictLabel, selectDictLabels, handleTree } from "@/utils/ruoyi"
  21. // 分页组件
  22. import Pagination from "@/components/Pagination"
  23. import Paginations from "@/components/Paginations"
  24. // 自定义表格工具组件
  25. import RightToolbar from "@/components/RightToolbar"
  26. // 富文本组件
  27. import Editor from "@/components/Editor"
  28. // 文件上传组件
  29. import FileUpload from "@/components/FileUpload"
  30. // 图片上传组件
  31. import ImageUpload from "@/components/ImageUpload"
  32. import ImageUploadr from "@/components/ImageUploadr"
  33. import ImageUploadrss from "@/components/ImageUploadrss"
  34. import Photo from "@/components/Photo"
  35. import VueAreaLinkage from 'vue-area-linkage'
  36. // 图片预览组件
  37. import ImagePreview from "@/components/ImagePreview"
  38. // 字典标签组件
  39. import DictTag from '@/components/DictTag'
  40. // 头部标签组件
  41. import VueMeta from 'vue-meta'
  42. // 字典数据组件
  43. import DictData from '@/components/DictData'
  44. // import Mqttzj from '@/components/Mqttzj'
  45. import {VueMasonryPlugin} from 'vue-masonry';
  46. // var VueMasonryPlugin = window["vue-masonry-plugin"].VueMasonryPlugin
  47. // 全局方法挂载
  48. Vue.prototype.getDicts = getDicts
  49. Vue.prototype.getConfigKey = getConfigKey
  50. Vue.prototype.parseTime = parseTime
  51. Vue.prototype.resetForm = resetForm
  52. Vue.prototype.addDateRange = addDateRange
  53. Vue.prototype.selectDictLabel = selectDictLabel
  54. Vue.prototype.selectDictLabels = selectDictLabels
  55. Vue.prototype.download = download
  56. Vue.prototype.handleTree = handleTree
  57. // 全局组件挂载
  58. Vue.component('DictTag', DictTag)
  59. Vue.component('Pagination', Pagination)
  60. Vue.component('Paginations', Paginations)
  61. Vue.component('RightToolbar', RightToolbar)
  62. Vue.component('Editor', Editor)
  63. Vue.component('FileUpload', FileUpload)
  64. Vue.component('ImageUpload', ImageUpload)
  65. Vue.component('ImageUploadr', ImageUploadr)
  66. Vue.component('ImageUploadrss', ImageUploadrss)
  67. Vue.component('Photo', Photo)
  68. // Vue.component('Mqttzj', Mqttzj)
  69. Vue.component('ImagePreview', ImagePreview)
  70. Vue.use(directive)
  71. Vue.use(plugins)
  72. Vue.use(VueMeta)
  73. Vue.use(VueAreaLinkage)
  74. // Vue.use(waterfall)
  75. Vue.use(VueMasonryPlugin);
  76. DictData.install()
  77. /**
  78. * If you don't want to use mock-server
  79. * you want to use MockJs for mock api
  80. * you can execute: mockXHR()
  81. *
  82. * Currently MockJs will be used in the production environment,
  83. * please remove it before going online! ! !
  84. */
  85. Vue.use(Element, {
  86. size: Cookies.get('size') || 'medium' // set element-ui default size
  87. })
  88. Vue.config.productionTip = false
  89. new Vue({
  90. el: '#app',
  91. router,
  92. store,
  93. render: h => h(App)
  94. })