You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

62 lines
1.9 KiB

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