From eb3195e397b023cfae1ee4dea7fbc29f1271504f Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期六, 07 六月 2025 15:37:51 +0800
Subject: [PATCH] 代码提交

---
 jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java |  209 ++++++++++++++++++++++++++++++---------------------
 1 files changed, 122 insertions(+), 87 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 abe1c41..5e6efac 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,7 +1,10 @@
 package cn.lihu.jh.module.ecg.controller.admin.devrent;
 
-import cn.lihu.jh.framework.common.util.exception.ExceptionUtils;
+import cn.lihu.jh.framework.security.core.util.SecurityFrameworkUtils;
+import cn.lihu.jh.module.ecg.dal.dataobject.appointment.AppointmentDO;
 import cn.lihu.jh.module.ecg.dal.dataobject.devmanage.DeviceDO;
+import cn.lihu.jh.module.ecg.enums.DevStateEnum;
+import cn.lihu.jh.module.ecg.service.appointment.AppointmentService;
 import cn.lihu.jh.module.ecg.service.devmanage.DeviceService;
 import cn.lihu.jh.module.ecg.service.queue.QueueService;
 import lombok.extern.slf4j.Slf4j;
@@ -23,8 +26,8 @@
 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 cn.lihu.jh.module.ecg.controller.admin.devrent.vo.*;
 import cn.lihu.jh.module.ecg.dal.dataobject.devrent.DevRentDO;
@@ -34,7 +37,7 @@
 import javax.servlet.http.HttpServletResponse;
 import javax.validation.Valid;
 
-@Tag(name = "绠$悊鍚庡彴 - 瑁呮満鎷嗘満")
+@Tag(name = "瑁呮満鎷嗘満")
 @RestController
 @RequestMapping("/ecg/dev-rent")
 @Validated
@@ -50,113 +53,104 @@
     @Resource
     private QueueService queueService;
 
+    @Resource
+    private AppointmentService appointmentService;
+
     // 甯歌妫�鏌� 瀹屾垚
     @PostMapping("/routine-finish")
-    @Operation(summary = "")
+    @Operation(summary = "甯歌妫�鏌ュ畬鎴�")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
-    public CommonResult<Long> routineFinish(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
+    public CommonResult<Long> routineFinish(@Valid @RequestBody RoutineFinishReqVO routineFinishReqVO) {
+        CommonResult<Long> result = devRentService.routineFinishOperation(routineFinishReqVO);
+
         try {
-            CommonResult<Long> result = devRentService.routineFinishOperation(createReqVO);
-            return result;
-        } catch ( RuntimeException runtimeException ) {
-            String err = ExceptionUtils.formatException( runtimeException );
-            log.error("checkFinish: " + err);
-            return CommonResult.error(DEV_INSTALL_EXCEPTION);
+            String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+            String userHisId = SecurityFrameworkUtils.getLoginUserHisId();
+            Long rentId = routineFinishReqVO.getId();
+            devRentService.feeConfirm(rentId, userHisId, userNickname, true);  // 鏁呮剰 涓嶆鏌ヨ繑鍥炲��
+        } catch (Exception e) {
+            log.error("甯歌妫�鏌ュ畬鎴�, 鑷姩纭垂澶辫触", e);
         }
+
+        return result;
     }
 
     @PostMapping("/dev-ready")
-    @Operation(summary = "璁惧棰嗙敤")
+    @Operation(summary = "璁惧棰嗙敤瀹屾垚")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<Long> devReady(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
+        CommonResult<Long> result = devRentService.readyOperation(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);
+            String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+            String userHisId = SecurityFrameworkUtils.getLoginUserHisId();
+            Long rentId = createReqVO.getId();
+            devRentService.feeConfirm(rentId, userHisId, userNickname, true);  // 鏁呮剰 涓嶆鏌ヨ繑鍥炲��
+        } catch (Exception e) {
+            log.error("璁惧棰嗙敤瀹屾垚, 鑷姩纭垂澶辫触", e);
         }
+
+        return result;
     }
 
     @PostMapping("/dev-install")
     @Operation(summary = "瑁呮満")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<Long> devInstall(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
-        try {
-            return devRentService.installOperation(createReqVO);
-        } catch ( RuntimeException runtimeException ) {
-            String err = ExceptionUtils.formatException( runtimeException );
-            log.error("devInstall: " + err);
-            return CommonResult.error(DEV_INSTALL_EXCEPTION);
-        }
+        return devRentService.installOperation(createReqVO);
     }
 
     @PostMapping("/dev-dismantle")
     @Operation(summary = "鎷嗘満")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
     public CommonResult<Long> devDismantle(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
-        try {
-            devRentService.dismantleOperation(createReqVO);
-            return CommonResult.success(0L);
-        } catch ( RuntimeException runtimeException ) {
-            String err = ExceptionUtils.formatException( runtimeException );
-            log.error("devDismantle: " + err);
-            return CommonResult.error(DEV_DISMANTLE_EXCEPTION);
-        }
+        devRentService.dismantleOperation(createReqVO);
+        return CommonResult.success(0L);
     }
 
     @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);
