main.ts 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. import type { MainAppProps } from '#/main';
  2. import 'uno.css';
  3. import '/@/design/index.less';
  4. import 'ant-design-vue/dist/reset.css';
  5. // 注册图标
  6. import 'virtual:svg-icons-register';
  7. import App from './App.vue';
  8. import { createApp } from 'vue';
  9. import { initAppConfigStore } from '/@/logics/initAppConfig';
  10. import { setupErrorHandle } from '/@/logics/error-handle';
  11. import { router, createRouter, setupRouter } from '/@/router';
  12. import { setupRouterGuard } from '/@/router/guard';
  13. import { setupStore } from '/@/store';
  14. import { setupGlobDirectives } from '/@/directives';
  15. import { setupI18n } from '/@/locales/setupI18n';
  16. // import { setupElectron } from '@/electron';
  17. import { registerGlobComp } from '/@/components/registerGlobComp';
  18. import { registerThirdComp } from '/@/settings/registerThirdComp';
  19. // import { registerSuper } from '/@/views/super/registerSuper';
  20. import { useSso } from '/@/hooks/web/useSso';
  21. // import { checkIsQiankunMicro } from '/@/qiankun/micro';
  22. // import { autoUseQiankunMicro } from '/@/qiankun/micro/qiankunMicro';
  23. import { useAppStoreWithOut } from '@/store/modules/app';
  24. // 注册online模块lib
  25. import { registerPackages } from '/@/utils/monorepo/registerPackages';
  26. // 程序入口
  27. async function main() {
  28. // 获取参数
  29. const props = getMainAppProps();
  30. // 普通启动
  31. await bootstrap(props);
  32. }
  33. main();
  34. async function bootstrap(props?: MainAppProps) {
  35. // 创建应用实例
  36. const app = createApp(App);
  37. // 【QQYUN-6329】
  38. window['JAppRootInstance'] = app;
  39. // 创建路由
  40. createRouter();
  41. // 配置存储
  42. setupStore(app);
  43. // 配置参数
  44. setupProps(props);
  45. // 多语言配置,异步情况:语言文件可以从服务器端获得
  46. await setupI18n(app);
  47. // 初始化内部系统配置
  48. initAppConfigStore();
  49. // 注册外部模块路由(注册online模块lib)
  50. registerPackages(app);
  51. // 注册全局组件
  52. registerGlobComp(app);
  53. //CAS单点登录
  54. await useSso().ssoLogin();
  55. // 注册super应用路由
  56. // await registerSuper(app);
  57. // 配置路由
  58. setupRouter(app);
  59. // 路由保护
  60. setupRouterGuard(router);
  61. // 注册全局指令
  62. setupGlobDirectives(app);
  63. // 配置全局错误处理
  64. setupErrorHandle(app);
  65. // 注册第三方组件
  66. await registerThirdComp(app);
  67. // 配置electron
  68. // setupElectron(app)
  69. // 当路由准备好时再执行挂载( https://next.router.vuejs.org/api/#isready)
  70. await router.isReady();
  71. // 挂载应用
  72. app.mount(getMountContainer(props), true);
  73. console.log(' vue3 app 加载完成!');
  74. return app;
  75. }
  76. // 获取应用挂载容器
  77. function getMountContainer(props?: MainAppProps) {
  78. const id = '#app';
  79. if (!props?.container?.querySelector) {
  80. return id;
  81. }
  82. return props.container.querySelector(id) ?? id;
  83. }
  84. // 获取主应用参数
  85. function getMainAppProps(): MainAppProps {
  86. // 从 queryString 中获取
  87. const searchParams = new URLSearchParams(window.location.search);
  88. // 隐藏侧边栏(菜单)
  89. let hideSider = searchParams.get('hideSider') === 'true';
  90. // 隐藏顶部
  91. let hideHeader = searchParams.get('hideHeader') === 'true';
  92. // 隐藏 多Tab 切换
  93. let hideMultiTabs = searchParams.get('hideMultiTabs') === 'true';
  94. return {
  95. hideSider,
  96. hideHeader,
  97. hideMultiTabs,
  98. };
  99. }
  100. // 配置主应用参数
  101. function setupProps(props?: MainAppProps) {
  102. if (!props) {
  103. return;
  104. }
  105. const appStore = useAppStoreWithOut();
  106. appStore.setMainAppProps(props);
  107. }