From eec1528a3c4f10c6096cbeadf2a7ef9104e8ec4b Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期三, 23 十月 2024 22:13:37 +0800
Subject: [PATCH] 检查类型 简单列表接口

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/appointment/AppointmentController.java |   56 ++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 44 insertions(+), 12 deletions(-)

diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/appointment/AppointmentController.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/appointment/AppointmentController.java
index 8db650a..fd5e59d 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/appointment/AppointmentController.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/appointment/AppointmentController.java
@@ -1,14 +1,20 @@
 package cn.lihu.jh.module.ecg.controller.admin.appointment;
 
 import cn.hutool.core.bean.BeanUtil;
+import cn.lihu.jh.framework.common.exception.ErrorCode;
+import cn.lihu.jh.framework.common.util.date.DateUtils;
+import cn.lihu.jh.module.ecg.controller.admin.devrent.vo.DevRentSaveReqVO;
 import cn.lihu.jh.module.ecg.controller.admin.queue.vo.QueueSaveReqVO;
+import cn.lihu.jh.module.ecg.enums.QueueStatusEnum;
 import cn.lihu.jh.module.ecg.feign.RemoteDataService;
 import cn.lihu.jh.module.ecg.feign.RestApiReqBodyVo;
 import cn.lihu.jh.module.ecg.feign.RestApiResult;
 import cn.lihu.jh.module.ecg.feign.dto.AppointmentExternal;
+import cn.lihu.jh.module.ecg.service.devrent.DevRentService;
 import cn.lihu.jh.module.ecg.service.queue.QueueService;
 import cn.lihu.jh.module.ecg.service.room.RoomService;
 import cn.lihu.jh.module.system.api.dept.DeptApi;
+import org.springframework.dao.DuplicateKeyException;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.security.access.prepost.PreAuthorize;
@@ -27,12 +33,15 @@
 import cn.lihu.jh.framework.common.pojo.PageResult;
 import cn.lihu.jh.framework.common.pojo.CommonResult;
 import cn.lihu.jh.framework.common.util.object.BeanUtils;
+
+import static cn.lihu.jh.framework.common.pojo.CommonResult.error;
 import static cn.lihu.jh.framework.common.pojo.CommonResult.success;
 
 import cn.lihu.jh.framework.excel.core.util.ExcelUtils;
 
 import cn.lihu.jh.framework.apilog.core.annotation.ApiAccessLog;
 import static cn.lihu.jh.framework.apilog.core.enums.OperateTypeEnum.*;
+import static cn.lihu.jh.module.ecg.enums.ErrorCodeConstants.*;
 import static java.time.format.DateTimeFormatter.ISO_LOCAL_DATE;
 import static java.time.format.DateTimeFormatter.ISO_LOCAL_TIME;
 
@@ -61,6 +70,9 @@
 
     @Resource
     private RemoteDataService remoteDataService;
+
+    @Resource
+    private DevRentService devRentService;
 
     @Resource
     private DeptApi deptApi;
@@ -95,6 +107,15 @@
     @PreAuthorize("@ss.hasPermission('ecg:appointment:query')")
     public CommonResult<AppointmentRespVO> getAppointment(@RequestParam("id") Integer id) {
         AppointmentDO appointment = appointmentService.getAppointment(id);
+        return success(BeanUtils.toBean(appointment, AppointmentRespVO.class));
+    }
+
+    @GetMapping("/get-by-patient")
+    @Operation(summary = "鑾峰緱棰勭害")
+    @Parameter(name = "id", description = "缂栧彿", required = true, example = "1024")
+    @PreAuthorize("@ss.hasPermission('ecg:appointment:query')")
+    public CommonResult<AppointmentRespVO> getAppointmentByPatient(@RequestParam("patId") String patId) {
+        AppointmentDO appointment = appointmentService.getAppointmentByPatId( patId );
         return success(BeanUtils.toBean(appointment, AppointmentRespVO.class));
     }
 
@@ -160,10 +181,10 @@
                         + bookEndTime.getHour()*100 + bookEndTime.getMinute() );
 
         //queueSaveReqVO.setBookCheckType( Byte.valueOf(appointmentExternal.getPlanDefItemList().getPlanDefItem().getPlanDefItemcode()) );
-        queueSaveReqVO.setBookCheckType( (byte)10 );
+        queueSaveReqVO.setBookCheckType( 10 );
 
         queueSaveReqVO.setSeqNum(1);
-        queueSaveReqVO.setStatus((byte)10);
+        queueSaveReqVO.setStatus(QueueStatusEnum.WAITING.getStatus());
         queueSaveReqVO.setPassed((byte)0);
         queueSaveReqVO.setExpired((byte)0);
 
@@ -179,17 +200,28 @@
     public CommonResult<String> appointmentConfirm(@RequestBody AppointmentConfirmReqVO confirmReqVO) {
         //TODO 鍏堜粠棰勭害琛ㄥ彇鏁版嵁锛屽悗缁鎺ユ暟鎹钩鍙版煡棰勭害鏁版嵁
         AppointmentDO appointment = appointmentService.getAppointment(confirmReqVO.getId());
+        if (null == appointment)
+            return error(PATIENT_NOT_EXISTS);
 
-        QueueSaveReqVO queueSaveReqVO = new QueueSaveReqVO();
-        queueSaveReqVO.setPatId( appointment.getPatId());
-        queueSaveReqVO.setPatName( appointment.getPatName() );
-        queueSaveReqVO.setPatGender( appointment.getPatGender());
-        queueSaveReqVO.setBookTimeslot( appointment.getBookTimeslot() );
-        queueSaveReqVO.setBookCheckType( appointment.getBookCheckType() );
-        queueSaveReqVO.setPassed((byte)0);
-        queueSaveReqVO.setExpired((byte)0);
-        queueService.queue(queueSaveReqVO);
+        if ( !DateUtils.isToday(appointment.getBookDate()) )
+            return error( APPOINTMENT_NOT_TODAY);
 
-        return success("hello");
+        try {
+            QueueSaveReqVO queueSaveReqVO = new QueueSaveReqVO();
+            queueSaveReqVO.setPatId(appointment.getPatId());
+            queueSaveReqVO.setPatName(appointment.getPatName());
+            queueSaveReqVO.setPatGender(appointment.getPatGender());
+            queueSaveReqVO.setBookDate(appointment.getBookDate());
+            queueSaveReqVO.setBookTimeslot(appointment.getBookTimeslot());
+            queueSaveReqVO.setBookCheckType(appointment.getBookCheckType());
+            queueSaveReqVO.setPassed((byte) 0);
+            queueSaveReqVO.setExpired((byte) 0);
+            queueSaveReqVO.setPatDetails( appointment.getPatDeptDesc() + "-" + appointment.getPatWardDesc() + "-" + appointment.getPatBedNo());
+            queueService.queue(queueSaveReqVO);
+        } catch (DuplicateKeyException duplicateKeyException) {
+            return success("鎮ㄥ凡缁忓湪鎺掗槦涓簡");
+        }
+
+        return success("鎿嶄綔鎴愬姛");
     }
 }

--
Gitblit v1.9.3