main.ts 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. import App from "./App.vue";
  2. import router from "./router";
  3. import { setupStore } from "@/store";
  4. import { getPlatformConfig } from "./config";
  5. import { MotionPlugin } from "@vueuse/motion";
  6. // import { useEcharts } from "@/plugins/echarts";
  7. import { createApp, type Directive } from "vue";
  8. import { useElementPlus } from "@/plugins/elementPlus";
  9. import * as echarts from "echarts";
  10. import { injectResponsiveStorage } from "@/utils/responsive";
  11. import * as ElementPlusIconsVue from "@element-plus/icons-vue";
  12. import Table from "@pureadmin/table";
  13. // import PureDescriptions from "@pureadmin/descriptions";
  14. // 控制台被动监听警告
  15. import "default-passive-events";
  16. // 引入重置样式
  17. import "./style/reset.scss";
  18. // 导入公共样式
  19. import "./style/index.scss";
  20. // 一定要在main.ts中导入tailwind.css,防止vite每次hmr都会请求src/style/index.scss整体css文件导致热更新慢的问题
  21. import "./style/tailwind.css";
  22. import "element-plus/dist/index.css";
  23. // 导入字体图标
  24. import "./assets/iconfont/iconfont.js";
  25. import "./assets/iconfont/iconfont.css";
  26. const app = createApp(App);
  27. for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  28. app.component(key, component);
  29. }
  30. // 自定义指令
  31. import * as directives from "@/directives";
  32. Object.keys(directives).forEach(key => {
  33. app.directive(key, (directives as { [key: string]: Directive })[key]);
  34. });
  35. // 全局注册@iconify/vue图标库
  36. import {
  37. IconifyIconOffline,
  38. IconifyIconOnline,
  39. FontIcon
  40. } from "./components/ReIcon";
  41. app.component("IconifyIconOffline", IconifyIconOffline);
  42. app.component("IconifyIconOnline", IconifyIconOnline);
  43. app.component("FontIcon", FontIcon);
  44. // 全局注册按钮级别权限组件
  45. import { Auth } from "@/components/ReAuth";
  46. app.component("Auth", Auth);
  47. // 全局注册vue-tippy
  48. import "tippy.js/dist/tippy.css";
  49. import "tippy.js/themes/light.css";
  50. import VueTippy from "vue-tippy";
  51. app.use(VueTippy);
  52. getPlatformConfig(app).then(async config => {
  53. setupStore(app);
  54. app.use(router);
  55. await router.isReady();
  56. injectResponsiveStorage(app, config);
  57. app.config.globalProperties.$echarts = echarts;
  58. app.use(MotionPlugin).use(useElementPlus).use(Table);
  59. // .use(PureDescriptions)
  60. // .use(useEcharts);
  61. app.mount("#app");
  62. });