From 4f6d2cf3cd7030d0700a23bbc13e516defbba407 Mon Sep 17 00:00:00 2001 From: eight <641137800@qq.com> Date: 星期五, 25 十月 2024 17:49:54 +0800 Subject: [PATCH] just comment --- jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/appointment/AppointmentController.java | 134 ++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 133 insertions(+), 1 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 16c0648..8b04bb3 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,5 +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; @@ -7,19 +22,28 @@ import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.Operation; +import java.time.LocalDateTime; +import java.time.format.DateTimeFormatter; +import java.time.format.DateTimeFormatterBuilder; import java.util.*; import java.io.IOException; +import java.util.stream.Collectors; import cn.lihu.jh.framework.common.pojo.PageParam; 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; import cn.lihu.jh.module.ecg.controller.admin.appointment.vo.*; import cn.lihu.jh.module.ecg.dal.dataobject.appointment.AppointmentDO; @@ -37,6 +61,21 @@ @Resource private AppointmentService appointmentService; + + @Resource + private QueueService queueService; + + @Resource + private RoomService roomService; + + @Resource + private RemoteDataService remoteDataService; + + @Resource + private DevRentService devRentService; + + @Resource + private DeptApi deptApi; @PostMapping("/create") @Operation(summary = "鍒涘缓棰勭害") @@ -71,6 +110,15 @@ return success(BeanUtils.toBean(appointment, AppointmentRespVO.class)); } + @GetMapping("/get-by-patient") + @Operation(summary = "鏍规嵁鎮h�呯紪鍙�.鑾峰緱棰勭害") + @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)); + } + @GetMapping("/page") @Operation(summary = "鑾峰緱棰勭害鍒嗛〉") @PreAuthorize("@ss.hasPermission('ecg:appointment:query')") @@ -92,4 +140,88 @@ BeanUtils.toBean(list, AppointmentRespVO.class)); } -} \ No newline at end of file + // TODO 瀵规帴鏁版嵁骞冲彴 + private void getRemoteAppointment(AppointmentConfirmReqVO confirmReqVO) { + RestApiReqBodyVo reqBodyVo = new RestApiReqBodyVo(); + reqBodyVo.setSfzh(confirmReqVO.getPatId()); + reqBodyVo.setMzzyh("A34343"); + + // QueryRisReportList queryEcgRequest + RestApiResult<Object> result = remoteDataService.httpApi("queryEcgRequest", "ECG", "ECG", reqBodyVo); + + List<AppointmentExternal> list = + result.getRow().stream().map( + rawItem -> { + //AppointmentExternal appointmentExternal = JSONObject.parseObject(JSONObject.toJSONString(rawItem), AppointmentExternal.class); + AppointmentExternal appointmentExternal = BeanUtil.toBeanIgnoreCase( rawItem, AppointmentExternal.class, true); + + return appointmentExternal; + } + ).collect(Collectors.toList()); + + AppointmentExternal appointmentExternal = list.get(0); + + QueueSaveReqVO queueSaveReqVO = new QueueSaveReqVO(); + + queueSaveReqVO.setPatId( appointmentExternal.getPatientID() ); + queueSaveReqVO.setPatName( appointmentExternal.getPatName() ); + queueSaveReqVO.setPatGender( Byte.valueOf(appointmentExternal.getPatgender()) ); + + + DateTimeFormatter ISO_LOCAL_DATE_TIME2 = new DateTimeFormatterBuilder() + .parseCaseInsensitive() + .append(ISO_LOCAL_DATE) + .appendLiteral(' ') + .append(ISO_LOCAL_TIME) + .toFormatter(); + LocalDateTime bookStartTime = LocalDateTime.parse(appointmentExternal.getReqExtBooktime(), ISO_LOCAL_DATE_TIME2); + LocalDateTime bookEndTime = bookStartTime.plusMinutes(30); + queueSaveReqVO.setBookTimeslot( + (bookStartTime.getHour()*100 + bookStartTime.getMinute())*10000 + + bookEndTime.getHour()*100 + bookEndTime.getMinute() ); + + //queueSaveReqVO.setBookCheckType( Byte.valueOf(appointmentExternal.getPlanDefItemList().getPlanDefItem().getPlanDefItemcode()) ); + queueSaveReqVO.setBookCheckType( 10 ); + + queueSaveReqVO.setSeqNum(1); + queueSaveReqVO.setStatus(QueueStatusEnum.WAITING.getStatus()); + queueSaveReqVO.setPassed((byte)0); + queueSaveReqVO.setExpired((byte)0); + + queueSaveReqVO.setRoomName("-"); + queueSaveReqVO.setBedNo("-"); + + queueService.createqueue(queueSaveReqVO); + } + + @PostMapping("/confirm") + @Operation(summary = "棰勭害纭") + @PreAuthorize("@ss.hasPermission('ecg:appointment:confirm')") + public CommonResult<String> appointmentConfirm(@RequestBody AppointmentConfirmReqVO confirmReqVO) { + //TODO 鍏堜粠棰勭害琛ㄥ彇鏁版嵁锛屽悗缁鎺ユ暟鎹钩鍙版煡棰勭害鏁版嵁 + AppointmentDO appointment = appointmentService.getAppointment(confirmReqVO.getId()); + if (null == appointment) + return error(PATIENT_NOT_EXISTS); + + if ( !DateUtils.isToday(appointment.getBookDate()) ) + return error( APPOINTMENT_NOT_TODAY); + + 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