dengzedong
2024-10-10 b45bad33154fb97b76e6c54a86609d446f02ad21
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
// 引入unocss css
import '@/plugins/unocss'
 
// 导入全局的svg图标
import '@/plugins/svgIcon'
 
// 初始化多语言
import { setupI18n } from '@/plugins/vueI18n'
 
// 引入状态管理
import { setupStore } from '@/store'
 
// 全局组件
import { setupGlobCom } from '@/components'
 
// 引入 element-plus
import { setupElementPlus } from '@/plugins/elementPlus'
 
// 引入 form-create
import { setupFormCreate } from '@/plugins/formCreate'
 
// 引入全局样式
import '@/styles/index.scss'
 
// 引入动画
import '@/plugins/animate.css'
 
// 路由
import router, { setupRouter } from '@/router'
 
// 权限
import { setupAuth } from '@/directives'
 
import { createApp } from 'vue'
 
import App from './App.vue'
 
import './permission'
 
import '@/plugins/tongji' // 百度统计
import Logger from '@/utils/Logger'
 
import VueDOMPurifyHTML from 'vue-dompurify-html' // 解决v-html 的安全隐患
 
import WujieVue from 'wujie-vue3'
 
const { setupApp } = WujieVue
 
import { micros, getUrl } from '@/utils/micors'
 
import lifecycles from '@/utils/lifecycles' // 生命周期函数
 
// 创建实例
const setupAll = async () => {
  const app = createApp(App)
 
  await setupI18n(app)
 
  setupStore(app)
 
  setupGlobCom(app)
 
  setupElementPlus(app)
 
  setupFormCreate(app)
 
  setupRouter(app)
 
  setupAuth(app)
 
  await router.isReady()
 
  app.use(VueDOMPurifyHTML)
 
  app.use(WujieVue)
 
  app.mount('#app')
}
 
setupAll()
 
// 模拟接口查询,实现动动态子应用加载与动态路由添加
const setMiro = () =>
  new Promise((resolve) => {
    for (const value of micros) {
      const obj: any = {
        path: `/${value.name}`,
        name: value.name,
        component: () => import(`@/views/micro/index.vue`)
      }
      router.addRoute('home', obj)
      setupApp({
        name: value.name,
        url: getUrl(value.name, micros),
        exec: true,
        ...lifecycles
      })
    }
    resolve(true)
  })
// eslint-disable-next-line require-await
router.beforeEach(async (to, _from, next) => {
  if (router.getRoutes().length <= 3) {
    // 如果路由个数为基础路由,则说明没有进行路由和子应用添加,需要动态添加,添加完成,根据路由地址进行跳转
    await setMiro()
    next({
      path: to.path,
      query: { ...to.query }
    })
  } else {
    next()
  }
})
 
Logger.prettyPrimary(`欢迎使用`, import.meta.env.VITE_APP_TITLE)