main.ts 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import App from "./App.vue";
  2. import router from "./router";
  3. import { setupStore } from "@/store";
  4. import ElementPlus from "element-plus";
  5. import { useI18n } from "@/plugins/i18n";
  6. import { getServerConfig } from "./config";
  7. import { createApp, Directive } from "vue";
  8. import { MotionPlugin } from "@vueuse/motion";
  9. import { useEcharts } from "@/plugins/echarts";
  10. import { useTable } from "@/plugins/vxe-table";
  11. import { injectResponsiveStorage } from "@/utils/responsive";
  12. import Table from "@pureadmin/table";
  13. import PureDescriptions from "@pureadmin/descriptions";
  14. // 引入重置样式
  15. import "./style/reset.scss";
  16. // 导入公共样式
  17. import "./style/index.scss";
  18. import "element-plus/dist/index.css";
  19. // 导入字体图标
  20. import "./assets/iconfont/iconfont.js";
  21. import "./assets/iconfont/iconfont.css";
  22. const app = createApp(App);
  23. // 自定义指令
  24. import * as directives from "@/directives";
  25. Object.keys(directives).forEach(key => {
  26. app.directive(key, (directives as { [key: string]: Directive })[key]);
  27. });
  28. // 全局注册`@iconify/vue`图标库
  29. import {
  30. IconifyIconOffline,
  31. IconifyIconOnline,
  32. FontIcon
  33. } from "./components/ReIcon";
  34. app.component("IconifyIconOffline", IconifyIconOffline);
  35. app.component("IconifyIconOnline", IconifyIconOnline);
  36. app.component("FontIcon", FontIcon);
  37. // 全局注册按钮级别权限组件
  38. import { Auth } from "@/components/ReAuth";
  39. app.component("Auth", Auth);
  40. getServerConfig(app).then(async config => {
  41. app.use(router);
  42. await router.isReady();
  43. injectResponsiveStorage(app, config);
  44. setupStore(app);
  45. app
  46. .use(MotionPlugin)
  47. .use(useI18n)
  48. .use(ElementPlus)
  49. .use(Table)
  50. .use(PureDescriptions)
  51. .use(useTable)
  52. .use(useEcharts);
  53. app.mount("#app");
  54. });