llj
1 天以前 7e6ffc18780b57f11cd32d8aaf5137c3cd4b1f7d
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
import Vue from 'vue'
import Cookies from 'js-cookie'
import Element from 'element-ui'
import './assets/styles/element-variables.scss'
import '@/assets/styles/index.scss' // global css
import '@/assets/styles/ruoyi.scss' // ruoyi 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'
import './assets/icons' // icon
import './permission' // permission control
import { getDicts } from "@/api/system/dict/data"
import { getConfigKey } from "@/api/system/config"
import { parseTime, resetForm, addDateRange, selectDictLabel, selectDictLabels, handleTree } 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 DictTag from '@/components/DictTag'
// 字典数据组件
import DictData from '@/components/DictData'
import * as XLSX from 'xlsx';
import { findAvailableService } from './utils/healthCheck'
import { setAxiosBaseUrl } from './utils/request'
 
Vue.prototype.$XLSX = XLSX; // 将 XLSX 添加到 Vue 的原型上,使其在所有组件中可用。
// 全局方法挂载
Vue.prototype.getDicts = getDicts
Vue.prototype.getConfigKey = getConfigKey
Vue.prototype.parseTime = parseTime
Vue.prototype.resetForm = resetForm
Vue.prototype.addDateRange = addDateRange
Vue.prototype.selectDictLabel = selectDictLabel
Vue.prototype.selectDictLabels = selectDictLabels
Vue.prototype.download = download
Vue.prototype.handleTree = handleTree
 
// 全局组件挂载
Vue.component('DictTag', DictTag)
Vue.component('Pagination', Pagination)
Vue.component('RightToolbar', RightToolbar)
Vue.component('Editor', Editor)
Vue.component('FileUpload', FileUpload)
Vue.component('ImageUpload', ImageUpload)
Vue.component('ImagePreview', ImagePreview)
 
Vue.use(directive)
Vue.use(plugins)
DictData.install()
 
// hiprint挂载
import Antd from 'ant-design-vue';
import 'ant-design-vue/dist/antd.css';
Vue.use(Antd);
 
import {hiPrintPlugin} from './hiprintVue/index'
Vue.use(hiPrintPlugin)
 
// 是否开启 socket.io 以启动客户端静默打印功能
hiPrintPlugin.disAutoConnect()
 
import Storage from 'vue-ls'
let options = {
  namespace: 'hiPrint-',
  name: 'ls',
  storage: 'local',
};
Vue.use(Storage, options);
/**
 * If you don't want to use mock-server
 * you want to use MockJs for mock api
 * you can execute: mockXHR()
 *
 * Currently MockJs will be used in the production environment,
 * please remove it before going online! ! !
 */
 
const initAPP = async () => {
  console.log("开始执行服务健康检查...");
  // 健康检查:获取可用的服务地址
  let availableBaseUrl = ""
  let sessionUrl = sessionStorage.getItem("cacheUrl")
  if(sessionUrl){
    console.log("使用缓存的地址: ", sessionUrl)
    availableBaseUrl = sessionUrl
  }else {
    sessionUrl = await findAvailableService();
    sessionStorage.setItem("cacheUrl", sessionUrl)
    availableBaseUrl = sessionUrl
  }
 
  // 注入 Axios 全局 baseURL
  setAxiosBaseUrl(availableBaseUrl);
  Vue.prototype.$baseUrl = availableBaseUrl
 
  Vue.use(Element, {
    size: Cookies.get('size') || 'medium' // set element-ui default size
  })
 
 
  Vue.config.productionTip = false
 
  new Vue({
    el: '#app',
    router,
    store,
    render: h => h(App)
  })
 
  //弹窗点击空白不消失
  Element.Dialog.props.closeOnClickModal.default = false
}
 
initAPP();