12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- import App from "./App.vue";
- import router from "./router";
- import { setupStore } from "@/store";
- import { getPlatformConfig } from "./config";
- import { MotionPlugin } from "@vueuse/motion";
- // import { useEcharts } from "@/plugins/echarts";
- import { createApp, type Directive } from "vue";
- import { useElementPlus } from "@/plugins/elementPlus";
- import * as echarts from "echarts";
- import { injectResponsiveStorage } from "@/utils/responsive";
- import * as ElementPlusIconsVue from "@element-plus/icons-vue";
- import Table from "@pureadmin/table";
- // import PureDescriptions from "@pureadmin/descriptions";
- // 控制台被动监听警告
- import "default-passive-events";
- // 引入重置样式
- 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";
- const app = createApp(App);
- for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
- app.component(key, component);
- }
- // 自定义指令
- 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";
- app.component("Auth", Auth);
- // 全局注册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.config.globalProperties.$echarts = echarts;
- app.use(MotionPlugin).use(useElementPlus).use(Table);
- // .use(PureDescriptions)
- // .use(useEcharts);
- app.mount("#app");
- });
|