elkers
2025-01-16 0b62eca817d6c40c188dc72c3034835a61a30a35
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
 * @Author: error: error: git config user.name & please set dead value or install git && error: git config user.email & please set dead value or install git & please set dead value or install git
 * @Date: 2024-05-16 11:24:17
 * @LastEditors: Liuyi candymxq888@outlook.com
 * @LastEditTime: 2024-08-15 12:03:58
 * @FilePath: \wisdom-water-factory-web\src\main.js
 * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
 */
import { createApp } from 'vue'
 
import Cookies from 'js-cookie'
 
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import locale from 'element-plus/es/locale/lang/zh-cn'
 
import '@/assets/styles/index.scss' // global css
 
import App from './App'
import store from './store'
import router from './router'
import directive from './directive' // directive
 
// 注册指令
import plugins from './plugins' // plugins
// import { download } from '@/utils/request'
 
// svg图标
import 'virtual:svg-icons-register'
import SvgIcon from '@/components/SvgIcon'
import elementIcons from '@/components/SvgIcon/svgicon'
 
import './permission' // permission control
import { btnPerms } from './utils/permission'
 
import { parseTime, resetForm, addDateRange, handleTree, selectDictLabel, selectDictLabels } from '@/utils/ruoyi'
 
// 分页组件
import Pagination from '@/components/Pagination'
// 自定义表格工具组件
import RightToolbar from '@/components/RightToolbar'
// 富文本组件
import Editor from "@/components/Editor"
// 文件上传组件
import FileUpload from "@/components/FileUpload"
// 图片上传组件
import ImageUpload from "@/components/ImageUpload"
// 图片预览组件
import ImagePreview from "@/components/ImagePreview"
// 自定义树选择组件
import TreeSelect from '@/components/TreeSelect'
// 字典标签组件
import DictTag from '@/components/DictTag'
//Echarts图表
import EchartsArea from '@/components/EchartsArea'
 
//自定义文件上传
import UploadFile from "@/components/UploadFile"
//多张图片上传
import UploadIcons from "@/components/UploadIcons"
 
 
//数据持久化
import piniaPersist from 'pinia-plugin-persist'
 
const app = createApp(App)
 
store.use(piniaPersist); //加载数据持久化
app.use(store)
 
// 全局方法挂载
// app.config.globalProperties.download = download
app.config.globalProperties.parseTime = parseTime
app.config.globalProperties.resetForm = resetForm
app.config.globalProperties.handleTree = handleTree
app.config.globalProperties.addDateRange = addDateRange
app.config.globalProperties.selectDictLabel = selectDictLabel
app.config.globalProperties.selectDictLabels = selectDictLabels  
 
// 全局组件挂载
app.component('EchartsArea', EchartsArea)
app.component('DictTag', DictTag)
app.component('Pagination', Pagination)
app.component('TreeSelect', TreeSelect)
app.component('FileUpload', FileUpload)
app.component('UploadFile', UploadFile)
app.component('UploadIcons', UploadIcons)
app.component('ImageUpload', ImageUpload)
app.component('ImagePreview', ImagePreview)
app.component('RightToolbar', RightToolbar)
app.component('Editor', Editor)
 
 
import { addActiveRoute } from '@/utils/index'
import usePermissionStore from '@/store/modules/permission'
 
//页面刷新时加载动态路由
//必须要在use(router)之前加载动态路由
const menuStore = usePermissionStore()
addActiveRoute(menuStore, router)
 
app.use(router)
app.use(plugins)
app.use(elementIcons)
app.component('svg-icon', SvgIcon)
 
directive(app)
btnPerms(app)
 
// 使用element-plus 并且设置全局的大小
app.use(ElementPlus, {
  locale: locale,
  // 支持 large、default、small
  size: Cookies.get('size') || 'default'
})
 
app.mount('#app')