From f72802ff8037bb5dc8f0671d5e26a6523aa79c0c Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期六, 29 三月 2025 10:01:08 +0800
Subject: [PATCH] #修改    1. 添加批次编码自动生成

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/ScheduleJobs.java |   37 +++++++++++++++++++++++++++++++++++--
 1 files changed, 35 insertions(+), 2 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/ScheduleJobs.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/ScheduleJobs.java
index 991e021..a44caf1 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/ScheduleJobs.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/ScheduleJobs.java
@@ -9,6 +9,7 @@
 import com.vincent.rsf.server.manager.service.*;
 import com.vincent.rsf.server.system.constant.SerialRuleCode;
 import com.vincent.rsf.server.system.utils.SerialRuleUtils;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
@@ -98,7 +99,10 @@
                 if (Objects.isNull(matnr)) {
                     throw new CoolException("鏁版嵁閿欒锛氬綋鍓嶇墿鏂欎笉瀛樺湪!!");
                 }
-//                //TODO barcode鐢熸垚绛栫暐
+                String trackCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_LABEL_CODE, item);
+                if (StringUtils.isBlank(trackCode)) {
+                    throw new CoolException("鍗曟嵁璺熻釜鐮佺敓鎴愬け璐ワ細璇锋鏌ャ�宻ys_asn_mantr_label銆嶆槸鍚﹂厤缃畬鎴愶紒锛�");
+                }
 //                String barcode = code + matnr.getCode();
                 orderItem.setAnfme(item.getAnfme())
                         .setAsnId(order.getId())
@@ -108,10 +112,11 @@
                         .setSplrCode(item.getSplrCode())
                         .setPoDetlId(item.getId())
                         .setPlatItemId(item.getPlatItemId())
-//                        .setBarcode(barcode)
+                        .setTrackCode(trackCode)
                         .setPoCode(purchase.getCode())
                         .setPurQty(item.getAnfme())
                         .setPurUnit(item.getUnit())
+                        .setMatnrCode(matnr.getCode())
                         .setMaktx(matnr.getName())
                         .setMatnrId(matnr.getId() + "");
                 orderItems.add(orderItem);
@@ -130,4 +135,32 @@
         });
     }
 
+
+    /**
+     * 鐢熸垚鐗╂枡鏍囩
+     */
+    @Scheduled(cron = "0 0/05 * * * ?  ")
+    @Transactional(rollbackFor = Exception.class)
+    public void generateMatnrLabel() {
+        List<AsnOrderItem> list = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>()
+                        .isNull(AsnOrderItem::getTrackCode)
+                .select(AsnOrderItem::getId));
+        if (Objects.isNull(list) || list.isEmpty()) {
+            return;
+        }
+        List<AsnOrderItem> items = new ArrayList<>();
+        list.forEach(item -> {
+            String trackCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_LABEL_CODE, item);
+            if (StringUtils.isBlank(trackCode)) {
+                throw new CoolException("鍗曟嵁璺熻釜鐮佺敓鎴愬け璐ワ細璇锋鏌ャ�宻ys_asn_mantr_label銆嶆槸鍚﹂厤缃畬鎴愶紒锛�");
+            }
+            item.setTrackCode(trackCode);
+            items.add(item);
+        });
+
+        if (!asnOrderItemService.updateBatchById(items)) {
+            throw new CoolException("鐢熸垚缂栫爜澶辫触锛侊紒");
+        }
+    }
+
 }

--
Gitblit v1.9.1