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,