确保username参数存在,避免因为空值造成接口调用失败 feat(editor): 重构富文本编辑器组件并优化图片上传逻辑 - 使用 Composition API 重构代码结构,提升可维护性 - 改进图片上传功能,增强对 quill 实例的安全访问 - 更新样式排版,提高组件可读性和一致性 refactor(file-upload): 移除旧代理引用,使用 modern Vue API 替换 `proxy` 调用为 `modal` 插件直接调用,提升代码清晰度与健壮性 refactor(image-upload): 替换旧实例调用方式,强化错误提示机制 统一使用 `modal` 进行消息提示和加载状态控制,改善用户体验 refactor(tree-select): 引入 Composition API 优化节点操作逻辑 移除 `getCurrentInstance` 的不必要使用,改为明确的模板引用管理 chore(main): 添加 util._extend 补丁以消除 Node.js 环境警告 解决开发环境下由于 Node.js 内建模块缺失造成的运行时警告问题 feat(template): 完善跌倒/坠床评估护理记录单模板 - 增加详细注释说明各部分作用,便于后续维护 - 明确组件名称为中文,利于业务识别 - 丰富表单交互细节及数据处理逻辑,支持动态打分、措施选择等功能 refactor(template-index): 加强模板组件自动注册逻辑 增加组件 name 属性校验,防止无效或匿名组件被注册到全局
123 lines
3.8 KiB
JavaScript
123 lines
3.8 KiB
JavaScript
import { createApp } from 'vue'
|
||
|
||
// 修复 util._extend 已弃用警告(仅在 Node.js 环境中需要)
|
||
if (typeof process !== 'undefined' && process.versions && process.versions.node) {
|
||
try {
|
||
import('util').then(util => {
|
||
if (!util._extend) {
|
||
util._extend = function(destination, source) {
|
||
for (var key in source) {
|
||
if (source.hasOwnProperty(key)) {
|
||
destination[key] = source[key];
|
||
}
|
||
}
|
||
return destination;
|
||
};
|
||
}
|
||
});
|
||
} catch (e) {
|
||
console.error('util._extend 补丁加载失败:', e);
|
||
}
|
||
}
|
||
|
||
import Cookies from 'js-cookie'
|
||
|
||
import ElementPlus 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 { parseTime, resetForm, addDateRange, handleTree, 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 request from './utils/request'
|
||
|
||
import { ElDialog, ElMessage } from 'element-plus';
|
||
|
||
import {registerComponents} from './template';
|
||
const app = createApp(App);
|
||
|
||
if(chrome.webview !== undefined) {
|
||
// 如果是webview环境,挂载CSharpAccessor对象到vue实例上
|
||
const csAccessor = chrome.webview.hostObjects.CSharpAccessor;
|
||
app.config.globalProperties.csAccessor = csAccessor;
|
||
}
|
||
|
||
// 全局方法挂载
|
||
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.config.globalProperties.$http = request
|
||
// 全局组件挂载
|
||
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)
|
||
// 使用element-plus 并且设置全局的大小
|
||
app.use(ElementPlus, {
|
||
locale: zhCn,
|
||
// 支持 large、default、small
|
||
size: Cookies.get('size') || 'default'
|
||
})
|
||
app.use(ElMessage)
|
||
app.use(registerComponents)
|
||
app.use(router)
|
||
app.use(store)
|
||
app.use(plugins)
|
||
app.use(elementIcons)
|
||
app.component('svg-icon', SvgIcon)
|
||
directive(app)
|
||
// 全局禁止点击遮罩层关闭弹窗
|
||
ElDialog.props.closeOnClickModal.default = false;
|
||
|
||
app.mount('#app') |