From 4b278300e8b3b1faabd5d080990cd3124f68612c Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期二, 26 十一月 2024 13:09:28 +0800
Subject: [PATCH] 会取下一个时段的序号

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java |   41 ++++++++++++++++++++++++++++++++++++-----
 1 files changed, 36 insertions(+), 5 deletions(-)

diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java
index 1bf0bd2..d48bf41 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java
@@ -138,12 +138,27 @@
     public Integer distributeSeqNo(Integer checkType, Integer timeslot) {
         Integer curSeqNo = queueSequenceMapper.selectQueueNoForUpdate(checkType, timeslot);
         if (null == curSeqNo) {
-            throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL);
-        }
+            // 浠庝笅涓�涓椂娈� 鑾峰彇搴忓彿銆傚師鍥犵郴缁熺敤30鍒嗛挓鐨勯棿闅斿垝鍒嗛绾︽椂闂存锛孒IS鐨勯绾︽椂闂存鍙兘鏄�30鍒嗛挓鎴�60鍒嗛挓
+            Integer nextTimeslot = getNextTimeSlot(timeslot, checkType);
+            if (null == nextTimeslot) {
+                throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL);
+            }
 
-        Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotSeqNo(checkType, timeslot, curSeqNo);
-        if (null == updateRowNum || updateRowNum == 0) {
-            throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION);
+            curSeqNo = queueSequenceMapper.selectQueueNoForUpdate(checkType, nextTimeslot);
+            if (null == curSeqNo) {
+                throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL);
+            }
+
+            Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotSeqNo(checkType, nextTimeslot, curSeqNo);
+            if (null == updateRowNum || updateRowNum == 0) {
+                throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION);
+            }
+
+        } else {
+            Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotSeqNo(checkType, timeslot, curSeqNo);
+            if (null == updateRowNum || updateRowNum == 0) {
+                throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION);
+            }
         }
 
         return curSeqNo + 1;
@@ -165,5 +180,21 @@
         return curVipSeqNo + 1;
     }
 
+    private Integer getNextTimeSlot(Integer timeslot, Integer checkType) {
+        List<DictDataRespDTO> dictBookTimeslotList = dictDataApi.getDictDataList(ECG_BOOK_TIMESLOT);
+        Optional<Integer> index = dictBookTimeslotList.stream()
+                .filter(e -> e.getValue().equals(String.valueOf(timeslot)))
+                .findFirst()
+                .map(dictBookTimeslotList::indexOf);
+        if (!index.isPresent())
+            return null;
+
+        if (dictBookTimeslotList.size() <= (index.get() + 1))
+            return null;
+
+        DictDataRespDTO dictDataRespDTO = dictBookTimeslotList.get(index.get() + 1);
+        return Integer.valueOf(dictDataRespDTO.getValue());
+    }
+
 }
 

--
Gitblit v1.9.3