From 691bee4229856f8bf81c2720092ecee1c9f21509 Mon Sep 17 00:00:00 2001
From: zhou zhou <3272660260@qq.com>
Date: 星期四, 09 四月 2026 19:18:12 +0800
Subject: [PATCH] #getter$摘出entity

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckDiffItemController.java |   85 +++++++++++++++++++++++++++++++++---------
 1 files changed, 66 insertions(+), 19 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckDiffItemController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckDiffItemController.java
index 1ccf55c..db6d6c4 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckDiffItemController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CheckDiffItemController.java
@@ -1,57 +1,73 @@
 package com.vincent.rsf.server.manager.controller;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.vincent.rsf.framework.common.Cools;
 import com.vincent.rsf.framework.common.R;
+import com.vincent.rsf.framework.exception.CoolException;
 import com.vincent.rsf.server.common.utils.ExcelUtil;
 import com.vincent.rsf.server.common.annotation.OperationLog;
 import com.vincent.rsf.server.common.domain.BaseParam;
 import com.vincent.rsf.server.common.domain.KeyValVo;
 import com.vincent.rsf.server.common.domain.PageParam;
+import com.vincent.rsf.server.manager.entity.CheckDiff;
 import com.vincent.rsf.server.manager.entity.CheckDiffItem;
+import com.vincent.rsf.server.manager.entity.WkOrder;
+import com.vincent.rsf.server.manager.enums.CheckDiffExceStatus;
+import com.vincent.rsf.server.manager.enums.CheckExceStatus;
 import com.vincent.rsf.server.manager.service.CheckDiffItemService;
+import com.vincent.rsf.server.manager.service.CheckDiffService;
+import com.vincent.rsf.server.manager.service.CheckOrderService;
+import com.vincent.rsf.server.manager.service.impl.CheckDiffServiceImpl;
+import com.vincent.rsf.server.manager.utils.buildPageRowsUtils;
 import com.vincent.rsf.server.system.controller.BaseController;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.web.bind.annotation.*;
 
-import javax.servlet.http.HttpServletResponse;
+import jakarta.servlet.http.HttpServletResponse;
 import java.util.*;
