From d9e1a1327d2d75e138f12e61c5faa155752be955 Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期五, 13 九月 2024 18:13:14 +0800
Subject: [PATCH] 作业统计 完成

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/doctor/DoctorController.java |  134 ++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 121 insertions(+), 13 deletions(-)

diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/doctor/DoctorController.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/doctor/DoctorController.java
index c444d26..daa8274 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/doctor/DoctorController.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/doctor/DoctorController.java
@@ -1,14 +1,12 @@
 package cn.lihu.jh.module.ecg.controller.admin.doctor;
 
-import cn.lihu.jh.framework.apilog.core.annotation.ApiAccessLog;
+import cn.lihu.jh.framework.common.exception.ErrorCode;
 import cn.lihu.jh.framework.common.pojo.CommonResult;
-import cn.lihu.jh.framework.common.pojo.PageParam;
-import cn.lihu.jh.framework.common.pojo.PageResult;
 import cn.lihu.jh.framework.common.util.object.BeanUtils;
-import cn.lihu.jh.framework.excel.core.util.ExcelUtils;
-import cn.lihu.jh.module.ecg.controller.admin.queue.vo.QueuePageReqVO;
+import cn.lihu.jh.framework.security.core.util.SecurityFrameworkUtils;
+import cn.lihu.jh.module.ecg.controller.admin.queue.vo.PatientStatisticVO;
 import cn.lihu.jh.module.ecg.controller.admin.queue.vo.QueueRespVO;
-import cn.lihu.jh.module.ecg.controller.admin.queue.vo.QueueSaveReqVO;
+import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomRespVO;
 import cn.lihu.jh.module.ecg.dal.dataobject.queue.QueueDO;
 import cn.lihu.jh.module.ecg.enums.QueueStatusEnum;
 import cn.lihu.jh.module.ecg.service.queue.QueueService;
@@ -20,13 +18,11 @@
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
-import javax.servlet.http.HttpServletResponse;
-import javax.validation.Valid;
-import java.io.IOException;
 import java.util.ArrayList;
 import java.util.List;
 
-import static cn.lihu.jh.framework.apilog.core.enums.OperateTypeEnum.EXPORT;
+import static cn.lihu.jh.framework.common.exception.enums.GlobalErrorCodeConstants.SUCCESS;
+import static cn.lihu.jh.framework.common.pojo.CommonResult.error;
 import static cn.lihu.jh.framework.common.pojo.CommonResult.success;
 
 @Tag(name = "绠$悊鍚庡彴 - 鍖荤敓鍙彿")
@@ -38,11 +34,92 @@
     @Resource
     private QueueService queueService;
 
+    @GetMapping("/bed-doctor-pause")
+    @Operation(summary = "鍖荤敓鏆傚仠")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:state')")
+    public CommonResult<Integer> bedPause(
+            @RequestParam("roomId") Long roomId,
+            @RequestParam("bedNo") String bedNo)
+    {
+        Long userId = SecurityFrameworkUtils.getLoginUserId();
+        String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+
+        ErrorCode result = queueService.startBedDoctorPause(roomId, bedNo, userId, userNickname);
+        if (result.equals(SUCCESS))
+            return success(SUCCESS.getCode());
+
+        return error(result);
+    }
+
+    @GetMapping("/bed-doctor-resume")
+    @Operation(summary = "鍖荤敓鎭㈠")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:state')")
+    public CommonResult<Integer> bedResume(
+            @RequestParam("roomId") Long roomId,
+            @RequestParam("bedNo") String bedNo)
+    {
+        Long userId = SecurityFrameworkUtils.getLoginUserId();
+        String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+
+        ErrorCode result = queueService.startBedDoctorResume(roomId, bedNo, userId, userNickname);
+        if (result.equals(SUCCESS))
+            return success(SUCCESS.getCode());
+
+        return error(result);
+    }
+
+    @GetMapping("/bed-doctor-on")
+    @Operation(summary = "鍖荤敓鍏ュ骇")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:state')")
+    public CommonResult<Integer> bedDoctorOn(
+            @RequestParam("roomId") Long roomId,
+            @RequestParam("bedNo") String bedNo)
+    {
+        Long userId = SecurityFrameworkUtils.getLoginUserId();
+        String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+
+        ErrorCode result = queueService.startBedDoctorOn(roomId, bedNo, userId, userNickname);
+        if (result.equals(SUCCESS))
+            return success(0);
+
+        return error(result);
+    }
+
+    @GetMapping("/bed-doctor-off")
+    @Operation(summary = "鍖荤敓绂诲骇")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:state')")
+    public CommonResult<Integer> bedDoctorOff(
+            @RequestParam("roomId") Long roomId,
+            @RequestParam("bedNo") String bedNo)
+    {
+        Long userId = SecurityFrameworkUtils.getLoginUserId();
+        String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+
+        ErrorCode result = queueService.startBedDoctorOff(roomId, bedNo, userId, userNickname);
+        if (result.equals(SUCCESS))
+            return success(SUCCESS.getCode());
+
+        return error(result);
+    }
+
+    @GetMapping("/bed-doctor-get")
+    @Operation(summary = "鍖荤敓宸ヤ綅鑾峰彇")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:state')")
+    public CommonResult<RoomRespVO> bedDoctorGet(
+            @RequestParam("roomId") Long roomId,
+            @RequestParam("bedNo") String bedNo)
+    {
+        Long userId = SecurityFrameworkUtils.getLoginUserId();
+
+        CommonResult<RoomRespVO> result = queueService.getRoom(roomId, bedNo, userId);
+        return result;
+    }
+
     @GetMapping("/finish-next-patient")
     @Operation(summary = "瀹屾垚銆佷笅涓�浣嶆偅鑰�")
     @Parameter(name = "roomId", description = "璇婂缂栧彿", required = true, example = "116")
     @Parameter(name = "bedNo", description = "宸ヤ綅缂栧彿", required = true, example = "B2")
