Blame view

src/main.ts 1.65 KB
vben authored
1
import '/@/design/index.less';
2
3
4

// Register windi
import 'virtual:windi.css';
5
6
// Register icon sprite
import 'virtual:svg-icons-register';
vben authored
7
import App from './App.vue';
Vben authored
8
import { createApp } from 'vue';
9
import { initAppConfigStore } from '/@/logics/initAppConfig';
10
import { setupErrorHandle } from '/@/logics/error-handle';
Vben authored
11
import { router, setupRouter } from '/@/router';
Vben authored
12
import { setupRouterGuard } from '/@/router/guard';
陈文彬 authored
13
import { setupStore } from '/@/store';
vben authored
14
import { setupGlobDirectives } from '/@/directives';
vben authored
15
16
import { setupI18n } from '/@/locales/setupI18n';
import { registerGlobComp } from '/@/components/registerGlobComp';
vben authored
17
18
19
// Do not introduce on-demand in local development?
// In the local development for introduce on-demand, the number of browser requests will increase by about 20%.
20
21
22
23
24
25
// Which may slow down the browser refresh.
// Therefore, all are introduced in local development, and only introduced on demand in the production environment
if (import.meta.env.DEV) {
  import('ant-design-vue/dist/antd.less');
}
vben authored
26
async function bootstrap() {
27
  const app = createApp(App);
Vben authored
28
29
  // Configure store
Vben authored
30
31
  setupStore(app);
32
  // Initialize internal system configuration
33
34
  initAppConfigStore();
35
36
  // Register global components
  registerGlobComp(app);
vben authored
37
Vben authored
38
39
40
  // Multilingual configuration
  await setupI18n(app);
41
42
  // Configure routing
  setupRouter(app);
vben authored
43
Vben authored
44
  // router-guard
45
  setupRouterGuard(router);
vben authored
46
47
48
  // Register global directive
  setupGlobDirectives(app);
陈文彬 authored
49
50
51
  // Configure global error handling
  setupErrorHandle(app);
陈文彬 authored
52
53
  // Mount when the route is ready
Vben authored
54
  // https://next.router.vuejs.org/api/#isready
Vben authored
55
  await router.isReady();
vben authored
56
57
  app.mount('#app', true);
vben authored
58
59
60
}

void bootstrap();