main.js 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import { createApp } from 'vue'
  2. import Cookies from 'js-cookie'
  3. import ElementPlus from 'element-plus'
  4. import 'element-plus/dist/index.css'
  5. import 'element-plus/theme-chalk/dark/css-vars.css'
  6. import locale from 'element-plus/es/locale/lang/zh-cn'
  7. import '@/assets/styles/index.scss' // global css
  8. import App from './App'
  9. import store from './store'
  10. import router from './router'
  11. import directive from './directive' // directive
  12. // 注册指令
  13. import plugins from './plugins' // plugins
  14. import { download } from '@/utils/request'
  15. // svg图标
  16. import 'virtual:svg-icons-register'
  17. import SvgIcon from '@/components/SvgIcon'
  18. import elementIcons from '@/components/SvgIcon/svgicon'
  19. import './permission' // permission control
  20. import { useDict } from '@/utils/dict'
  21. import { parseTime, resetForm, addDateRange, handleTree, selectDictLabel, selectDictLabels } from '@/utils/ruoyi'
  22. // 分页组件
  23. import Pagination from '@/components/Pagination'
  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. // 图片预览组件
  33. import ImagePreview from "@/components/ImagePreview"
  34. // 字典标签组件
  35. import DictTag from '@/components/DictTag'
  36. import TlbsMap from 'tlbs-map-vue';
  37. const app = createApp(App)
  38. // 全局方法挂载
  39. app.config.globalProperties.useDict = useDict
  40. app.config.globalProperties.download = download
  41. app.config.globalProperties.parseTime = parseTime
  42. app.config.globalProperties.resetForm = resetForm
  43. app.config.globalProperties.handleTree = handleTree
  44. app.config.globalProperties.addDateRange = addDateRange
  45. app.config.globalProperties.selectDictLabel = selectDictLabel
  46. app.config.globalProperties.selectDictLabels = selectDictLabels
  47. // 全局组件挂载
  48. app.component('DictTag', DictTag)
  49. app.component('Pagination', Pagination)
  50. app.component('FileUpload', FileUpload)
  51. app.component('ImageUpload', ImageUpload)
  52. app.component('ImagePreview', ImagePreview)
  53. app.component('RightToolbar', RightToolbar)
  54. app.component('Editor', Editor)
  55. app.use(router)
  56. app.use(store)
  57. app.use(plugins)
  58. app.use(elementIcons)
  59. app.use(TlbsMap)
  60. app.component('svg-icon', SvgIcon)
  61. directive(app)
  62. // 使用element-plus 并且设置全局的大小
  63. app.use(ElementPlus, {
  64. locale: locale,
  65. // 支持 large、default、small
  66. size: Cookies.get('size') || 'default'
  67. })
  68. app.mount('#app')