From c116b3cd452dcb3de02935711a1ca3441382657d Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期一, 11 十一月 2024 14:36:50 +0800
Subject: [PATCH] update

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java |   25 +++++++++++++++++++++++++
 1 files changed, 25 insertions(+), 0 deletions(-)

diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java
index bc4b4ef..93a8719 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java
@@ -16,6 +16,7 @@
 import cn.lihu.jh.module.ecg.dal.mysql.room.RoomMapper;
 import cn.lihu.jh.module.ecg.enums.BedStatusEnum;
 import cn.lihu.jh.module.ecg.enums.QueueStatusEnum;
+import cn.lihu.jh.module.infra.api.config.ConfigApi;
 import cn.lihu.jh.module.system.api.oauth2.OAuth2TokenApi;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Component;
@@ -29,6 +30,7 @@
 
 import static cn.lihu.jh.framework.common.exception.util.ServiceExceptionUtil.exception;
 import static cn.lihu.jh.framework.common.pojo.CommonResult.error;
+import static cn.lihu.jh.module.ecg.Constants.*;
 import static cn.lihu.jh.module.ecg.enums.ErrorCodeConstants.*;
 
 /**
@@ -40,6 +42,9 @@
 @Validated
 @Slf4j
 public class QueueServiceTxFunctions {
+
+    @Resource
+    private ConfigApi configApi;
 
     @Resource
     private OAuth2TokenApi oAuth2TokenApi;
@@ -413,6 +418,22 @@
                 return;
             }
 
+            // 鎶㈠埌鎺掗槦鎮h�呭悗锛屽鐞� 妫�鏌ラ」鐩�.浜插拰鎬� 閫昏緫
+            QueueDO queueDO = queueMapper.getQueueItemBySeqNum(curSeqNum.get() + 1);
+            CheckTypeDO checkTypeDO = getCheckTypeItem( queueDO.getBookCheckType() );
+            if ( checkTypeDO.getAffinityCheckTypes().length > 0) {
+                List<QueueDO> affinityItems = queueMapper.getCurPatGivenCheckItems(queueDO.getPatId(), checkTypeDO.getAffinityCheckTypes());
+                for (int i = 0; i < affinityItems.size(); i++) {
+                    QueueDO queueItem = affinityItems.get(i);
+                    queueItem.setStatus(QueueStatusEnum.AFFINITY_ALREADY.getStatus()); //鏀瑰彉 鎺掗槦鐘舵��
+                    queueItem.setRoomId(queueItem.getRoomId());
+                    queueItem.setRoomName(queueItem.getRoomName());
+                    queueItem.setBedNo(queueItem.getBedNo());
+                    queueItem.setSeqNum(curSeqNum.get() + 1);  // 浣跨敤鍚屼竴涓� 鍐呴儴搴忓彿
+                    queueMapper.updateById(queueItem);
+                }
+            }
+
             curSeqNum.getAndIncrement();
 
             // 鍙兘宸茬粡銆愬苟鍙戠殑銆戝湪 nextPatient 涓敼鍙樹簡鍊�
@@ -436,6 +457,10 @@
         mapCheckTypeVsReadyMax = checkTypeDOList.stream().collect(Collectors.toMap(CheckTypeDO::getValue, checkType -> checkType));
     }
 
+    public CheckTypeDO getCheckTypeItem(Integer checkType) {
+        return mapCheckTypeVsReadyMax.get( checkType );
+    }
+
     public BedQueueBO getBedQueueBO(Long roomId, String bedNo) {
         return mapBedVsQueue.get( Utils.formatRoomBed(roomId, bedNo) );
     }

--
Gitblit v1.9.3