From d7637e7da67eed5c0c924b1200d839b2ba71a788 Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期五, 18 七月 2025 13:54:06 +0800
Subject: [PATCH] #bug修复

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java |   49 ++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 48 insertions(+), 1 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java
index e94be30..8a93ef2 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java
@@ -48,6 +48,8 @@
     private LocServiceImpl locService;
     @Autowired
     private TaskItemServiceImpl taskItemService;
+    @Autowired
+    private CheckOrderService checkOrderService;
 
     /**
      * @author Ryan
@@ -278,6 +280,10 @@
                 if (Objects.isNull(loc)) {
                     throw new CoolException("褰撳墠搴撲綅涓嶅瓨鍦紒锛�");
                 }
+                Task task1 = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getBarcode, key));
+                if (!Objects.isNull(task1)) {
+                    throw new CoolException("鎵樼洏浠诲姟宸插瓨鍦紒锛�");
+                }
                 List<CheckOrderItemParams> itemParams = listMap.get(key);
                 CheckOrderItemParams checkItem = itemParams.stream().findFirst().get();
                 Task task = new Task();
@@ -292,6 +298,8 @@
                         .setTaskType(TaskType.TASK_TYPE_CHECK_OUT.type)
                         .setTaskStatus(TaskStsType.GENERATE_OUT.id)
                         .setCreateTime(new Date())
+                        .setUpdateBy(loginUserId)
+                        .setUpdateTime(new Date())
                         .setCreateBy(loginUserId)
                         .setBarcode(key);
 
@@ -302,7 +310,6 @@
                 itemParams.forEach(item -> {
                     TaskItem taskItem = new TaskItem();
                     taskItem.setTaskId(task.getId())
-                            .setOrderId(checkParam.getOrderId())
                             .setOrderType(OrderType.ORDER_CHECK.type)
                             .setAnfme(item.getAnfme())
                             .setWorkQty(0.0)
@@ -317,12 +324,52 @@
                             .setMatnrId(checkParam.getMatnrId())
                             .setCreateBy(loginUserId)
                             .setCreateTime(new Date())
+                            .setUpdateBy(loginUserId)
+                            .setUpdateTime(new Date())
+                            .setOrderItemId(checkParam.getId())
+                            .setOrderId(checkParam.getOrderId())
                             .setPlatItemId(checkParam.getPlatItemId());
                     items.add(taskItem);
+
+                    if (!checkOrderItemService.update(new LambdaUpdateWrapper<WkOrderItem>()
+                            .eq(WkOrderItem::getId, checkParam.getId())
+                            .setSql("work_qty = work_qty + " + item.getAnfme())
+                            .set(WkOrderItem::getWorkQty, checkItem.getAnfme()))) {
+                        throw new CoolException("鐩樼偣鏄庣粏淇敼澶辫触锛侊紒");
+                    }
                 });
                 if (!taskItemService.saveBatch(items)) {
                     throw new CoolException("浠诲姟鏄庣粏淇濆瓨澶辫触锛侊紒");
                 }
+
+                loc.setUseStatus(LocStsType.LOC_STS_TYPE_R.type);
+                if (!locService.updateById(loc)) {
+                    throw new CoolException("搴撲綅棰勭害鍑哄簱澶辫触锛侊紒");
+                }
+
+            });
+
+            Set<Long> checkItemIds = checkParams.stream().map(CheckOrderParams::getOrderId).collect(Collectors.toSet());
+            checkItemIds.forEach(orderId -> {
+                WkOrder order = this.getById(orderId);
+                if (Objects.isNull(order)) {
+                    throw new CoolException("鏁版嵁閿欒锛氬崟鎹笉瀛樺湪锛侊紒");
+                }
+                List<WkOrderItem> orderItems = checkOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, orderId));
+                if (orderItems.isEmpty()) {
+                    throw new CoolException("鏁版嵁閿欒锛氬崟鎹槑缁嗕笉瀛樺湪锛侊紒");
+                }
+                Double sum = orderItems.stream().mapToDouble(WkOrderItem::getWorkQty).sum();
+
+                if (order.getAnfme().compareTo(sum) <= 0) {
+                    order.setWorkQty(sum).setExceStatus(CheckExceStatus.CHECK_ORDER_STATUS_EXCE_DONE.val);
+                } else {
+                    order.setWorkQty(sum).setExceStatus(CheckExceStatus.CHECK_ORDER_STATUS_EXCE_ING.val);
+                }
+
+                if (!this.updateById(order)) {
+                    throw new CoolException("鐩樼偣鍗曚俊鎭慨鏀瑰け璐ワ紒锛�");
+                }
             });
         }
         return R.ok();

--
Gitblit v1.9.1