-        }
+        devRentService.dataEntryOperation(createReqVO);
+        return CommonResult.success(0L);
+    }
+
+    @PostMapping("/routine-check-cancel")
+    @Operation(summary = "鍙栨秷甯歌妫�鏌�")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Long> routineCheckCancel(@Valid @RequestBody DevCancelReqVO cancelReqVO) {
+        return devRentService.cancelRoutineOperation(cancelReqVO);
     }
 
     @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);
-        }
+        return devRentService.cancelReadyOperation(cancelReqVO);
     }
 
     @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);
-        }
+        return devRentService.cancelInstallOperation(cancelReqVO);
     }
 
     @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);
-        }
+        loseReqVO.setState(DevStateEnum.LOST.getState());
+        return devRentService.dismantleExceptionOperation(loseReqVO);
+    }
+
+    @PostMapping("/dev-damage")
+    @Operation(summary = "鎹熷潖")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Long> devDamage(@Valid @RequestBody DevRentSaveReqVO damageReqVO) {
+        damageReqVO.setState(DevStateEnum.DAMAGED.getState());
+        return devRentService.dismantleExceptionOperation(damageReqVO);
     }
 
     @PostMapping("/create")
@@ -192,11 +186,12 @@
 
         DevRentRespVO devRentRespVO = BeanUtils.toBean(devRent, DevRentRespVO.class);
 
-        DeviceDO deviceDO = deviceService.getDevice( devRent.getDevId() );
+        DeviceDO deviceDO = deviceService.getDevice(devRent.getDevId());
         if (null != deviceDO) {
             devRentRespVO.setCategory(deviceDO.getCategory());
             devRentRespVO.setBrand(deviceDO.getBrand());
             devRentRespVO.setModel(deviceDO.getModel());
+            devRentRespVO.setDevState(deviceDO.getState());
         }
         return CommonResult.success(devRentRespVO);
     }
@@ -213,71 +208,111 @@
     @Operation(summary = "瀵煎嚭瑁呮満鎷嗘満 Excel")
     @PreAuthorize("@ss.hasPermission('ecg:dev-rent:export')")
     @ApiAccessLog(operateType = EXPORT)