-    @PreAuthorize("@ss.hasPermission('ecg:doctor:nextpatient')")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<List<QueueRespVO>> finishNextPatient(
             @RequestParam("roomId") Long roomId,
             @RequestParam("bedNo") String bedNo)
@@ -61,7 +138,7 @@
     @Operation(summary = "杩囧彿銆佷笅涓�浣嶆偅鑰�")
     @Parameter(name = "roomId", description = "璇婂缂栧彿", required = true, example = "116")
     @Parameter(name = "bedNo", description = "宸ヤ綅缂栧彿", required = true, example = "B2")
-    @PreAuthorize("@ss.hasPermission('ecg:doctor:nextpatient')")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<List<QueueRespVO>> passNextPatient(
             @RequestParam("roomId") Long roomId,
             @RequestParam("bedNo") String bedNo)
@@ -80,7 +157,7 @@
     @Operation(summary = "鍙栨偅鑰呭垪琛�")
     @Parameter(name = "roomId", description = "璇婂缂栧彿", required = true, example = "116")
     @Parameter(name = "bedNo", description = "宸ヤ綅缂栧彿", required = true, example = "B2")
-    @PreAuthorize("@ss.hasPermission('ecg:doctor:patientlist')")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<List<QueueRespVO>> getPatientList(
             @RequestParam("roomId") Long roomId,
             @RequestParam("bedNo") String bedNo)
@@ -93,4 +170,35 @@
         return success(BeanUtils.toBean(queueDOList, QueueRespVO.class));
     }
 
+    @GetMapping("/get-patient-statistic")
+    @Operation(summary = "鍙栨偅鑰呯粺璁�")
+    @Parameter(name = "roomId", description = "璇婂缂栧彿", required = true, example = "116")
+    @Parameter(name = "bedNo", description = "宸ヤ綅缂栧彿", required = true, example = "B2")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<PatientStatisticVO> getPatientStatistic(
+            @RequestParam("roomId") Long roomId,
+            @RequestParam("bedNo") String bedNo)
+    {
+        PatientStatisticVO patientStatisticVO = queueService.getPatientStatistic(roomId, bedNo);
+        return success(patientStatisticVO);
+    }
+
+    @GetMapping("/recall-patient")
+    @Operation(summary = "杩囨湡鐥呬汉鍙洖")
+    @Parameter(name = "roomId", description = "璇婂缂栧彿", required = true, example = "116")
+    @Parameter(name = "bedNo", description = "宸ヤ綅缂栧彿", required = true, example = "B2")
+    @Parameter(name = "patId", description = "鎮h�呯紪鍙�", required = true, example = "B2")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<String> recallPatient(
+            @RequestParam("roomId") Long roomId,
+            @RequestParam("bedNo") String bedNo,
+            @RequestParam("patId") String patId )
+    {
+        Integer result = queueService.recallPatient(roomId, bedNo, patId);
+        if (null == result || 0 == result)
+            return error( new ErrorCode(201, "鎵句笉鍒版偅鑰�") );
+
+        return success("success");
+    }
+
 }

--
Gitblit v1.9.3