main.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. import App from "./App.vue";
  2. import router from "./router";
  3. import { setupStore } from "/@/store";
  4. import ElementPlus, { ElDialog } from "element-plus";
  5. import { getServerConfig } from "./config";
  6. import { createApp, Directive } from "vue";
  7. import { MotionPlugin } from "@vueuse/motion";
  8. import { useEcharts } from "/@/plugins/echarts";
  9. import VirtualScroller from "vue-virtual-scroller";
  10. import { useTable } from "../src/plugins/vxe-table";
  11. import { injectResponsiveStorage } from "/@/utils/responsive";
  12. import Table from "@pureadmin/table";
  13. import PureDescriptions from "@pureadmin/descriptions";
  14. import NoAuth from "./components/NoAuth/index";
  15. import PagePower from "./components/PagePower/index";
  16. import "uno.css";
  17. import "animate.css";
  18. // 引入重置样式
  19. import "./style/reset.scss";
  20. // 导入公共样式
  21. import "./style/index.scss";
  22. import "element-plus/dist/index.css";
  23. import "@pureadmin/components/dist/index.css";
  24. import "@pureadmin/components/dist/theme.css";
  25. // 导入字体图标
  26. import "./assets/iconfont/iconfont.js";
  27. import "./assets/iconfont/iconfont.css";
  28. import "v-contextmenu/dist/themes/default.css";
  29. import "vue-virtual-scroller/dist/vue-virtual-scroller.css";
  30. import "@wangeditor/editor/dist/css/style.css"; // 引入 css
  31. const app = createApp(App);
  32. registerEvent();
  33. ElDialog.props.closeOnClickModal = {
  34. type: Boolean,
  35. default: false
  36. }
  37. ElDialog.props.closeOnPressEscape = {
  38. type: Boolean,
  39. default: false
  40. }
  41. // 自定义指令
  42. import * as directives from "/@/directives";
  43. Object.keys(directives).forEach(key => {
  44. app.directive(key, (directives as { [key: string]: Directive })[key]);
  45. });
  46. // 全局注册`@iconify/vue`图标库
  47. import {
  48. IconifyIconOffline,
  49. IconifyIconOnline,
  50. FontIcon
  51. } from "./components/ReIcon";
  52. import { setupPageComponent } from "./plugins/globalComponent";
  53. import { registerEvent } from "/@/utils/watchToken";
  54. import { removeRelaComNo } from "./utils/auth";
  55. app.component("IconifyIconOffline", IconifyIconOffline);
  56. app.component("IconifyIconOnline", IconifyIconOnline);
  57. app.component("FontIcon", FontIcon);
  58. app.component("NoAuth", NoAuth);
  59. app.component("PagePower", PagePower);
  60. setupPageComponent(app);
  61. window.addEventListener("beforeunload", () => removeRelaComNo());
  62. getServerConfig(app).then(async config => {
  63. app.use(router);
  64. await router.isReady();
  65. injectResponsiveStorage(app, config);
  66. setupStore(app);
  67. app
  68. .use(MotionPlugin)
  69. .use(ElementPlus)
  70. .use(Table)
  71. .use(PureDescriptions)
  72. .use(useTable)
  73. .use(useEcharts)
  74. .use(VirtualScroller);
  75. app.mount("#app");
  76. });