From 18080d68a84f2c0ae317f4473c80b1ec492e5fd4 Mon Sep 17 00:00:00 2001
From: Junjie <540245094@qq.com>
Date: 星期五, 18 七月 2025 15:35:18 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/ytflWms' into ytflWms

---
 src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java |   84 ++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 80 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java b/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java
index 4daad98..17045e3 100644
--- a/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java
+++ b/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java
@@ -1,5 +1,6 @@
 package com.zy.asrs.task.handler;
 
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Cools;
 import com.core.exception.CoolException;
@@ -11,12 +12,15 @@
 import com.zy.asrs.utils.MathUtils;
 import com.zy.asrs.utils.OrderInAndOutUtil;
 import com.zy.common.model.DetlDto;
+import com.zy.nc.entity.NccSaleDbddWms;
+import com.zy.nc.entity.NccSaleXsfhmxWms;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.jdbc.core.JdbcTemplate;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.math.BigDecimal;
 import java.util.ArrayList;
 import java.util.List;
 
@@ -221,13 +225,49 @@
                 //鍏堟寜鐓ф壒娆″尮閰嶏紝鍐嶆寜鐓ф棤鎵规鍙锋壒娆★紝鍥犱负閿�鍞彂璐э紝鎵规鍙峰彲鑳藉甫锛屾湁鍙兘涓嶆惡甯︼紝鎵�浠ュ氨浼氭湁闂锛涜�屼笖鑰冭檻鍒颁竴鏉¤鍗曢噷濡傛灉鐩稿悓鐗╂枡锛屼竴鏉″甫鎵规锛屼竴鏉′笉甯︽壒娆★紝鎯呭喌
                 for (OrderDetl xxx : old) {
                     if (xxx.beSimilar(wrkDetl)) {
-                        orderDetl.setRemark(xxx.getRemark());
+                        if(Cools.isEmpty(orderDetl.getRemark())) {
+                            orderDetl.setRemark(xxx.getRemark());
+                        }else {
+                            NccSaleXsfhmxWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleXsfhmxWms.class);
+                            if (currentData == null) {
+                                continue;
+                            }
+
+                            NccSaleXsfhmxWms nextData = JSONObject.parseObject(xxx.getRemark(), NccSaleXsfhmxWms.class);
+                            if (nextData == null) {
+                                continue;
+                            }
+
+                            BigDecimal currentFslDecimal = currentData.getNastnum();
+                            BigDecimal nextFslDecimal = nextData.getNastnum();
+                            if(currentFslDecimal.doubleValue() < nextFslDecimal.doubleValue()) {
+                                orderDetl.setRemark(xxx.getRemark());
+                            }
+                        }
                     }
                 }
                 if (Cools.isEmpty(orderDetl.getRemark())) {
                     for (OrderDetl xxx : old) {
                         if (xxx.beSimilarByWrkDetl(wrkDetl)) {
-                            orderDetl.setRemark(xxx.getRemark());
+                            if(Cools.isEmpty(orderDetl.getRemark())) {
+                                orderDetl.setRemark(xxx.getRemark());
+                            }else {
+                                NccSaleXsfhmxWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleXsfhmxWms.class);
+                                if (currentData == null) {
+                                    continue;
+                                }
+
+                                NccSaleXsfhmxWms nextData = JSONObject.parseObject(xxx.getRemark(), NccSaleXsfhmxWms.class);
+                                if (nextData == null) {
+                                    continue;
+                                }
+
+                                BigDecimal currentFslDecimal = currentData.getNastnum();
+                                BigDecimal nextFslDecimal = nextData.getNastnum();
+                                if(currentFslDecimal.doubleValue() < nextFslDecimal.doubleValue()) {
+                                    orderDetl.setRemark(xxx.getRemark());
+                                }
+                            }
                         }
                     }
                 }
@@ -292,13 +332,49 @@
                 //鍏堟寜鐓ф壒娆″尮閰嶏紝鍐嶆寜鐓ф棤鎵规鍙锋壒娆★紝鍥犱负閿�鍞彂璐э紝鎵规鍙峰彲鑳藉甫锛屾湁鍙兘涓嶆惡甯︼紝鎵�浠ュ氨浼氭湁闂锛涜�屼笖鑰冭檻鍒颁竴鏉¤鍗曢噷濡傛灉鐩稿悓鐗╂枡锛屼竴鏉″甫鎵规锛屼竴鏉′笉甯︽壒娆★紝鎯呭喌
                 for (OrderDetl xxx : old) {
                     if (xxx.beSimilar(wrkDetl)) {
-                        orderDetl.setRemark(xxx.getRemark());
+                        if(Cools.isEmpty(orderDetl.getRemark())) {
+                            orderDetl.setRemark(xxx.getRemark());
+                        }else {
+                            NccSaleDbddWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleDbddWms.class);
+                            if (currentData == null) {
+                                continue;
+                            }
+
+                            NccSaleDbddWms nextData = JSONObject.parseObject(xxx.getRemark(), NccSaleDbddWms.class);
+                            if (nextData == null) {
+                                continue;
+                            }
+
+                            BigDecimal currentFslDecimal = currentData.getFsl();
+                            BigDecimal nextFslDecimal = nextData.getFsl();
+                            if(currentFslDecimal.doubleValue() < nextFslDecimal.doubleValue()) {
+                                orderDetl.setRemark(xxx.getRemark());
+                            }
+                        }
                     }
                 }
                 if (Cools.isEmpty(orderDetl.getRemark())) {
                     for (OrderDetl xxx : old) {
                         if (xxx.beSimilarByWrkDetl(wrkDetl)) {
-                            orderDetl.setRemark(xxx.getRemark());
+                            if(Cools.isEmpty(orderDetl.getRemark())) {
+                                orderDetl.setRemark(xxx.getRemark());
+                            }else {
+                                NccSaleDbddWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleDbddWms.class);
+                                if (currentData == null) {
+                                    continue;
+                                }
+
+                                NccSaleDbddWms nextData = JSONObject.parseObject(xxx.getRemark(), NccSaleDbddWms.class);
+                                if (nextData == null) {
+                                    continue;
+                                }
+
+                                BigDecimal currentFslDecimal = currentData.getFsl();
+                                BigDecimal nextFslDecimal = nextData.getFsl();
+                                if(currentFslDecimal.doubleValue() < nextFslDecimal.doubleValue()) {
+                                    orderDetl.setRemark(xxx.getRemark());
+                                }
+                            }
                         }
                     }
                 }

--
Gitblit v1.9.1