CASM_web/src/main.js

130 lines
3.6 KiB
JavaScript
Raw Normal View History

2024-03-26 06:11:10 +00:00
import { createApp } from 'vue'
import Cookies from 'js-cookie'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
2024-03-26 09:02:42 +00:00
import zhLocale from 'element-plus/es/locale/lang/zh-cn'
import enLocale from 'element-plus/es/locale/lang/en'
// 引入 elementui 的多语言
2024-03-26 06:11:10 +00:00
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'
// i18n js
import i18n from './lang/i18n.js'
import './permission' // permission control
import { useDict } from '@/utils/dict'
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'
2024-03-26 09:02:42 +00:00
import { getStoredLanguage, saveStoredLanguage } from "@/utils/languageStorage";
2024-04-10 11:00:36 +00:00
import VECharts from 'vue-echarts'
import { use } from 'echarts/core'
// 手动引入 ECharts 各模块来减小打包体积
import {
CanvasRenderer
} from 'echarts/renderers'
import {
2024-04-11 11:01:19 +00:00
PieChart,LineChart
2024-04-10 11:00:36 +00:00
} from 'echarts/charts'
import {
TitleComponent,
TooltipComponent,
2024-04-11 11:01:19 +00:00
LegendComponent,
GridComponent
2024-04-10 11:00:36 +00:00
} from 'echarts/components'
use([
CanvasRenderer,
TitleComponent,
TooltipComponent,
2024-04-11 11:01:19 +00:00
LegendComponent,
GridComponent,
PieChart,
LineChart,
2024-04-10 11:00:36 +00:00
]);
// 设置语言
2024-03-26 09:02:42 +00:00
let locale = getStoredLanguage() === 'en-US' ? enLocale : zhLocale
2024-03-26 06:11:10 +00:00
const app = createApp(App)
// 全局方法挂载
app.config.globalProperties.useDict = useDict
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
// 此段代码写入main.js中
app.config.globalProperties.$t = i18n.global.t
2024-04-08 09:10:20 +00:00
app.config.globalProperties.$te = i18n.global.te
2024-04-10 11:00:36 +00:00
app.config.globalProperties.tLang = (parent, item) => {
2024-04-08 09:10:20 +00:00
if (i18n.global.te(parent + "." + item)) {
2024-04-10 11:00:36 +00:00
return i18n.global.t(parent + "." + item)
}
2024-04-08 09:10:20 +00:00
return item
}
2024-03-26 06:11:10 +00:00
// 全局组件挂载
app.component('DictTag', DictTag)
app.component('Pagination', Pagination)
app.component('TreeSelect', TreeSelect)
app.component('FileUpload', FileUpload)
app.component('ImageUpload', ImageUpload)
app.component('ImagePreview', ImagePreview)
app.component('RightToolbar', RightToolbar)
app.component('Editor', Editor)
2024-04-10 11:00:36 +00:00
// 全局注册组件(也可以使用局部注册)
app.component('v-chart', VECharts)
2024-03-26 06:11:10 +00:00
app.use(router)
app.use(store)
app.use(i18n)
app.use(plugins)
app.use(elementIcons)
app.component('svg-icon', SvgIcon)
directive(app)
// 使用element-plus 并且设置全局的大小
app.use(ElementPlus, {
locale: locale,
// 支持 large、default、small
size: Cookies.get('size') || 'default'
})
app.mount('#app')