main.ts 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. import 'uno.css';
  2. import '/@/design/index.less';
  3. //lxh
  4. import './assets/iconfong/iconfont.css';
  5. import './assets/iconfong/iconfont.js';
  6. import animate from 'animate.css';
  7. // 注册图标
  8. import 'virtual:svg-icons-register';
  9. import App from './App.vue';
  10. import { createApp } from 'vue';
  11. import { getRemoteSetting } from '/@/hooks/setting';
  12. import { initAppConfigStore } from '/@/logics/initAppConfig';
  13. import { setupErrorHandle } from '/@/logics/error-handle';
  14. import { router, setupRouter } from '/@/router';
  15. import { setupRouterGuard } from '/@/router/guard';
  16. import { setupStore } from '/@/store';
  17. import { setupGlobDirectives } from '/@/directives';
  18. import { setupI18n } from '/@/locales/setupI18n';
  19. import { registerGlobComp } from '/@/components/registerGlobComp';
  20. import { registerThirdComp } from '/@/settings/registerThirdComp';
  21. // 注册online模块lib
  22. // import { registerPackages } from '/@/utils/monorepo/registerPackages';
  23. import { initModalWorker, initTHREE } from '/@/utils/threejs/main.worker';
  24. import GlobalConfig from './components/config/GlobalConfig.vue';
  25. import { MODAL_TYPE } from '/@/enums/cacheEnum';
  26. // 在本地开发中引入的,以提高浏览器响应速度
  27. if (import.meta.env.DEV) {
  28. // @ts-ignore
  29. import('ant-design-vue/dist/antd.less');
  30. }
  31. await getRemoteSetting();
  32. async function bootstrap() {
  33. // 创建应用实例
  34. const app = createApp(App);
  35. app.use(animate);
  36. // 多语言配置,异步情况:语言文件可以从服务器端获得
  37. await setupI18n(app);
  38. // 配置存储
  39. setupStore(app);
  40. // 初始化内部系统配置
  41. initAppConfigStore();
  42. // 注册外部模块路由(注册online模块lib)
  43. // registerPackages(app);
  44. // 注册全局组件
  45. registerGlobComp(app);
  46. // 配置路由
  47. setupRouter(app);
  48. // 路由保护
  49. setupRouterGuard(router);
  50. // 注册全局指令
  51. setupGlobDirectives(app);
  52. // 配置全局错误处理
  53. setupErrorHandle(app);
  54. // 注册第三方组件
  55. await registerThirdComp(app);
  56. // 当路由准备好时再执行挂载( https://next.router.vuejs.org/api/#isready)
  57. await router.isReady();
  58. initModalWorker();
  59. initTHREE();
  60. app.component('GlobalConfig', GlobalConfig);
  61. app.provide('globalConfig', {
  62. // 你的全局配置
  63. simulatedPassword: VENT_PARAM['simulatedPassword'],
  64. History_Type: History_Type['type'],
  65. pageType: '',
  66. showReport: VENT_PARAM['showReport'],
  67. is2DModel: localStorage.getItem(MODAL_TYPE) == 'false' ? false : true,
  68. });
  69. // 挂载应用
  70. app.mount('#app', true);
  71. console.log(' vue3 app 加载完成!');
  72. }
  73. bootstrap();