main.js
4.69 KB
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
import { createApp } from 'vue'
import Cookies from 'js-cookie'
import ElementPlus from 'element-plus'
import '@/assets/styles/index.scss' // global css
import App from './App'
import store from './store'
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 './permissionPc' // permission control
import * as socket from './utils/sockets'
import { useDict } from '@/utils/dict'
import { getConfigKey, updateConfigByKey } from '@/api/system/config'
import { parseTime, resetForm, addDateRange, handleTree, selectDictLabel, selectDictLabels, fillImgUrl, downloadFile } from '@/utils/ruoyi'
import { CountDown } from 'vant'
import 'vant/lib/index.css'
import 'flag-icon-css/css/flag-icons.css'
import Particles from 'vue3-particles'
// 分页组件
import PaginationPc from '@/components/PaginationPc'
// 自定义表格工具组件
import RightToolbar from '@/components/RightToolbar'
// 富文本组件
import Editor from '@/components/Editor'
// 文件上传组件
import FileUpload from '@/components/FileUpload'
import FileImport from '@/components/FileImport'
// 图片上传组件
import ImageUpload from '@/components/ImageUpload'
import ImageUpload2 from '@/components/ImageUpload/index2'
// 图片预览组件
import ImagePreview from '@/components/ImagePreview'
// 自定义树选择组件
import TreeSelect from '@/components/TreeSelect'
// 字典标签组件
import DictTag from '@/components/DictTag'
import draggable from 'vuedraggable'
import VueVideoPlayer from '@videojs-player/vue'
import 'video.js/dist/video-js.min.css'
import cache from '@/plugins/cache'
import router from './routerPc/index'
import localeCn from 'element-plus/es/locale/lang/zh-cn' // 中文语言
import localeEn from 'element-plus/es/locale/lang/en'
import DataV, { setClassNamePrefix } from 'datav-vue3'
import {useStorage} from "@vueuse/core/index";
import VueFullPage from 'vue-fullpage.js'
import 'fullpage.js/dist/fullpage.min.css'
// import VueRouter from 'vue-router'
// import VueRouterTransition from 'vue-router-transition'
const language= useStorage('language',0)
const app = createApp(App)
// 全局方法挂载
app.config.globalProperties.useDict = useDict
app.config.globalProperties.getConfigKey = getConfigKey
app.config.globalProperties.updateConfigByKey = updateConfigByKey
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.config.globalProperties.fillImgUrl = fillImgUrl
app.config.globalProperties.fillImgUrl_train = (url) => fillImgUrl(url, 'ztx-train')
app.config.globalProperties.fillImgUrl_match = (url) => fillImgUrl(url, 'ztx-match')
app.config.globalProperties.fillImgUrl_webSite = (url) => fillImgUrl(url, 'ztx-webSite')
app.config.globalProperties.downloadFile = downloadFile
app.config.globalProperties.downloadFile_match = (filePath) => downloadFile(filePath, 'ztx-webSite')
app.config.globalProperties.downloadFile_webSite = (filePath) => downloadFile(filePath, 'ztx-webSite')
app.config.globalProperties.$socket = socket
// 全局组件挂载
app.component('DictTag', DictTag)
app.component('PaginationPc', PaginationPc)
app.component('TreeSelect', TreeSelect)
app.component('FileUpload', FileUpload)
app.component('FileImport', FileImport)
app.component('ImageUpload', ImageUpload)
app.component('ImageUpload2', ImageUpload2)
app.component('ImagePreview', ImagePreview)
app.component('RightToolbar', RightToolbar)
app.component('Editor', Editor)
app.component('Draggable', draggable)
if (language.value == 0) {
app.use(router)
app.use(ElementPlus, {
locale: localeCn,
size: Cookies.get('size') || 'default'
})
} else {
app.use(router)
app.use(ElementPlus, {
locale: localeEn,
size: Cookies.get('size') || 'default'
})
}
app.use(store)
app.use(plugins)
app.use(elementIcons)
app.use(CountDown)
app.use(Particles)
app.use(VueFullPage)
app.use(DataV, { classNamePrefix: 'dv-' })
// app.use(Vcode)
// app.use(VueRouter);
// app.use(VueRouterTransition);
app.component('SvgIcon', SvgIcon)
app.use(VueVideoPlayer)
directive(app)
// 修改 el-dialog 默认点击遮照为不关闭
app._context.components.ElDialog.props.closeOnClickModal.default = false
app.mount('#app')
if (process.env.NODE_ENV !== 'development') {
// disorderCopy()
}