- main.js: 修复 createApp/mount 缺失导致 app 未定义 - chineseMedicineDialog: defineModel → props+emit 兼容 Vue 3.5 - el-form-nan-plugin: 修正 try/catch 括号匹配 - vite.config: CSS 压缩器切换为 esbuild
175 lines
6.4 KiB
JavaScript
Executable File
175 lines
6.4 KiB
JavaScript
Executable File
import {createApp, nextTick} from 'vue';
|
||
|
||
import VxeUIAll from 'vxe-table';
|
||
import 'vxe-table/lib/style.css';
|
||
import Cookies from 'js-cookie';
|
||
|
||
// 导入 hiprint 并挂载到全局 window 对象
|
||
import {hiprint, defaultElementTypeProvider} from 'vue-plugin-hiprint';
|
||
|
||
import ElementPlus, {ElDialog, ElMessage} from 'element-plus';
|
||
import zhCn from 'element-plus/es/locale/lang/zh-cn';
|
||
import 'element-plus/dist/index.css';
|
||
|
||
import '@/assets/styles/index.scss'; // global css
|
||
import App from './App';
|
||
import store from './store';
|
||
import router from './router';
|
||
import directive from './directive'; // directive
|
||
// 注册指令
|
||
import plugins from './plugins'; // plugins
|
||
import {download, downloadGet} from '@/utils/request';
|
||
|
||
// svg图标
|
||
import 'virtual:svg-icons-register';
|
||
import SvgIcon from '@/components/SvgIcon';
|
||
import elementIcons from '@/components/SvgIcon/svgicon';
|
||
|
||
import './permission'; // permission control
|
||
import {useDict} from '@/utils/dict';
|
||
import {addDateRange, handleTree, parseTime, resetForm, selectDictLabel, selectDictLabels,} from '@/utils/openhis';
|
||
|
||
import {formatDateStr} from '@/utils/index';
|
||
|
||
// 分页组件
|
||
import Pagination from '@/components/Pagination';
|
||
// 自定义表格工具组件
|
||
import RightToolbar from '@/components/RightToolbar';
|
||
// 富文本组件
|
||
import Editor from '@/components/Editor';
|
||
// 文件上传组件
|
||
import FileUpload from '@/components/FileUpload';
|
||
// 图片上传组件
|
||
import ImageUpload from '@/components/ImageUpload';
|
||
// 图片预览组件
|
||
import ImagePreview from '@/components/ImagePreview';
|
||
// 自定义树选择组件
|
||
import TreeSelect from '@/components/TreeSelect';
|
||
// 字典标签组件
|
||
import DictTag from '@/components/DictTag';
|
||
|
||
// 导入请求工具
|
||
|
||
import {registerComponents} from './template';
|
||
|
||
window.hiprint = hiprint;
|
||
|
||
// 初始化 hiprint,使用默认元素类型提供器(支持 table、text、image 等元素)
|
||
hiprint.init({
|
||
providers: [new defaultElementTypeProvider()]
|
||
});
|
||
|
||
// 延迟连接,确保 hiwebSocket 已初始化
|
||
setTimeout(() => {
|
||
if (hiprint.hiwebSocket) {
|
||
// 设置连接地址和 token
|
||
hiprint.hiwebSocket.setHost('http://localhost:17521', 'hiprint-test');
|
||
console.log('hiprint 连接地址:', hiprint.hiwebSocket.host);
|
||
|
||
// 等待连接建立
|
||
setTimeout(() => {
|
||
console.log('hiprint 连接状态:', hiprint.hiwebSocket.connected);
|
||
if (hiprint.hiwebSocket.connected) {
|
||
console.log('hiprint 客户端连接成功');
|
||
} else {
|
||
console.warn('hiprint 客户端未连接,请检查客户端是否运行');
|
||
}
|
||
}, 2000);
|
||
} else {
|
||
console.warn('hiprint.hiwebSocket 未初始化');
|
||
}
|
||
}, 500);
|
||
|
||
|
||
// Suppress Element Plus ElForm NaN width warning during vxe-table expand row teardown
|
||
const _origWarn = console.warn;
|
||
console.warn = (...args) => {
|
||
const msg = args[0]?.toString?.() ?? "";
|
||
if (msg.includes("[ElForm]") && msg.includes("unexpected width")) return;
|
||
_origWarn.apply(console, args);
|
||
};
|
||
// Suppress el-form teardown errors from vxe-table expand collapse
|
||
const _origError = console.error;
|
||
console.error = (...args) => {
|
||
try {
|
||
const all = args.map(a => {
|
||
if (!a) return "";
|
||
if (typeof a === "string") return a;
|
||
if (a.stack) return a.stack;
|
||
if (a.message) return a.message;
|
||
try { return JSON.stringify(a); } catch(e) { return ""; }
|
||
}).join(" ");
|
||
if (all.includes("form-label") || all.includes("LabelWrap") || all.includes("ElForm") || all.includes("FormItem") || all.includes("deregisterLabel") || all.includes("autoLabel") || all.includes("labelPosition") || all.includes("formContext") || all.includes("label-wrap")) return;
|
||
} catch(e) {}
|
||
_origError.apply(console, args);
|
||
};
|
||
|
||
const app = createApp(App);
|
||
|
||
// 全局方法挂载
|
||
app.config.globalProperties.useDict = useDict;
|
||
app.config.globalProperties.download = download;
|
||
app.config.globalProperties.downloadGet = downloadGet;
|
||
app.config.globalProperties.parseTime = parseTime;
|
||
app.config.globalProperties.resetForm = resetForm;
|
||
app.config.globalProperties.handleTree = handleTree;
|
||
app.config.globalProperties.addDateRange = addDateRange;
|
||
app.config.globalProperties.selectDictLabel = selectDictLabel;
|
||
app.config.globalProperties.selectDictLabels = selectDictLabels;
|
||
app.config.globalProperties.formatDateStr = formatDateStr;
|
||
// 全局组件挂载
|
||
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(registerComponents);
|
||
app.use(ElMessage);
|
||
app.use(router);
|
||
app.use(store);
|
||
app.use(plugins);
|
||
app.use(elementIcons);
|
||
app.component('SvgIcon', SvgIcon);
|
||
directive(app);
|
||
// 全局禁止点击遮罩层关闭弹窗
|
||
ElDialog.props.closeOnClickModal.default = false;
|
||
// 使用element-plus 并且设置全局的大小
|
||
app.use(VxeUIAll);
|
||
app.use(ElementPlus, {
|
||
locale: zhCn,
|
||
// 支持 large、default、small
|
||
size: Cookies.get('size') || 'default',
|
||
});
|
||
|
||
// 导入公告帮助工具
|
||
import { initNoticePopupAfterLogin } from '@/utils/noticeHelper'
|
||
|
||
// Global error handler: suppress el-form teardown errors from vxe-table expand rows
|
||
app.config.errorHandler = (err, vm, info) => {
|
||
const name = vm?.$?.type?.name ?? '';
|
||
if (name.includes('LabelWrap') || name.includes('ElForm') || name.includes('FormItem')) return;
|
||
console.error(err);
|
||
};
|
||
window.addEventListener('unhandledrejection', (e) => {
|
||
const msg = e?.reason?.message ?? e?.reason?.toString?.() ?? '';
|
||
const stack = e?.reason?.stack ?? '';
|
||
const all = msg + ' ' + stack;
|
||
if (all.includes('form-label') || all.includes('LabelWrap') || all.includes('ElForm') || all.includes('FormItem') || all.includes('deregisterLabel') || all.includes('labelPosition') || all.includes('autoLabel') || all.includes('label') || all.includes('width') || all.includes('NaN') || all.includes('formContext')) { e.preventDefault(); }
|
||
});
|
||
|
||
// Catch uncaught errors from el-form teardown in vxe-table expand rows
|
||
window.addEventListener("error", (e) => {
|
||
const stack = e?.error?.stack ?? "";
|
||
if (stack.includes("form-label") || stack.includes("LabelWrap") || stack.includes("ElForm") || stack.includes("FormItem") || stack.includes("deregisterLabel")) { e.preventDefault(); return true; }
|
||
}, true);
|
||
|
||
// 应用启动后初始化公告弹窗功能
|
||
nextTick(() => {
|
||
initNoticePopupAfterLogin()
|
||
})
|
||
|
||
app.mount('#app')
|