From 5336bfc54525253a30f1f8238806d3a67f388e14 Mon Sep 17 00:00:00 2001
From: wangxinhui <wangxinhui@hnkhzn.com>
Date: 星期五, 21 十一月 2025 15:12:03 +0800
Subject: [PATCH] 优化接口,增加字段等

---
 项目代码/WMS/WMSServices/WIDESEA_OutboundService/OutSGOrderService.cs |   50 ++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 40 insertions(+), 10 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 6c40d09..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
 {
@@ -51,12 +54,12 @@
                 //鑾峰彇鎵�鏈夋帓绋嬪崟
                 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}宸插瓨鍦�");
-                }
+                ////鍒ゆ柇鍗曟嵁
+                //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));
@@ -66,15 +69,28 @@
                     return content.Error($"鐢熶骇鎺掔▼{sGOutOrderDTO.OrderId}鐗╂枡:{sGOutOrderDTO.MaterialNo}涓嶅瓨鍦�");
                 }
                 List<Dt_OutSGOrder> AddOutSGOrders = new List<Dt_OutSGOrder>();
-                foreach (var item in outOrderDTOs)
+                foreach (var item in outOrderDTOs.OrderBy(x=>x.Number))
                 {
                     //鑾峰彇宸ュ崟
                     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);
+                    //鑾峰彇鐗╂枡
+                    Dt_MaterielInfo? materielInfo = materielInfos.FirstOrDefault(x => x.MaterielCode == item.MaterialNo);
+                    string code = ExtractFirstPercentContent(outSGOrderDetail.Remark);
+                    //澶勭悊鐗规畩鎸囧畾鎺掔▼鍒ゆ柇
+                    if (!code.IsNullOrEmpty() && code.StartsWith(outSGOrderDetail.MaterialNo))
+                    {
+                        materielInfo = materielInfos.FirstOrDefault(x => x.MaterielCode == code);
+                        if (materielInfo==null)
+                        {
+                            return content.Error($"鐢熶骇鎺掔▼{item.OrderId}鎸囧畾鎺掔▼鐗╂枡:{code}涓嶅瓨鍦�");
+                        }
+                        outSGOrderDetail.MaterialNo = code;
+                    }
                     outSGOrderDetail.MaterialName = materielInfo.MaterielName;
+                    
                     //鍒ゆ柇宸ュ崟鏄惁宸茬粡瀛樺湪
                     if (ExistOutSGOrder != null)
                     {
@@ -82,7 +98,6 @@
                     }
                     else
                     {
-
                         Dt_OutSGOrder outSGOrder = _mapper.Map<Dt_OutSGOrder>(item);
                         outSGOrder.Details = new List<Dt_OutSGOrderDetail>() { outSGOrderDetail };
                         AddOutSGOrders.Add(outSGOrder);
@@ -97,5 +112,20 @@
             }
             return content;
         }
+        public static string ExtractFirstPercentContent(string input)
+        {
+            if (string.IsNullOrEmpty(input))
+                return null;
+
+            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