From 8f7bc2dc2c05724e21998076955da000158e109a Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期五, 08 十一月 2024 17:15:33 +0800
Subject: [PATCH] update

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/appointment/AppointmentServiceImpl.java |   45 +++++++++++++++++++++++++++++++++------------
 1 files changed, 33 insertions(+), 12 deletions(-)

diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/appointment/AppointmentServiceImpl.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/appointment/AppointmentServiceImpl.java
index fb405e9..45cad56 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/appointment/AppointmentServiceImpl.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/appointment/AppointmentServiceImpl.java
@@ -10,6 +10,7 @@
 import cn.lihu.jh.module.ecg.service.config.EcgConfigService;
 import cn.lihu.jh.module.ecg.service.queue.QueueService;
 import cn.lihu.jh.module.ecg.service.queuesequence.QueueSequenceService;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.dao.DuplicateKeyException;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -41,6 +42,7 @@
  */
 @Service
 @Validated
+@Slf4j
 public class AppointmentServiceImpl implements AppointmentService {
 
     @Resource
@@ -112,29 +114,33 @@
     }
 
     /**
-     * // TODO 灏氫笉鏀寔, 涓�浣嶆偅鑰呭綋澶╀袱绉嶆鏌ラ」鐩殑鎯呭喌
      * @param patCode 缂栧彿 : !!! 涓嶄竴瀹氬氨鏄湰绯荤粺鐨� 鎮h�呯紪鍙�(patID), 鏍规簮鍦ㄤ簬 妫�鏌ュ崟鎵弿鍑烘潵鐨勭紪鍙� 涓嶄竴瀹氭槸 鏈郴缁熺殑 鎮h�呯紪鍙�(patID)
      * @return
      */
     @Override
-    public AppointmentDO queryAndCreateAppointmentByPatId(String patCode) {
+    public List<AppointmentDO> queryAndCreateAppointmentByPatId(String patCode) {
         // 鍏堜粠鍖婚櫌骞冲彴鏌ヨ
         List<AppointmentDO> appointmentExtermalList = getAppointmentExtermal( patCode );
+
         for ( int appointmentIndex = 0; appointmentIndex < appointmentExtermalList.size(); appointmentIndex++ ) {
             AppointmentDO appointmentExtermal = appointmentExtermalList.get(appointmentIndex);
-            if (null != appointmentExtermal && null != appointmentExtermal.getBookDate() && appointmentExtermal.getBookDate().isEqual(LocalDate.now())) {
-                // 鏌ュ埌褰撳ぉ鐨勯绾﹀悗锛屾煡璇B涓� 鏄惁宸茬粡瀛樺湪
-                AppointmentDO appointmentDO = appointmentMapper.getCurrentByPatAndCheckType(appointmentExtermal.getPatId(), appointmentExtermal.getBookCheckType());
-                if (null == appointmentDO) {
-                    appointmentMapper.insert(appointmentExtermal);
-                    return appointmentExtermal;
-                }
-                return appointmentDO;
+            if (null == appointmentExtermal )
+                continue;
+
+            // 浠嶥B鏌ュ埌棰勭害锛屾槸鍚﹀凡缁忓瓨鍦�
+            AppointmentDO appointmentDO = appointmentMapper.getByPatAndCheckTypeAndBookDate(appointmentExtermal.getPatId(), appointmentExtermal.getBookCheckType(), appointmentExtermal.getBookDate());
+            if (null == appointmentDO) {
+                appointmentMapper.insert(appointmentExtermal);
+            } else {
+                appointmentExtermal.setId( appointmentDO.getId() ); // 纭繚 杩斿洖鍊间繚鎶� appointment id
             }
         }
 
-        List<AppointmentDO> appointmentDOList = appointmentMapper.getCurrentPatId( patCode );
-        return 0 == appointmentDOList.size() ? null : appointmentDOList.get(0);
+        // 涓嶄粠DB鏌ヨ
+        //List<AppointmentDO> appointmentDOList = appointmentMapper.getCurrentPatId( patCode );
+        //return 0 == appointmentDOList.size() ? null : appointmentDOList.get(0);
+
+        return appointmentExtermalList;
     }
 
     @Override
@@ -163,6 +169,8 @@
             AppointmentExternal appointmentExternal = result.getRow().get( appointIndex );
 
             AppointmentDO appointmentDO = BeanUtils.toBean(appointmentExternal, AppointmentDO.class);
+            appointmentDO.setApplyNo( appointmentExternal.getReqIdeApplyno() );
+            appointmentDO.setPatSrc( getCorrespondingPatientSource(appointmentExternal.getAdmTypeCode()) );
             appointmentDO.setPatId(appointmentExternal.getPatientID()); // 鍐呭涓� 韬唤璇佸彿 鎴� 闂ㄨ瘖浣忛櫌鍙�
             appointmentDO.setPatName(appointmentExternal.getPatName());
             appointmentDO.setPatGender(Byte.valueOf(appointmentExternal.getPatgender()));
@@ -269,4 +277,17 @@
 
         return 100;
     }
+
+    private Integer getCorrespondingPatientSource(String admTypeCode) {
+        if (admTypeCode.equals("AMB"))
+            return 1;
+        else if (admTypeCode.equals("EMER"))
+            return 2;
+        else if (admTypeCode.equals("IMP"))
+            return 3;
+        else if (admTypeCode.equals("PHY"))
+            return 4;
+
+        return 0;
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.3