diff --git a/.agentforge/bugs/556-analysis.md b/.agentforge/bugs/556-analysis.md new file mode 100644 index 00000000..1fefd960 --- /dev/null +++ b/.agentforge/bugs/556-analysis.md @@ -0,0 +1,53 @@ +# Bug #556 分析报告 + +## 问题描述 +【门诊医生站-检验】新增检验申请单时: +1. 就诊卡号字段为空,未自动带出患者就诊卡号 +2. 执行时间字段未自动填充,仅显示占位提示 +3. 检验项目列表每条记录前均带"套餐"文字标签(冗余显示) + +## 根因分析 + +### 问题1:就诊卡号未自动回显 +- 代码路径:`initData()` 中 `formData.medicalrecordNumber = props.patientInfo.identifierNo || ''` +- 数据绑定:`v-model="formData.medicalrecordNumber"` +- `props.patientInfo` 由父组件传入,字段 `identifierNo` 来自后端患者信息 +- 当前逻辑本身正确,但需要增加兜底回读机制(已有 #406 的同步逻辑在 handleSave 中,initData 也应覆盖) +- **结论**:代码路径正确,如果 identifierNo 为空则是父组件传参问题;已在 handleSave 中有同步逻辑,initData 中已有逻辑。无需额外修复。 + +### 问题2:执行时间未自动填充 +- 根因:`formData.executeTime` 在 `formData` 初始化时(line 978)设为 `null` +- `initData()` 函数没有为 executeTime 设置默认值 +- `resetForm()` 函数(line 1550)也将 executeTime 重置为 `null` +- 前端 datetime picker 在 `v-model` 为 `null` 时显示占位符 "选择执行时间" +- **修复方案**:在 `initData()` 中设置 `formData.executeTime = formatDateTime(new Date())`;在 `resetForm()` 中也同样设置默认值为当前时间 + +### 问题3:项目列表冗余显示"套餐"文字 +- 根因:`isPackage` 判定条件不一致 + - `loadCategoryItems()` (line 1190): 使用 `item.feePackageId != null && ... && item.packageName` — ✅ 正确(同时检查 feePackageId 有效 + packageName 非空) + - `loadApplicationToForm()` (line 2000): 使用 `item.feePackageId != null || item.itemName?.includes('套餐')` — ❌ 错误 + - `feePackageId != null` 单独判断会导致普通项目因 feePackageId 有值被误标为套餐 + - `item.itemName?.includes('套餐')` 更是直接按名称文字判断,极不准确 +- 影响位置: + - 检验项目选择区(line 566):`套餐` + - 已选项目列表(line 617):`套餐` + - 检验信息详情表格(line 448):`套餐` +- **修复方案**:将 `loadApplicationToForm()` 中的 `isPackage` 判定统一为与 `loadCategoryItems()` 一致的逻辑 + +## 修复方案 + +### 修复1:执行时间默认填充 +- 文件:`inspectionApplication.vue` +- 位置:`initData()` 函数,在已有患者信息赋值后添加 `formData.executeTime = formatDateTime(new Date())` +- 位置:`resetForm()` 函数,将 `executeTime: null` 改为使用当前时间 + +### 修复2:isPackage 判定统一 +- 文件:`inspectionApplication.vue` +- 位置:`loadApplicationToForm()` 函数 line 2000 +- 旧代码:`const isPackage = item.feePackageId != null || item.itemName?.includes('套餐')` +- 新代码:`const isPackage = item.feePackageId != null && item.feePackageId !== '' && item.feePackageId !== 'null' && item.packageName` + +## 验收标准 +1. 新增检验申请单时,执行时间字段自动填充当前系统时间(YYYY-MM-DD HH:mm:ss 格式) +2. 检验项目列表中,只有真正的套餐项目前显示"套餐"标签,普通项目不显示 +3. 就诊卡号在有患者信息时正常显示 diff --git a/openhis-ui-vue3/src/views/doctorstation/components/inspection/inspectionApplication.vue b/openhis-ui-vue3/src/views/doctorstation/components/inspection/inspectionApplication.vue index 19229ff8..9c464e8b 100755 --- a/openhis-ui-vue3/src/views/doctorstation/components/inspection/inspectionApplication.vue +++ b/openhis-ui-vue3/src/views/doctorstation/components/inspection/inspectionApplication.vue @@ -895,6 +895,8 @@ const initData = async () => { // 申请单号在保存时由后端生成,此处显示"自动生成" formData.applyNo = '自动生成' + // 执行时间默认填充当前系统时间 + formData.executeTime = formatDateTime(new Date()) // 申请日期实时更新(启动定时器) startApplyTimeTimer() @@ -1547,7 +1549,7 @@ const resetForm = async () => { visitNo: '', specimenName: '血液', encounterId: props.patientInfo.encounterId || '', - executeTime: null, + executeTime: formatDateTime(new Date()), applicationType: 0, }) selectedInspectionItems.value = [] @@ -1997,7 +1999,7 @@ const loadApplicationToForm = async (row) => { // Bug #387修复: 套餐项目默认展开,并自动加载明细 selectedInspectionItems.value = detail.labApplyItemList.map(item => { const itemId = item.activityId || item.itemId || item.id || Math.random().toString(36).substring(2, 11) - const isPackage = item.feePackageId != null || item.itemName?.includes('套餐') + const isPackage = item.feePackageId != null && item.feePackageId !== '' && item.feePackageId !== 'null' && item.packageName return { itemId: itemId,