From 784c60d5baad7edceab2f1668ed9116e5b5e5e89 Mon Sep 17 00:00:00 2001 From: eight <641137800@qq.com> Date: 星期四, 31 十月 2024 16:22:50 +0800 Subject: [PATCH] update --- jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/appointment/AppointmentController.java | 134 ++++++++++++-------------------------------- 1 files changed, 37 insertions(+), 97 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 16070bd..012c5e6 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,17 +1,9 @@ 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.queue.vo.QueueSaveReqVO; -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; @@ -19,12 +11,8 @@ 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; @@ -39,8 +27,6 @@ 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; @@ -66,7 +52,7 @@ private RoomService roomService; @Resource - private RemoteDataService remoteDataService; + private DevRentService devRentService; @Resource private DeptApi deptApi; @@ -74,7 +60,7 @@ @PostMapping("/create") @Operation(summary = "鍒涘缓棰勭害") @PreAuthorize("@ss.hasPermission('ecg:appointment:create')") - public CommonResult<Integer> createAppointment(@Valid @RequestBody AppointmentSaveReqVO createReqVO) { + public CommonResult<Long> createAppointment(@Valid @RequestBody AppointmentSaveReqVO createReqVO) { return success(appointmentService.createAppointment(createReqVO)); } @@ -90,7 +76,7 @@ @Operation(summary = "鍒犻櫎棰勭害") @Parameter(name = "id", description = "缂栧彿", required = true) @PreAuthorize("@ss.hasPermission('ecg:appointment:delete')") - public CommonResult<Boolean> deleteAppointment(@RequestParam("id") Integer id) { + public CommonResult<Boolean> deleteAppointment(@RequestParam("id") Long id) { appointmentService.deleteAppointment(id); return success(true); } @@ -99,8 +85,37 @@ @Operation(summary = "鑾峰緱棰勭害") @Parameter(name = "id", description = "缂栧彿", required = true, example = "1024") @PreAuthorize("@ss.hasPermission('ecg:appointment:query')") - public CommonResult<AppointmentRespVO> getAppointment(@RequestParam("id") Integer id) { + public CommonResult<AppointmentRespVO> getAppointment(@RequestParam("id") Long id) { AppointmentDO appointment = appointmentService.getAppointment(id); + return success(BeanUtils.toBean(appointment, AppointmentRespVO.class)); + } + + @GetMapping("/get-current-by-patient") + @Operation(summary = "鏍规嵁鎮h�呯紪鍙�.鏌ヨ褰撳ぉ棰勭害") + @Parameter(name = "id", description = "缂栧彿", required = true, example = "1024") + @PreAuthorize("@ss.hasPermission('ecg:appointment:query')") + public CommonResult<AppointmentRespVO> getCurAppointmentByPatId(@RequestParam("patId") String patId) { + AppointmentDO appointment = appointmentService.getCurAppointmentByPatId( patId ); + return success(BeanUtils.toBean(appointment, AppointmentRespVO.class)); + } + + @GetMapping("/query-and-create-by-patient") + @Operation(summary = "鏍规嵁鎮h�呯紪鍙�.鑾峰緱棰勭害.骞跺唴閮ㄥ垱寤洪绾�") + @Parameter(name = "id", description = "缂栧彿", required = true, example = "1024") + @PreAuthorize("@ss.hasPermission('ecg:appointment:query')") + public CommonResult<AppointmentRespVO> queryAndCreateAppointmentByPatId(@RequestParam("patId") String patId) { + AppointmentDO appointment = appointmentService.queryAndCreateAppointmentByPatId( patId ); + return success(BeanUtils.toBean(appointment, AppointmentRespVO.class)); + } + + @GetMapping("/query-his-by-patient") + @Operation(summary = "浠嶩IS.鏌ヨ鎮h�呴绾�/寮�鍗曚俊鎭�") + @Parameter(name = "id", description = "缂栧彿", required = true, example = "1024") + @PreAuthorize("@ss.hasPermission('ecg:appointment:query')") + public CommonResult<AppointmentRespVO> queryHisByPatient(@RequestParam("patId") String patId) { + AppointmentDO appointment = appointmentService.getAppointmentExtermal( patId ); + if ( null == appointment) + return error(APPOINTMENT_NOT_BILLING); return success(BeanUtils.toBean(appointment, AppointmentRespVO.class)); } @@ -125,87 +140,12 @@ BeanUtils.toBean(list, AppointmentRespVO.class)); } - // 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( (byte)10 ); - - queueSaveReqVO.setSeqNum(1); - queueSaveReqVO.setStatus((byte)10); - 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); - queueService.queue(queueSaveReqVO); - } catch (DuplicateKeyException duplicateKeyException) { - return success("鎮ㄥ凡缁忓湪鎺掗槦涓簡"); - } - - return success("鎿嶄綔鎴愬姛"); + appointmentService.appoitmentConfirm( confirmReqVO ); + return success("纭鎴愬姛"); } + } -- Gitblit v1.9.3