From 97834ce60827831a864ebe37e585f8a921352669 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期四, 13 十一月 2025 19:11:06 +0800
Subject: [PATCH] 文件名修改
---
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java | 264 ++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 244 insertions(+), 20 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 bd79b4f..3f49886 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,5 +1,13 @@
package cn.lihu.jh.module.ecg.controller.admin.devrent;
+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;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import org.springframework.security.access.prepost.PreAuthorize;
@@ -14,11 +22,11 @@
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.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 cn.lihu.jh.module.ecg.controller.admin.devrent.vo.*;
@@ -29,67 +37,283 @@
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
-@Tag(name = "绠$悊鍚庡彴 - 瑁呮満鎷嗘満")
+@Tag(name = "瑁呮満鎷嗘満")
@RestController
@RequestMapping("/ecg/dev-rent")
@Validated
+@Slf4j
public class DevRentController {
@Resource
private DevRentService devRentService;
+ @Resource
+ private DeviceService deviceService;
+
+ @Resource
+ private QueueService queueService;
+
+ @Resource
+ private AppointmentService appointmentService;
+
+ // 甯歌妫�鏌� 瀹屾垚
+ @PostMapping("/routine-finish")
+ @Operation(summary = "甯歌妫�鏌ュ畬鎴�")
+ @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+ public CommonResult<Long> routineFinish(@Valid @RequestBody RoutineFinishReqVO routineFinishReqVO) {
+ CommonResult<Long> result = devRentService.routineFinishOperation(routineFinishReqVO);
+
+ try {
+ 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 = "璁惧棰嗙敤瀹屾垚")
+ @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+ public CommonResult<Long> devReady(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
+ String userHisId = SecurityFrameworkUtils.getLoginUserHisId();
+ String userNickname = SecurityFrameworkUtils.getLoginUserNickname();
+ createReqVO.setOperater(userNickname);
+ CommonResult<Long> result = devRentService.readyOperation(createReqVO);
+
+ try {
+ 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) {
+ return devRentService.installOperation(createReqVO);
+ }
+
+ @PostMapping("/dev-dismantle")
+ @Operation(summary = "鎷嗘満")
+ @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+ public CommonResult<Long> devDismantle(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
+ 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) {
+ 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) {
+ return devRentService.cancelReadyOperation(cancelReqVO);
+ }
+
+ @PostMapping("/dev-install-cancel")
+ @Operation(summary = "鍙栨秷瑁呮満")
+ @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+ public CommonResult<Long> devInstallCancel(@Valid @RequestBody DevCancelReqVO cancelReqVO) {
+ return devRentService.cancelInstallOperation(cancelReqVO);
+ }
+
+ @PostMapping("/dev-lose")
+ @Operation(summary = "閬楀け")
+ @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+ public CommonResult<Long> devLose(@Valid @RequestBody DevRentSaveReqVO loseReqVO) {
+ 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")
@Operation(summary = "鍒涘缓瑁呮満鎷嗘満")
- @PreAuthorize("@ss.hasPermission('ecg:dev-rent:create')")
- public CommonResult<Integer> createDevRent(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
- return success(devRentService.createDevRent(createReqVO));
+ @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+ public CommonResult<Long> createDevRent(@Valid @RequestBody DevRentSaveReqVO createReqVO) {
+ return CommonResult.success(devRentService.createDevRent(createReqVO));
}
@PutMapping("/update")
@Operation(summary = "鏇存柊瑁呮満鎷嗘満")
- @PreAuthorize("@ss.hasPermission('ecg:dev-rent:update')")
+ @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")
@Operation(summary = "鍒犻櫎瑁呮満鎷嗘満")
@Parameter(name = "id", description = "缂栧彿", required = true)
- @PreAuthorize("@ss.hasPermission('ecg:dev-rent:delete')")
- public CommonResult<Boolean> deleteDevRent(@RequestParam("id") Integer id) {
+ @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")
@Operation(summary = "鑾峰緱瑁呮満鎷嗘満")
@Parameter(name = "id", description = "缂栧彿", required = true, example = "1024")
- @PreAuthorize("@ss.hasPermission('ecg:dev-rent:query')")
- public CommonResult<DevRentRespVO> getDevRent(@RequestParam("id") Integer id) {
+ @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());
+ devRentRespVO.setDevState(deviceDO.getState());
+ }
+ return CommonResult.success(devRentRespVO);
}
@GetMapping("/page")
@Operation(summary = "鑾峰緱瑁呮満鎷嗘満鍒嗛〉")
- @PreAuthorize("@ss.hasPermission('ecg:dev-rent:query')")
+ @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")
@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));
}
-}
\ No newline at end of file
+ @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);
+ 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());
+ devRentRespVO.setDevState(deviceDO.getState());
+ }
+ return CommonResult.success(devRentRespVO);
+ }
+
+ @GetMapping("/get-existing-rent")
+ @Operation(summary = "鑾峰彇宸插畨瑁呫�佸凡棰嗙敤鐨勭璧佹儏鍐�")
+ @PreAuthorize("@ss.hasPermission('ecg:doctor:task')")
+ 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());
+
+ DevRentRespVO devRentRespVO = BeanUtils.toBean(devRent, DevRentRespVO.class);
+ 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);
+ 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("/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