mainPc.js 4.32 KB
import { createApp } from 'vue'

import Cookies from 'js-cookie'

import ElementPlus from 'element-plus'
import '@/assets/styles/index.scss' // global css
import App from './AppPc'
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 PaginationPc from '@/components/PaginationPc'
// 自定义表格工具组件
import RightToolbar from '@/components/RightToolbar'
// 富文本组件
import Editor from '@/components/Editor'
// 文件上传组件
import FileUpload from '@/components/FileUpload'
// 图片上传组件
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 wePay from '@/components/hy/wePay'

import VueVideoPlayer from '@videojs-player/vue'
import 'video.js/dist/video-js.min.css'
import cache from '@/plugins/cache'

import routerCn from './routerPc/cn'
import routerEn from './routerPc/en'
import localeCn from 'element-plus/lib/locale/lang/zh-cn' // 中文语言
import localeEn from 'element-plus/lib/locale/lang/en'

const language = cache.local.get('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('ImageUpload', ImageUpload)
app.component('ImageUpload2', ImageUpload2)
app.component('ImagePreview', ImagePreview)
app.component('RightToolbar', RightToolbar)
app.component('Editor', Editor)
app.component('Draggable', draggable)
app.component('WePay', wePay)


if (language == 0) {
  app.use(routerCn)
  app.use(ElementPlus, {
    locale: localeCn,
    size: Cookies.get('size') || 'default'
  })
} else {
  app.use(routerEn)
  app.use(ElementPlus, {
    locale: localeEn,
    size: Cookies.get('size') || 'default'
  })
}

app.use(store)
app.use(plugins)
app.use(elementIcons)
app.use(CountDown)
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()
}