import App from './App.vue'; import router from './router'; import { setupStore } from '@/store'; import { getPlatformConfig } from './config'; import { MotionPlugin } from '@vueuse/motion'; import { registerVueEcharts } from '@/plugins/echarts'; import { createApp, type Directive } from 'vue'; import { useElementPlus } from '@/plugins/elementPlus'; import { injectResponsiveStorage } from '@/utils/responsive'; import { useAutoImport } from '@/components/AutoImport'; import Table from '@pureadmin/table'; // import PureDescriptions from "@pureadmin/descriptions"; // 引入重置样式 import './style/reset.scss'; // 导入公共样式 import './style/index.scss'; // 一定要在main.ts中导入tailwind.css,防止vite每次hmr都会请求src/style/index.scss整体css文件导致热更新慢的问题 import './style/tailwind.css'; import 'element-plus/dist/index.css'; // 导入字体图标 import './assets/iconfont/iconfont.js'; import './assets/iconfont/iconfont.css'; // github-markdown-css 全局md样式美化 import 'github-markdown-css/github-markdown.css'; const app = createApp(App); // 自定义指令 import * as directives from '@/directives'; Object.keys(directives).forEach((key) => { app.directive(key, (directives as { [key: string]: Directive })[key]); }); // 全局注册@iconify/vue图标库 import { IconifyIconOffline, IconifyIconOnline, FontIcon } from './components/ReIcon'; app.component('IconifyIconOffline', IconifyIconOffline); app.component('IconifyIconOnline', IconifyIconOnline); app.component('FontIcon', FontIcon); // 全局注册按钮级别权限组件 import { Auth } from '@/components/ReAuth'; import { Perms } from '@/components/RePerms'; app.component('Auth', Auth); app.component('Perms', Perms); // 全局注册vue-tippy import 'tippy.js/dist/tippy.css'; import 'tippy.js/themes/light.css'; import VueTippy from 'vue-tippy'; app.use(VueTippy); getPlatformConfig(app).then(async (config) => { setupStore(app); app.use(router); await router.isReady(); injectResponsiveStorage(app, config); app.use(MotionPlugin).use(useElementPlus).use(useAutoImport).use(Table); // .use(PureDescriptions) registerVueEcharts(app); app.mount('#app'); });