From 6a7f481d975f94984602b15c90904090f30b9b67 Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期六, 12 十月 2024 10:15:17 +0800
Subject: [PATCH] 叫号分 领用叫号、安装叫号、常规叫号

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java |  172 ++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 150 insertions(+), 22 deletions(-)

diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java
index 8e2dc08..bfe957c 100644
--- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java
+++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java
@@ -1,6 +1,9 @@
 package cn.lihu.jh.module.ecg.controller.admin.devrent;
 
 import cn.lihu.jh.framework.common.util.exception.ExceptionUtils;
+import cn.lihu.jh.module.ecg.dal.dataobject.devmanage.DeviceDO;
+import cn.lihu.jh.module.ecg.service.devmanage.DeviceService;
+import cn.lihu.jh.module.ecg.service.queue.QueueService;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.validation.annotation.Validated;
@@ -17,16 +20,11 @@
 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.framework.common.util.exception.ExceptionUtils.formatException;
-import static cn.lihu.jh.module.ecg.enums.ErrorCodeConstants.DEV_DISMANTLE_EXCEPTION;
-import static cn.lihu.jh.module.ecg.enums.ErrorCodeConstants.DEV_INSTALL_EXCEPTION;
+import static cn.lihu.jh.module.ecg.enums.ErrorCodeConstants.*;
 
 import cn.lihu.jh.module.ecg.controller.admin.devrent.vo.*;
 import cn.lihu.jh.module.ecg.dal.dataobject.devrent.DevRentDO;
@@ -46,17 +44,36 @@
     @Resource
     private DevRentService devRentService;
 
+    @Resource
+    private DeviceService deviceService;
+
+    @Resource
+    private QueueService queueService;
+
+    @PostMapping("/dev-ready")
+    @Operation(summary = "璁惧棰嗙敤")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Long> devReady(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
+        try {
+            CommonResult<Long> result = devRentService.readyOperation(createReqVO);
+            return result;
+        } catch ( RuntimeException runtimeException ) {
+            String err = ExceptionUtils.formatException( runtimeException );
+            log.error("devReady: " + err);
+            return CommonResult.error(DEV_INSTALL_EXCEPTION);
+        }
+    }
+
     @PostMapping("/dev-install")
     @Operation(summary = "瑁呮満")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<Long> devInstall(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
         try {
-            Long rent_id = devRentService.installOperation(createReqVO);
-            return success(rent_id);
+            return devRentService.installOperation(createReqVO);
         } catch ( RuntimeException runtimeException ) {
             String err = ExceptionUtils.formatException( runtimeException );
             log.error("devInstall: " + err);
-            return error(DEV_INSTALL_EXCEPTION);
+            return CommonResult.error(DEV_INSTALL_EXCEPTION);
         }
     }
 
@@ -66,11 +83,64 @@
     public CommonResult<Long> devDismantle(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
         try {
             devRentService.dismantleOperation(createReqVO);
-            return success(0L);
+            return CommonResult.success(0L);
         } catch ( RuntimeException runtimeException ) {
             String err = ExceptionUtils.formatException( runtimeException );
             log.error("devDismantle: " + err);
-            return error(DEV_DISMANTLE_EXCEPTION);
+            return CommonResult.error(DEV_DISMANTLE_EXCEPTION);
+        }
+    }
+
+    @PostMapping("/dev-data-entry")
+    @Operation(summary = "鏁版嵁褰曞叆")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Long> devDataEntry(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
+        try {
+            devRentService.dataEntryOperation(createReqVO);
+            return CommonResult.success(0L);
+        } catch ( RuntimeException runtimeException ) {
+            String err = ExceptionUtils.formatException( runtimeException );
+            log.error("devDismantle: " + err);
+            return CommonResult.error(DEV_DISMANTLE_EXCEPTION);
+        }
+    }
+
+    @PostMapping("/dev-ready-cancel")
+    @Operation(summary = "鍙栨秷瑁呮満")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Long> devReadyCancel(@Valid @RequestBody DevCancelReqVO cancelReqVO) {
+        try {
+            return devRentService.cancelReadyOperation(cancelReqVO);
+        } catch ( RuntimeException runtimeException ) {
+            String err = ExceptionUtils.formatException( runtimeException );
+            log.error("devCancel: " + err);
+            return CommonResult.error(DEV_CANCEL_EXCEPTION);
+        }
+    }
+
+    @PostMapping("/dev-install-cancel")
+    @Operation(summary = "鍙栨秷瑁呮満")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Long> devInstallCancel(@Valid @RequestBody DevCancelReqVO cancelReqVO) {
+        try {
+            return devRentService.cancelInstallOperation(cancelReqVO);
+        } catch ( RuntimeException runtimeException ) {
+            String err = ExceptionUtils.formatException( runtimeException );
+            log.error("devCancel: " + err);
+            return CommonResult.error(DEV_CANCEL_EXCEPTION);
+        }
+    }
+
+    @PostMapping("/dev-lose")
+    @Operation(summary = "閬楀け")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Long> devLose(@Valid @RequestBody DevRentSaveReqVO loseReqVO) {
+        try {
+            return devRentService.loseOperation(loseReqVO);
+        } catch ( RuntimeException runtimeException ) {
+            String err = ExceptionUtils.formatException( runtimeException );
+            log.error("devLose: " + err);
+            return CommonResult.error(DEV_LOSE_EXCEPTION);
         }
     }
 
