YZProjectCloud/yanzhu-ui-vue3/src/main.js

139 lines
4.1 KiB
JavaScript
Raw Normal View History

2025-04-25 23:14:21 +08:00
import { createApp } from "vue";
2024-08-17 12:11:19 +08:00
2025-04-25 23:14:21 +08:00
import Cookies from "js-cookie";
2024-08-17 12:11:19 +08:00
2025-04-25 23:14:21 +08:00
import ElementPlus from "element-plus";
import locale from "element-plus/es/locale/lang/zh-cn";
import "element-plus/theme-chalk/index.css";
import "@/assets/styles/index.scss"; // global css
2024-08-17 12:11:19 +08:00
2025-04-25 23:14:21 +08:00
import App from "./App";
import store from "./store";
import router from "./router";
import directive from "./directive"; // directive
2024-08-17 12:11:19 +08:00
// 注册指令
2025-04-25 23:14:21 +08:00
import plugins from "./plugins"; // plugins
import { download } from "@/utils/request";
2024-08-17 12:11:19 +08:00
// svg图标
2025-04-25 23:14:21 +08:00
import "virtual:svg-icons-register";
import SvgIcon from "@/components/SvgIcon";
import elementIcons from "@/components/SvgIcon/svgicon";
2024-08-17 12:11:19 +08:00
2025-04-25 23:14:21 +08:00
import "./permission"; // permission control
2024-08-17 12:11:19 +08:00
2025-04-25 23:14:21 +08:00
import { useDict } from "@/utils/dict";
import {
parseTime,
resetForm,
addDateRange,
formatDuraDate,
formatDuraTime,
handleTree,
selectDictLabel,
selectDictLabels,
} from "@/utils/ruoyi";
import request from "@/utils/request";
2024-08-17 12:11:19 +08:00
// 分页组件
2025-04-25 23:14:21 +08:00
import Pagination from "@/components/Pagination";
2024-08-17 12:11:19 +08:00
// 自定义表格工具组件
2025-04-25 23:14:21 +08:00
import RightToolbar from "@/components/RightToolbar";
2024-08-17 12:11:19 +08:00
// 富文本组件
2025-04-25 23:14:21 +08:00
import Editor from "@/components/Editor";
2024-08-17 12:11:19 +08:00
// 文件上传组件
2025-04-25 23:14:21 +08:00
import FileUpload from "@/components/FileUpload";
2024-08-17 12:11:19 +08:00
// 图片上传组件
2025-04-25 23:14:21 +08:00
import ImageUpload from "@/components/ImageUpload";
2024-08-17 12:11:19 +08:00
// 图片预览组件
2025-04-25 23:14:21 +08:00
import ImagePreview from "@/components/ImagePreview";
2024-08-17 12:11:19 +08:00
// 自定义树选择组件
2025-04-25 23:14:21 +08:00
import TreeSelect from "@/components/TreeSelect";
2024-08-17 12:11:19 +08:00
// 字典标签组件
2025-04-25 23:14:21 +08:00
import DictTag from "@/components/DictTag";
2024-08-24 11:53:56 +08:00
// Vue3表单组件
2025-04-25 23:14:21 +08:00
import VForm3 from "@/lib/vform/designer.umd.js";
import "@/lib/vform/designer.style.css";
import dayjs from "dayjs";
import { notification, message, Modal } from "ant-design-vue";
const app = createApp(App);
notification.config({
placement: "topLeft",
bottom: "50px",
top: "50px",
duration: 3,
});
2024-08-17 12:11:19 +08:00
// 全局方法挂载
2025-04-25 23:14:21 +08:00
app.config.globalProperties.$confirm = Modal.confirm;
app.config.globalProperties.$message = message;
app.config.globalProperties.$notification = notification;
app.config.globalProperties.$info = Modal.info;
app.config.globalProperties.$success = Modal.success;
app.config.globalProperties.$error = Modal.error;
app.config.globalProperties.$warning = Modal.warning;
app.config.globalProperties.useDict = useDict;
app.config.globalProperties.download = download;
app.config.globalProperties.parseTime = parseTime;
app.config.globalProperties.resetForm = resetForm;
app.config.globalProperties.handleTree = handleTree;
app.config.globalProperties.addDateRange = addDateRange;
app.config.globalProperties.formatDuraDate = formatDuraDate;
app.config.globalProperties.formatDuraTime = formatDuraTime;
app.config.globalProperties.selectDictLabel = selectDictLabel;
app.config.globalProperties.selectDictLabels = selectDictLabels;
app.config.globalProperties.$tryToJson = (str, df) => {
try {
if (!str) {
return df || {};
2024-10-10 00:34:39 +08:00
}
2025-04-25 23:14:21 +08:00
return JSON.parse(str) || df || {};
} catch {
return df || {};
2024-10-10 00:34:39 +08:00
}
2025-04-25 23:14:21 +08:00
};
app.config.globalProperties.$dt = dayjs;
app.config.globalProperties.$formatDate = dt=>{
return dt?dayjs(dt).format("YYYY-MM-DD"):"" ;
};
app.config.globalProperties.$formatDateTime = dt=>{
return dt?dayjs(dt).format("YYYY-MM-DD HH:mm:ss"):"" ;
};
app.config.globalProperties.$formatTime = dt=>{
return dt?dayjs(dt).format("HH:mm:ss"):"" ;
};
2025-06-25 18:43:53 +08:00
app.config.globalProperties.$formatTime = dt=>{
return dt?dayjs(dt).format("HH:mm:ss"):"" ;
};
2025-04-25 23:14:21 +08:00
app.config.globalProperties.$http = request;
2024-08-17 12:11:19 +08:00
// 全局组件挂载
2025-04-25 23:14:21 +08:00
app.component("DictTag", DictTag);
app.component("Pagination", Pagination);
app.component("TreeSelect", TreeSelect);
app.component("FileUpload", FileUpload);
app.component("ImageUpload", ImageUpload);
app.component("ImagePreview", ImagePreview);
app.component("RightToolbar", RightToolbar);
app.component("Editor", Editor);
app.use(router);
app.use(store);
app.use(plugins);
app.use(elementIcons);
2024-08-24 11:53:56 +08:00
// 全局注册VForm3同时注册了v-form-designer、v-form-render等组件
2025-04-25 23:14:21 +08:00
app.use(VForm3);
app.component("svg-icon", SvgIcon);
2024-08-17 12:11:19 +08:00
2025-04-25 23:14:21 +08:00
directive(app);
2024-08-17 12:11:19 +08:00
// 使用element-plus 并且设置全局的大小
app.use(ElementPlus, {
locale: locale,
// 支持 large、default、small
2025-04-25 23:14:21 +08:00
size: Cookies.get("size") || "default",
});
2024-08-17 12:11:19 +08:00
2025-04-25 23:14:21 +08:00
app.mount("#app");