60 lines
1.8 KiB
TypeScript
60 lines
1.8 KiB
TypeScript
import App from "./App.vue";
|
||
import router from "./router";
|
||
import { setupStore } from "@/store";
|
||
import ElementPlus from "element-plus";
|
||
import { getServerConfig } from "./config";
|
||
import { createApp, Directive } from "vue";
|
||
import { MotionPlugin } from "@vueuse/motion";
|
||
// import { useEcharts } from "@/plugins/echarts";
|
||
import { injectResponsiveStorage } from "@/utils/responsive";
|
||
|
||
// import Table from "@pureadmin/table";
|
||
// import PureDescriptions from "@pureadmin/descriptions";
|
||
|
||
// 引入自定义字体
|
||
import "./assets/fonts/index.scss";
|
||
// 引入重置样式
|
||
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);
|
||
|
||
// 自定义指令
|
||
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);
|
||
|
||
getServerConfig(app).then(async config => {
|
||
app.use(router);
|
||
await router.isReady();
|
||
injectResponsiveStorage(app, config);
|
||
setupStore(app);
|
||
app.use(MotionPlugin).use(ElementPlus);
|
||
// .use(useEcharts);
|
||
// .use(Table);
|
||
// .use(PureDescriptions);
|
||
app.mount("#app");
|
||
});
|