@@ -78,7 +148,7 @@
     @Operation(summary = "鍒涘缓瑁呮満鎷嗘満")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<Long> createDevRent(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
-        return success(devRentService.createDevRent(createReqVO));
+        return CommonResult.success(devRentService.createDevRent(createReqVO));
     }
 
     @PutMapping("/update")
@@ -86,7 +156,7 @@
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<Boolean> updateDevRent(@Valid @RequestBody DevRentSaveReqVO updateReqVO) {
         devRentService.updateDevRent(updateReqVO);
-        return success(true);
+        return CommonResult.success(true);
     }
 
     @DeleteMapping("/delete")
@@ -95,7 +165,7 @@
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<Boolean> deleteDevRent(@RequestParam("id") Long id) {
         devRentService.deleteDevRent(id);
-        return success(true);
+        return CommonResult.success(true);
     }
 
     @GetMapping("/get")
@@ -104,7 +174,16 @@
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<DevRentRespVO> getDevRent(@RequestParam("id") Long id) {
         DevRentDO devRent = devRentService.getDevRent(id);
-        return success(BeanUtils.toBean(devRent, DevRentRespVO.class));
+
+        DevRentRespVO devRentRespVO = BeanUtils.toBean(devRent, DevRentRespVO.class);
+
+        DeviceDO deviceDO = deviceService.getDevice( devRent.getDevId() );
+        if (null != deviceDO) {
+            devRentRespVO.setCategory(deviceDO.getCategory());
+            devRentRespVO.setBrand(deviceDO.getBrand());
+            devRentRespVO.setModel(deviceDO.getModel());
+        }
+        return CommonResult.success(devRentRespVO);
     }
 
     @GetMapping("/page")
@@ -112,7 +191,7 @@
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<PageResult<DevRentRespVO>> getDevRentPage(@Valid DevRentPageReqVO pageReqVO) {
         PageResult<DevRentDO> pageResult = devRentService.getDevRentPage(pageReqVO);
-        return success(BeanUtils.toBean(pageResult, DevRentRespVO.class));
+        return CommonResult.success(BeanUtils.toBean(pageResult, DevRentRespVO.class));
     }
 
     @GetMapping("/export-excel")
@@ -128,13 +207,62 @@
                         BeanUtils.toBean(list, DevRentRespVO.class));
     }
 
-    @GetMapping("/get-latest-rent")
-    @Operation(summary = "鑾峰彇鎮h�呰澶囩殑鏈�杩戠璧佹儏鍐�")
-    @Parameter(name = "dev-id", description = "璁惧缂栧彿", required = true, example = "1024")
+    @GetMapping("/get-ready-rent")
+    @Operation(summary = "鑾峰彇宸查鍙栫璧佹儏鍐�")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
-    public CommonResult<DevRentRespVO> getLatestRent( @RequestParam("dev-id") String devId )
+    public CommonResult<DevRentRespVO> getReadyRent( @Valid DevRentSearchReqVO searchReqVO )
     {
-        DevRentDO devRent = devRentService.getLatestRent( devId );
-        return success(BeanUtils.toBean(devRent, DevRentRespVO.class));
+        DevRentDO devRent = devRentService.getReadyOrCancelledRent( searchReqVO );
+        if (null == devRent) {
+            return CommonResult.success(null);
+        }
+
+        DevRentRespVO devRentRespVO = BeanUtils.toBean(devRent, DevRentRespVO.class);
+
+        DeviceDO deviceDO = deviceService.getDevice( devRent.getDevId() );
+        if (null != deviceDO) {
+            devRentRespVO.setCategory(deviceDO.getCategory());
+            devRentRespVO.setBrand(deviceDO.getBrand());
+            devRentRespVO.setModel(deviceDO.getModel());
+        }
+        return CommonResult.success(devRentRespVO);
+    }
+
+    @GetMapping("/get-installed-rent")
+    @Operation(summary = "鑾峰彇宸插畨瑁呯璧佹儏鍐�")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<DevRentRespVO> getInstalledRent( @Valid DevRentSearchReqVO searchReqVO )
+    {
+        DevRentDO devRent = devRentService.getInstalledOrCancelledRent( searchReqVO );
+        if (null == devRent) {
+            return CommonResult.success(null);
+        }
+
+        DeviceDO deviceDO = deviceService.getDevice( devRent.getDevId() );
+
+        DevRentRespVO devRentRespVO = BeanUtils.toBean(devRent, DevRentRespVO.class);
+        devRentRespVO.setCategory( deviceDO.getCategory() );
+        devRentRespVO.setBrand( deviceDO.getBrand() );
+        devRentRespVO.setModel( deviceDO.getModel() );
+        return CommonResult.success(devRentRespVO);
+    }
+
+    @GetMapping("/get-dismantled-rent")
+    @Operation(summary = "鑾峰彇宸叉媶鍗哥璧佹儏鍐�")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<DevRentRespVO> getDismantledRent( @Valid DevRentSearchReqVO searchReqVO )
+    {
+        DevRentDO devRent = devRentService.getDismantledRent( searchReqVO );
+        if (null == devRent) {
+            return CommonResult.success(null);
+        }
+
+        DeviceDO deviceDO = deviceService.getDevice( devRent.getDevId() );
+
+        DevRentRespVO devRentRespVO = BeanUtils.toBean(devRent, DevRentRespVO.class);
+        devRentRespVO.setCategory( deviceDO.getCategory() );
+        devRentRespVO.setBrand( deviceDO.getBrand() );
+        devRentRespVO.setModel( deviceDO.getModel() );
+        return CommonResult.success(devRentRespVO);
     }
 }

--
Gitblit v1.9.3