Fix Bug #476: 住院医生工作-检查申请单界面缺失核心临床字段(紧急程度、过敏史、检查目的等)

详情弹窗和打印功能缺少紧急程度、过敏史、检查目的、期望检查时间、病史摘要等字段显示。
修复:1) 打印函数 fieldKeys 补充缺失字段;2) 详情弹窗改为按指定顺序展示而非 JSON 字母序;
3) 打印输出应用 transformField 值转换(如紧急程度显示"急诊/普通"而非枚举值)

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
赵云
2026-05-16 19:24:09 +08:00
parent d89128ec54
commit 19cd4a87d4

View File

@@ -179,11 +179,14 @@
<div v-if="descJsonData && hasMatchedFields" class="applicationShow-container-content"> <div v-if="descJsonData && hasMatchedFields" class="applicationShow-container-content">
<el-descriptions title="申请单描述" :column="2"> <el-descriptions title="申请单描述" :column="2">
<template v-for="(value, key) in descJsonData" :key="key"> <el-descriptions-item
<el-descriptions-item v-if="isFieldMatched(key)" :label="getFieldLabel(key)"> v-for="key in orderedDescFieldKeys"
{{ transformField(key, value) || '-' }} :key="key"
</el-descriptions-item> v-if="descJsonData[key] != null && descJsonData[key] !== ''"
</template> :label="getFieldLabel(key)"
>
{{ transformField(key, descJsonData[key]) || '-' }}
</el-descriptions-item>
</el-descriptions> </el-descriptions>
</div> </div>
@@ -511,6 +514,13 @@ const hasMatchedFields = computed(() => {
return Object.keys(descJsonData.value).some((key) => isFieldMatched(key)); return Object.keys(descJsonData.value).some((key) => isFieldMatched(key));
}); });
// Ordered field keys for detail display and print, matching the bug requirement order
const orderedDescFieldKeys = [
'targetDepartment', 'urgencyLevel', 'allergyHistory', 'examinationPurpose',
'expectedExaminationTime', 'medicalHistorySummary', 'symptom', 'sign',
'clinicalDiagnosis', 'otherDiagnosis', 'relatedResult', 'attention',
];
/** 查询科室 */ /** 查询科室 */
const getLocationInfo = async () => { const getLocationInfo = async () => {
try { try {
@@ -679,15 +689,16 @@ const handlePrint = async (row) => {
} }
// 构建 descJson 字段行(与详情弹窗展示的字段一致) // 构建 descJson 字段行(与详情弹窗展示的字段一致)
const fieldKeys = ['targetDepartment', 'symptom', 'sign', 'clinicalDiagnosis', 'otherDiagnosis', 'relatedResult', 'attention']; const fieldKeys = orderedDescFieldKeys;
let descFieldsHtml = ''; let descFieldsHtml = '';
fieldKeys.forEach((key) => { fieldKeys.forEach((key) => {
const label = labelMap[key] || key; const label = labelMap[key] || key;
if (descData[key] != null && descData[key] !== '') { const value = transformField(key, descData[key]);
if (descData[key] != null && descData[key] !== '' && value != null && value !== '') {
descFieldsHtml += ` descFieldsHtml += `
<div class="info-row"> <div class="info-row">
<span class="label">${label}</span> <span class="label">${label}</span>
<span class="value">${descData[key]}</span> <span class="value">${value}</span>
</div>`; </div>`;
} }
}); });