From 9086b238cd9fbb9fbeae7cab11d59576cd9d2853 Mon Sep 17 00:00:00 2001
From: liulijun <liulijun@hnkhzn.com>
Date: 星期一, 24 十一月 2025 10:27:01 +0800
Subject: [PATCH] 合并

---
 项目代码/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs |  121 +++++++++++++++++++++++++---------------
 1 files changed, 76 insertions(+), 45 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs"
index e4416b0..14554e5 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs"
@@ -20,6 +20,9 @@
 using WIDESEA_Common.WareHouseEnum;
 using WIDESEA_Core.Helper;
 using System.Reflection;
+using System.Text.RegularExpressions;
+using Microsoft.AspNetCore.Http;
+using HslCommunication;
 
 namespace WIDESEA_OutboundService
 {
@@ -45,56 +48,84 @@
         
         public WebResponseContent AddOutSGOrder(List<SGOutOrderDTO> outOrderDTOs)
         {
-            
-                WebResponseContent content = new WebResponseContent();
-                try
+            WebResponseContent content = new WebResponseContent();
+            try
+            {
+                //鑾峰彇鎵�鏈夋帓绋嬪崟
+                List<Dt_OutSGOrder> outSGOrders = BaseDal.Db.Queryable<Dt_OutSGOrder>().Includes(x => x.Details).ToList();
+                List<Dt_OutSGOrderDetail> outSGOrderDetails= outSGOrders.SelectMany(x=>x.Details).ToList();
+                ////鍒ゆ柇鍗曟嵁
+                //Dt_OutSGOrderDetail? ExistAddOutOrderDetail = outSGOrderDetails.FirstOrDefault(x => outOrderDTOs.Select(t => t.BoardMpsDetailId).Distinct().Contains(x.BoardMpsDetailId));
+                //if (ExistAddOutOrderDetail != null)
+                //{
+                //    return content.Error($"鍑哄簱鎺掔▼鏄庣粏{nameof(SGOutOrderDTO.BoardMpsDetailId)}:{ExistAddOutOrderDetail.BoardMpsDetailId}宸插瓨鍦�");
+                //}
+                //鑾峰彇鎵�鏈夌墿鏂�
+                List<Dt_MaterielInfo> materielInfos = _basicRepository.MaterielInfoRepository.QueryData(x => x.WarehouseId == WarehouseEnum.LLDYL.ObjToInt() && x.MaterielInvOrgId == MaterielInvOrgEnum.鑰佸巶.ObjToInt() && x.MaterialSourceId != 0);
+                SGOutOrderDTO? sGOutOrderDTO = outOrderDTOs.FirstOrDefault(x => !materielInfos.Select(x => x.MaterielCode).Contains(x.MaterialNo));
+                //SGOutOrderDTO? sGOutOrderDTO = outOrderDTOs.FirstOrDefault(x => materielInfos.FirstOrDefault(t=>t.MaterielCode.StartsWith(x.MaterialNo))==null);
+                if (sGOutOrderDTO != null)
                 {
-                    //鑾峰彇鎵�鏈夋帓绋嬪崟
-                    List<Dt_OutSGOrder> outSGOrders = BaseDal.Db.Queryable<Dt_OutSGOrder>().Includes(x => x.Details).ToList();
-                    //鍒ゆ柇鍗曟嵁
-                    Dt_OutSGOrder? ExistAddOutOrder = outSGOrders.FirstOrDefault(x => outOrderDTOs.Select(x => x.OrderId).Distinct().Contains(x.OrderId));
-                    if (ExistAddOutOrder != null)
+                    return content.Error($"鐢熶骇鎺掔▼{sGOutOrderDTO.OrderId}鐗╂枡:{sGOutOrderDTO.MaterialNo}涓嶅瓨鍦�");
+                }
+                List<Dt_OutSGOrder> AddOutSGOrders = new List<Dt_OutSGOrder>();
+                foreach (var item in outOrderDTOs.OrderBy(x=>x.Number))
+                {
+                    //鑾峰彇宸ュ崟
+                    Dt_OutSGOrder? ExistOutSGOrder = AddOutSGOrders.FirstOrDefault(x => x.OrderId == item.OrderId);
+                    
+                    //鏄庣粏鎻愬墠杞崲
+                    Dt_OutSGOrderDetail outSGOrderDetail = _mapper.Map<Dt_OutSGOrderDetail>(item);
+                    //鑾峰彇鐗╂枡
+                    Dt_MaterielInfo? materielInfo = materielInfos.FirstOrDefault(x => x.MaterielCode == item.MaterialNo);
+                    string code = ExtractFirstPercentContent(outSGOrderDetail.Remark);
+                    //澶勭悊鐗规畩鎸囧畾鎺掔▼鍒ゆ柇
+                    if (!code.IsNullOrEmpty() && code.StartsWith(outSGOrderDetail.MaterialNo))
                     {
-                        return content.Error($"鍑哄簱鎺掔▼鍗曞彿{nameof(SGOutOrderDTO.OrderId)}:{ExistAddOutOrder.OrderId}宸插瓨鍦�");
-                    }
-                    //鑾峰彇鎵�鏈夌墿鏂� 
-                    List<Dt_MaterielInfo> materielInfos = _basicRepository.MaterielInfoRepository.QueryData(x => x.WarehouseId == WarehouseEnum.LLDYL.ObjToInt() && x.MaterielInvOrgId == MaterielInvOrgEnum.鑰佸巶.ObjToInt() && x.MaterialSourceId != 0);
-                    SGOutOrderDTO? sGOutOrderDTO = outOrderDTOs.FirstOrDefault(x => !materielInfos.Select(x => x.MaterielCode).Contains(x.MaterialNo));
-                    if (sGOutOrderDTO != null)
-                    {
-                        return content.Error($"鐢熶骇鎺掔▼{sGOutOrderDTO.OrderId}鐗╂枡:{sGOutOrderDTO.MaterialNo}涓嶅瓨鍦�");
-                    }
-                    List<Dt_OutSGOrder> AddOutSGOrders = new List<Dt_OutSGOrder>();
-                    foreach (var item in outOrderDTOs)
-                    {
-                        //鑾峰彇宸ュ崟
-                        Dt_OutSGOrder? ExistOutSGOrder = AddOutSGOrders.FirstOrDefault(x => x.OrderId == item.OrderId);
-                        //鑾峰彇鐗╂枡
-                        Dt_MaterielInfo materielInfo = materielInfos.FirstOrDefault(x => x.MaterielCode == item.MaterialNo);
-                        //鏄庣粏鎻愬墠杞崲
-                        Dt_OutSGOrderDetail outSGOrderDetail = _mapper.Map<Dt_OutSGOrderDetail>(item);
-                        outSGOrderDetail.MaterialName = materielInfo.MaterielName;
-                        //鍒ゆ柇宸ュ崟鏄惁宸茬粡瀛樺湪
-                        if (ExistOutSGOrder != null)
+                        materielInfo = materielInfos.FirstOrDefault(x => x.MaterielCode == code);
+                        if (materielInfo==null)
                         {
-                            ExistOutSGOrder.Details.Add(outSGOrderDetail);
+                            return content.Error($"鐢熶骇鎺掔▼{item.OrderId}鎸囧畾鎺掔▼鐗╂枡:{code}涓嶅瓨鍦�");
                         }
-                        else
-                        {
+                        outSGOrderDetail.MaterialNo = code;
+                    }
+                    outSGOrderDetail.MaterialName = materielInfo.MaterielName;
+                    
+                    //鍒ゆ柇宸ュ崟鏄惁宸茬粡瀛樺湪
+                    if (ExistOutSGOrder != null)
+                    {
+                        ExistOutSGOrder.Details.Add(outSGOrderDetail);
+                    }
+                    else
+                    {
+                        Dt_OutSGOrder outSGOrder = _mapper.Map<Dt_OutSGOrder>(item);
+                        outSGOrder.Details = new List<Dt_OutSGOrderDetail>() { outSGOrderDetail };
+                        AddOutSGOrders.Add(outSGOrder);
+                    }
+                }
+                BaseDal.Db.InsertNav(AddOutSGOrders).Include(x => x.Details).ExecuteCommand();
+                content.OK("鎺ユ敹鎺掔▼鎴愬姛");
+            }
+            catch (Exception ex)
+            {
+                content.Error(ex.Message);
+            }
+            return content;
+        }
+        public static string ExtractFirstPercentContent(string input)
+        {
+            if (string.IsNullOrEmpty(input))
+                return null;
 
-                            Dt_OutSGOrder outSGOrder = _mapper.Map<Dt_OutSGOrder>(item);
-                            outSGOrder.Details = new List<Dt_OutSGOrderDetail>() { outSGOrderDetail };
-                            AddOutSGOrders.Add(outSGOrder);
-                        }
-                    }
-                    BaseDal.Db.InsertNav(AddOutSGOrders).Include(x => x.Details).ExecuteCommand();
-                    content.OK("鎺ユ敹鎺掔▼鎴愬姛");
-                }
-                catch (Exception ex)
-                {
-                    content.Error(ex.Message);
-                }
-                return content;
+            Regex regex = new Regex(@"%(.*?)%");
+            Match match = regex.Match(input);
+
+            if (match.Success && match.Groups[1].Success)
+            {
+                return match.Groups[1].Value.Trim();
+            }
+
+            return null;
         }
     }
 }

--
Gitblit v1.9.3