From c48f179be89343dc1620bfa147433bfe87d9bed3 Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期一, 11 十一月 2024 17:29:50 +0800
Subject: [PATCH] 检查项-亲和性处理

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queue/QueueServiceTxFunctions.java |   59 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 59 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..166034f 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;
@@ -40,6 +41,9 @@
 @Validated
 @Slf4j
 public class QueueServiceTxFunctions {
+
+    @Resource
+    private ConfigApi configApi;
 
     @Resource
     private OAuth2TokenApi oAuth2TokenApi;
@@ -238,6 +242,7 @@
         return GlobalErrorCodeConstants.SUCCESS;
     }
 
+    /* 2024.11.11
     // 甯歌 鎴栬�� 棰嗙敤 鏃� 鍖荤敓 鍙栦笅涓�浣嶆偅鑰�
     public ErrorCode nextPatient(Long roomId, String bedNo) {
         // 浠� DB 鎶婅宸ヤ綅.搴忓彿鏈�灏忕殑 [灏辫瘖鍑嗗涓璢 鐨勪汉 璁剧疆涓� [灏辫瘖涓璢 (鎴栭鐢ㄤ腑)
@@ -246,6 +251,39 @@
         // 璇ュ伐浣� 娌℃湁 [灏辫瘖鍑嗗涓璢 浜哄憳
         if (null == updateNum || 0 == updateNum) {
             return QUEUE_NOT_READY_PATIENT;
+        }
+
+        // 浼樺厛闃熷垪涓� 璇ュ伐浣� 灏辫瘖鍑嗗涓汉鐨勬暟閲� 鍑忎竴
+        BedQueueBO bo = mapBedVsQueue.get( Utils.formatRoomBed( roomId, bedNo ) );
+        bo.queueNum.getAndDecrement(); // 鍙兘宸茬粡銆愬苟鍙戠殑銆戝湪 hurry-up 涓敼鍙樹簡鍊�
+
+        refreshPriorityQueue(bo);
+        return GlobalErrorCodeConstants.SUCCESS;
+    }
+    */
+
+    // 甯歌 鎴栬�� 棰嗙敤 鏃� 鍖荤敓 鍙栦笅涓�浣嶆偅鑰�
+    public ErrorCode nextPatient(Long roomId, String bedNo) {
+        QueueDO firstReadyQueueItem = queueMapper.getFirstItemByBedAndStatus(roomId, bedNo, QueueStatusEnum.READY.getStatus());
+        // 璇ュ伐浣� 娌℃湁 [灏辫瘖鍑嗗涓璢 浜哄憳
+        if (null == firstReadyQueueItem) {
+            return QUEUE_NOT_READY_PATIENT;
+        }
+
+        // QueueStatusEnum.READY  =>  QueueStatusEnum.ONSTAGE
+        firstReadyQueueItem.setStatus(QueueStatusEnum.ONSTAGE.getStatus());
+        queueMapper.updateById( firstReadyQueueItem );
+
+        // 妫�鏌ラ」鐩�.浜插拰鎬� 澶勭悊閫昏緫
+        CheckTypeDO checkTypeDO = getCheckTypeItem( firstReadyQueueItem.getBookCheckType() );
+        if (checkTypeDO.getAffinityCheckTypes().length > 0) {
+            List<QueueDO> affinityItems = queueMapper.getCurPatGivenCheckTypesAndStatus(firstReadyQueueItem.getPatId(), checkTypeDO.getAffinityCheckTypes(), QueueStatusEnum.AFFINITY_WAITING.getStatus());
+            if (!affinityItems.isEmpty()) {
+                QueueDO tmpQueueDO = affinityItems.get(0);
+                tmpQueueDO.setStatus( QueueStatusEnum.READY.getStatus() );
+                queueMapper.updateById( tmpQueueDO );
+                return GlobalErrorCodeConstants.SUCCESS;   // 鍑嗗涓� 鏁伴噺娌℃湁鍙樺寲锛屾晠鐩存帴杩斿洖
+            }
         }
 
         // 浼樺厛闃熷垪涓� 璇ュ伐浣� 灏辫瘖鍑嗗涓汉鐨勬暟閲� 鍑忎竴
@@ -413,6 +451,23 @@
                 return;
             }
 
+            // 鎶㈠埌鎺掗槦鎮h�呭悗锛屽鐞� 妫�鏌ラ」鐩�.浜插拰鎬� 閫昏緫
+            QueueDO queueDO = queueMapper.getQueueItemBySeqNum(curSeqNum.get() + 1);
+            CheckTypeDO checkTypeDO = getCheckTypeItem( queueDO.getBookCheckType() );
+            if ( checkTypeDO.getAffinityCheckTypes().length > 0) {
+                List<QueueDO> affinityItems = queueMapper.getCurPatGivenCheckTypesAndStatus(queueDO.getPatId(),
+                        checkTypeDO.getAffinityCheckTypes(), QueueStatusEnum.WAITING.getStatus());
+                for (int i = 0; i < affinityItems.size(); i++) {
+                    QueueDO queueItem = affinityItems.get(i);
+                    queueItem.setStatus(QueueStatusEnum.AFFINITY_WAITING.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 +491,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