-    public void exportDevRentExcel(@Valid DevRentPageReqVO pageReqVO,
-              HttpServletResponse response) throws IOException {
+    public void exportDevRentExcel(@Valid DevRentPageReqVO pageReqVO, HttpServletResponse response) throws IOException {
         pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
         List<DevRentDO> list = devRentService.getDevRentPage(pageReqVO).getList();
         // 瀵煎嚭 Excel
-        ExcelUtils.write(response, "瑁呮満鎷嗘満.xls", "鏁版嵁", DevRentRespVO.class,
-                        BeanUtils.toBean(list, DevRentRespVO.class));
+        ExcelUtils.write(response, "瑁呮満鎷嗘満.xls", "鏁版嵁", DevRentRespVO.class, BeanUtils.toBean(list, DevRentRespVO.class));
+    }
+
+    @GetMapping("/get-free-rent")
+    @Operation(summary = "鏍规嵁鎮h�呮垨璁惧, 鑾峰彇宸查鍙栫璧佹儏鍐�")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<DevRentRespVO> getFreeRent(@Valid DevRentSearchReqVO searchReqVO) {
+        DevRentDO devRent = devRentService.getFreeRent(searchReqVO);
+        if (null == devRent) {
+            return CommonResult.success(null);
+        }
+
+        DevRentRespVO devRentRespVO = BeanUtils.toBean(devRent, DevRentRespVO.class);
+        return CommonResult.success(devRentRespVO);
     }
 
     @GetMapping("/get-ready-rent")
     @Operation(summary = "鑾峰彇宸查鍙栫璧佹儏鍐�")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
-    public CommonResult<DevRentRespVO> getReadyRent( @Valid DevRentSearchReqVO searchReqVO )
-    {
-        DevRentDO devRent = devRentService.getReadyOrCancelledRent( searchReqVO );
+    public CommonResult<DevRentRespVO> getReadyRent(@Valid DevRentSearchReqVO searchReqVO) {
+        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() );
+        DeviceDO deviceDO = deviceService.getDevice(devRent.getDevId());
         if (null != deviceDO) {
             devRentRespVO.setCategory(deviceDO.getCategory());
             devRentRespVO.setBrand(deviceDO.getBrand());
             devRentRespVO.setModel(deviceDO.getModel());
+            devRentRespVO.setDevState(deviceDO.getState());
         }
         return CommonResult.success(devRentRespVO);
     }
 
-    @GetMapping("/get-installed-rent")
-    @Operation(summary = "鑾峰彇宸插畨瑁呯璧佹儏鍐�")
+    @GetMapping("/get-existing-rent")
+    @Operation(summary = "鑾峰彇宸插畨瑁呫�佸凡棰嗙敤鐨勭璧佹儏鍐�")
     @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
-    public CommonResult<DevRentRespVO> getInstalledRent( @Valid DevRentSearchReqVO searchReqVO )
-    {
-        DevRentDO devRent = devRentService.getInstalledOrCancelledRent( searchReqVO );
+    public CommonResult<DevRentRespVO> getInstalledRent(@Valid DevRentSearchReqVO searchReqVO) {
+        DevRentDO devRent = devRentService.getExistingRent(searchReqVO);
         if (null == devRent) {
             return CommonResult.success(null);
         }
 
-        DeviceDO deviceDO = deviceService.getDevice( devRent.getDevId() );
+        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() );
+        devRentRespVO.setCategory(deviceDO.getCategory());
+        devRentRespVO.setBrand(deviceDO.getBrand());
+        devRentRespVO.setModel(deviceDO.getModel());
+        devRentRespVO.setDevState(devRent.getState());
         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 );
+    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() );
+        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() );
+        devRentRespVO.setCategory(deviceDO.getCategory());
+        devRentRespVO.setBrand(deviceDO.getBrand());
+        devRentRespVO.setModel(deviceDO.getModel());
         return CommonResult.success(devRentRespVO);
     }
+
+    // 纭垂
+    @GetMapping("/fee-confirm")
+    @Operation(summary = "纭垂")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Integer> feeConfirm(@Valid Long rentId) {
+        Long userId = SecurityFrameworkUtils.getLoginUserId();
+        String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+        String userHisId = SecurityFrameworkUtils.getLoginUserHisId();
+
+        Integer result = devRentService.feeConfirm(rentId, userHisId, userNickname, true);
+        if (1 == result) return CommonResult.error(result, "纭垂澶辫触");
+
+        return CommonResult.success(result);
+    }
+
+    // 鍙栨秷纭垂
+    @GetMapping("/fee-cancel")
+    @Operation(summary = "鍙栨秷纭垂")
+    @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+    public CommonResult<Integer> feeCancel(@Valid Long rentId) {
+        Long userId = SecurityFrameworkUtils.getLoginUserId();
+        String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+        String userHisId = SecurityFrameworkUtils.getLoginUserHisId();
+
+        Integer result = devRentService.feeConfirm(rentId, userHisId, userNickname, false);
+        if (1 == result) return CommonResult.error(result, "鍙栨秷纭垂澶辫触");
+
+        return CommonResult.success(result);
+    }
 }

--
Gitblit v1.9.3