Merge remote-tracking branch 'origin/develop' into develop

This commit is contained in:
wangjian963
2026-05-20 09:46:29 +08:00
22 changed files with 675 additions and 534 deletions

View File

@@ -86,7 +86,7 @@
</template>
<el-table-column type="index" label="序号" width="60" align="center" />
<el-table-column prop="patientName" label="患者姓名" width="120" />
<el-table-column label="申请单名称" width="140">
<el-table-column label="申请单名称" min-width="140">
<template #default="scope">
<span>{{ buildApplicationName(scope.row) }}</span>
</template>
@@ -444,11 +444,9 @@ const buildApplicationName = (row) => {
if (!details || details.length === 0) {
return row.name || '-';
}
if (details.length === 1) {
return details[0].adviceName || row.name || '-';
}
const first = details[0];
return `${first.adviceName || ''}${details.length}`;
const names = details.map(d => d.adviceName).filter(Boolean);
if (names.length === 0) return row.name || '-';
return names.join(' + ');
};
/**

View File

@@ -529,7 +529,13 @@ const handleViewDetail = async (row) => {
if (row.descJson) {
try {
const obj = JSON.parse(row.descJson);
obj.targetDepartment = recursionFun(obj.targetDepartment);
// 将发往科室 ID 转换为名称
if (obj.targetDepartment) {
const deptName = recursionFun(obj.targetDepartment);
if (deptName) {
obj.targetDepartment = deptName;
}
}
// 转换申请类型编码为可读文本
if (obj.applicationType === 0) obj.applicationType = '普通';
else if (obj.applicationType === 1) obj.applicationType = '急诊';

View File

@@ -430,11 +430,52 @@ const loadEditData = () => {
const projectWithDepartment = (selectProjectIds) => {
if (!selectProjectIds || selectProjectIds.length === 0) {
form.targetDepartment = '';
return;
}
// 获取第一个选中项目的发往科室orgId
// 优先使用配置的发往科室,如果没有则保留手动选择
const selectedProject = applicationListAll.value?.find(
item => selectProjectIds.includes(item.adviceDefinitionId)
);
if (selectedProject && selectedProject.orgId) {
// 项目配置了发往科室,自动填充
const orgId = selectedProject.orgId;
const orgName = selectedProject.orgName;
// 查找树中对应的节点,获取正确的 id 类型
const findNode = (nodes, targetId) => {
if (!nodes) return null;
for (const node of nodes) {
if (String(node.id) === String(targetId)) {
return node;
}
if (node.children && node.children.length > 0) {
const found = findNode(node.children, targetId);
if (found) return found;
}
}
return null;
};
const treeNode = findNode(orgOptions.value, orgId);
if (treeNode) {
// 使用树节点的原始 id 值(确保类型匹配)
form.targetDepartment = treeNode.id;
} else {
// 科室不在列表中(可能已删除),留空让用户手动选择
form.targetDepartment = '';
}
}
// 如果没有配置发往科室,保留手动选择(不修改 form.targetDepartment
};
watch(() => transferValue.value, (newValue) => {
projectWithDepartment(newValue);
// 使用 nextTick 确保 DOM 更新完成后再设置值
nextTick(() => {
projectWithDepartment(newValue);
});
});
const getPriorityCode = () => {

View File

@@ -429,6 +429,8 @@ const props = defineProps({
});
const isAdding = ref(false);
const isSaving = ref(false);
// 标记双击编辑的是否为已有数据的行(用于保存后是否自动添加下一行)
const wasDoubleClickEdit = ref(false);
const prescriptionRef = ref();
const expandOrder = ref([]); //目前的展开行
const stockList = ref([]);
@@ -1397,7 +1399,9 @@ function handleSaveSign(row, index) {
}
});
} else {
if (prescriptionList.value[0].adviceName) {
// 仅通过【新增】按钮创建的医嘱保存后才自动添加下一行空医嘱
// 双击编辑已有"待保存"医嘱保存时,不应自动添加空行
if (isAdding.value && prescriptionList.value[0].adviceName) {
handleAddPrescription();
}
}