From f5b4f189e460480a96acf3d1864344d8d5d92695 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期三, 07 五月 2025 10:18:57 +0800
Subject: [PATCH] PO单模板优化 ASN单模板优化

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/QlyIsptItemServiceImpl.java |   17 ++++++++++++++++-
 1 files changed, 16 insertions(+), 1 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/QlyIsptItemServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/QlyIsptItemServiceImpl.java
index ea34d24..04257e1 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/QlyIsptItemServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/QlyIsptItemServiceImpl.java
@@ -30,6 +30,7 @@
 
     @Autowired
     private QlyInspectService qlyInspectService;
+    @Autowired
     private AsnOrderItemService asnOrderItemService;
 
     /**
@@ -82,9 +83,23 @@
             items.forEach(qlyIsptItem -> {
                 AsnOrderItem orderItem = asnOrderItemService.getById(qlyIsptItem.getAsnItemId());
                 if (qlyIsptItem.getSafeQty().compareTo(orderItem.getAnfme()) >= 0.00) {
-                    orderItem.setIsptResult()
+                    orderItem.setIsptResult(QlyIsptResult.QLY_ISPT_RESULT_EXCELLENT.val)
+                            .setIsptStatus(QlyIsptStatus.QLY_ISPT_STAS_DONE.val);
+                } else if (qlyIsptItem.getSafeQty().compareTo(0.00) > 0.00 && qlyIsptItem.getSafeQty().compareTo(orderItem.getAnfme()) < 0.00) {
+                    orderItem.setIsptResult(QlyIsptResult.QLY_ISPT_RESULT_SECTION.val);
+                    if (Double.compare(qlyIsptItem.getSafeQty() + qlyIsptItem.getDisQty(), orderItem.getAnfme()) >= 0.00 ) {
+                        orderItem.setIsptStatus(QlyIsptStatus.QLY_ISPT_STAS_DONE.val);
+                    } else {
+                        orderItem.setIsptStatus(QlyIsptStatus.QLY_ISPT_STAS_ING.val);
+                    }
+                } else {
+                    orderItem.setIsptResult(QlyIsptResult.QLY_ISPT_RESULT_DEFECT.val)
+                            .setIsptStatus(QlyIsptStatus.QLY_ISPT_STAS_DONE.val);
                 }
 
+                if (!asnOrderItemService.updateById(orderItem)) {
+                    throw new CoolException("鏀惰揣鍗曟槑缁嗕慨鏀瑰け璐ワ紒锛�");
+                }
             });
             Double safeQty = items.stream().mapToDouble(QlyIsptItem::getSafeQty).sum();
             Double disQty = items.stream().mapToDouble(QlyIsptItem::getDisQty).sum();

--
Gitblit v1.9.1