+import java.util.stream.Collectors;
 
 @RestController
 public class CheckDiffItemController extends BaseController {
 
     @Autowired
     private CheckDiffItemService checkDiffItemService;
+    @Autowired
+    private CheckDiffService checkDiffService;
+    @Autowired
+    private CheckOrderService checkOrderService;
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:list')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:list')")
     @PostMapping("/checkDiffItem/page")
     public R page(@RequestBody Map<String, Object> map) {
         BaseParam baseParam = buildParam(map, BaseParam.class);
         PageParam<CheckDiffItem, BaseParam> pageParam = new PageParam<>(baseParam, CheckDiffItem.class);
-        return R.ok().add(checkDiffItemService.page(pageParam, pageParam.buildWrapper(true)));
+        PageParam<CheckDiffItem, BaseParam> page = checkDiffItemService.page(pageParam, pageParam.buildWrapper(true));
+        return R.ok().add(buildPageRowsUtils.rowsMap(page));
     }
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:list')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:list')")
     @PostMapping("/checkDiffItem/list")
     public R list(@RequestBody Map<String, Object> map) {
-        return R.ok().add(checkDiffItemService.list());
+        return R.ok().add(buildPageRowsUtils.rowsMap(checkDiffItemService.list()));
     }
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:list')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:list')")
     @PostMapping({"/checkDiffItem/many/{ids}", "/checkDiffItems/many/{ids}"})
     public R many(@PathVariable Long[] ids) {
-        return R.ok().add(checkDiffItemService.listByIds(Arrays.asList(ids)));
+        return R.ok().add(buildPageRowsUtils.rowsMap(checkDiffItemService.listByIds(Arrays.asList(ids))));
     }
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:list')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:list')")
     @GetMapping("/checkDiffItem/{id}")
     public R get(@PathVariable("id") Long id) {
-        return R.ok().add(checkDiffItemService.getById(id));
+        return R.ok().add(buildPageRowsUtils.rowsMap(checkDiffItemService.getById(id)));
     }
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:save')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:save')")
     @OperationLog("Create 鐩樼偣鏄庣粏宸紓琛�")
     @PostMapping("/checkDiffItem/save")
     public R save(@RequestBody CheckDiffItem checkDiffItem) {
@@ -62,10 +78,10 @@
         if (!checkDiffItemService.save(checkDiffItem)) {
             return R.error("Save Fail");
         }
-        return R.ok("Save Success").add(checkDiffItem);
+        return R.ok("Save Success").add(buildPageRowsUtils.rowsMap(checkDiffItem));
     }
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:update')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:update')")
     @OperationLog("Update 鐩樼偣鏄庣粏宸紓琛�")
     @PostMapping("/checkDiffItem/update")
     public R update(@RequestBody CheckDiffItem checkDiffItem) {
@@ -74,20 +90,51 @@
         if (!checkDiffItemService.updateById(checkDiffItem)) {
             return R.error("Update Fail");
         }
-        return R.ok("Update Success").add(checkDiffItem);
+
+        List<CheckDiffItem> diffItems = checkDiffItemService.list(new LambdaQueryWrapper<CheckDiffItem>().eq(CheckDiffItem::getCheckId, checkDiffItem.getCheckId()));
+        if (!diffItems.isEmpty()) {
+            Map<Integer, List<CheckDiffItem>> listMap = diffItems.stream().collect(Collectors.groupingBy(CheckDiffItem::getExceStatus));
+            List<CheckDiffItem> checkDiffItems = listMap.get(CheckDiffExceStatus.CHECK_DIFF_EXCE_STATUS_END.val);
+            if (checkDiffItems != null && diffItems.size() == checkDiffItems.size()) {
+                if (!checkDiffService.update(new LambdaUpdateWrapper<CheckDiff>()
+                        .eq(CheckDiff::getId, checkDiffItem.getCheckId())
+                        .set(CheckDiff::getExceStatus, CheckDiffExceStatus.CHECK_DIFF_EXCE_STATUS_END.val))) {
+                    throw new CoolException("鐩樼偣鍗曠姸鎬佹洿鏂板け璐ワ紒锛�");
+                }
+                // 浠呭湪鏈夊崟鏃舵洿鏂扮洏鐐瑰崟(WkOrder)鎵ц鐘舵�侊紱鏃犲崟鐩樼偣鏃犵洏鐐瑰崟锛屼笉鏇存柊
+                CheckDiff checkDiff = checkDiffService.getById(checkDiffItem.getCheckId());
+                if (checkDiff != null && checkDiff.getOrderId() != null) {
+                    WkOrder order = checkOrderService.getById(checkDiff.getOrderId());
+                    if (order == null) {
+                        throw new CoolException("鐩樼偣鍗曚笉瀛樺湪锛侊紒");
+                    }
+                    order.setExceStatus(CheckExceStatus.CHECK_ORDER_STATUS_EXCE_DONE.val);
+                    if (!checkOrderService.updateById(order)) {
+                        throw new CoolException("鐩樼偣鍗曟墽琛岀姸鎬佷慨鏀瑰け璐ワ紒锛�");
+                    }
+                }
+            } else {
+                if (!checkDiffService.update(new LambdaUpdateWrapper<CheckDiff>()
+                        .eq(CheckDiff::getId, checkDiffItem.getCheckId())
+                        .set(CheckDiff::getExceStatus, CheckDiffExceStatus.CHECK_DIFF_EXCE_STATUS_HOLD.val))) {
+                    throw new CoolException("鐩樼偣鍗曠姸鎬佹洿鏂板け璐ワ紒锛�");
+                }
+            }
+        }
+        return R.ok("Update Success").add(buildPageRowsUtils.rowsMap(checkDiffItem));
     }
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:remove')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:remove')")
     @OperationLog("Delete 鐩樼偣鏄庣粏宸紓琛�")
     @PostMapping("/checkDiffItem/remove/{ids}")
     public R remove(@PathVariable Long[] ids) {
         if (!checkDiffItemService.removeByIds(Arrays.asList(ids))) {
             return R.error("Delete Fail");
         }
-        return R.ok("Delete Success").add(ids);
+        return R.ok("Delete Success").add(buildPageRowsUtils.rowsMap(ids));
     }
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:list')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:list')")
     @PostMapping("/checkDiffItem/query")
     public R query(@RequestParam(required = false) String condition) {
         List<KeyValVo> vos = new ArrayList<>();
@@ -98,13 +145,13 @@
         checkDiffItemService.page(new Page<>(1, 30), wrapper).getRecords().forEach(
                 item -> vos.add(new KeyValVo(item.getId(), item.getId()))
         );
-        return R.ok().add(vos);
+        return R.ok().add(buildPageRowsUtils.rowsMap(vos));
     }
 
-    @PreAuthorize("hasAuthority('manager:checkDiffItem:list')")
+    @PreAuthorize("hasAuthority('manager:checkDiff:list')")
     @PostMapping("/checkDiffItem/export")
     public void export(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
-        ExcelUtil.build(ExcelUtil.create(checkDiffItemService.list(), CheckDiffItem.class), response);
+        ExcelUtil.build(ExcelUtil.create(buildPageRowsUtils.rowsMap(checkDiffItemService.list()), CheckDiffItem.class), response);
     }
 
 }

--
Gitblit v1.9.1