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_InboundService/MESProInOrderInfoService.cs |  117 ++++++++++++++++++++++++++--------------------------------
 1 files changed, 52 insertions(+), 65 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_InboundService/MESProInOrderInfoService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_InboundService/MESProInOrderInfoService.cs"
index 755c45e..4096a29 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_InboundService/MESProInOrderInfoService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_InboundService/MESProInOrderInfoService.cs"
@@ -3,6 +3,7 @@
 using System.Collections.Generic;
 using System.Linq;
 using System.Text;
+using System.Text.RegularExpressions;
 using System.Threading.Tasks;
 using WIDESEA_Common.MaterielEnum;
 using WIDESEA_Common.OrderEnum;
@@ -11,6 +12,8 @@
 using WIDESEA_Core.BaseServices;
 using WIDESEA_Core.Helper;
 using WIDESEA_DTO.MES;
+using WIDESEA_External.MESService;
+using WIDESEA_External.Model;
 using WIDESEA_IBasicRepository;
 using WIDESEA_IInboundRepository;
 using WIDESEA_IInboundService;
@@ -24,75 +27,15 @@
         private readonly IBasicRepository _basicRepository;
         private readonly IAGVStationInfoRepository _agvStationInfoRepository;
         private readonly IMapper _mapper;
-        public MESProInOrderInfoService(IMESProInOrderInfoRepository BaseDal,IBasicRepository basicRepository,IMapper mapper, IAGVStationInfoRepository agvStationInfoRepository) : base(BaseDal)
+        private readonly IInvokeMESService _invokeMESService;
+        public MESProInOrderInfoService(IMESProInOrderInfoRepository BaseDal,IBasicRepository basicRepository,IMapper mapper, IAGVStationInfoRepository agvStationInfoRepository,IInvokeMESService invokeMESService) : base(BaseDal)
         {
             _basicRepository = basicRepository;
             _mapper = mapper;
             _agvStationInfoRepository = agvStationInfoRepository;
+            _invokeMESService = invokeMESService;
         }
 
-        /// <summary>
-        /// 鎴愬搧/鍗婃垚鍝佷俊鎭悓姝ユ帴鍙�
-        /// </summary>
-        public WebResponseContent ReceiveProCodeInfo(List<MESProInDTO> proInDTOs)
-        {
-            WebResponseContent content = new WebResponseContent();
-            try
-            {
-                if (proInDTOs==null || proInDTOs.Count<=0)
-                {
-                    return content.Error("浼犲叆淇℃伅涓虹┖");
-                }
-                //鑾峰彇鎵�鏈夋垚鍝侊紝鍗婃垚鍝佷俊鎭�
-                List<Dt_MESProInOrderInfo> proInOrderInfos = BaseDal.QueryData();
-                //鑾峰彇鎵�鏈夌墿鏂欎俊鎭�
-                List<Dt_MaterielInfo> materielInfos = _basicRepository.MaterielInfoRepository.QueryData(x => x.MaterielInvOrgId == MaterielInvOrgEnum.鏂板巶.ObjToInt());
-                
-                MESProInDTO? CheckMaterialCode = proInDTOs.FirstOrDefault(x => !materielInfos.Select(x => x.MaterielCode).Contains(x.MaterialCode));
-                if (CheckMaterialCode != null)
-                {
-                    return content.Error($"鐗╂枡缂栫爜{nameof(MESProInDTO.MaterialCode)}:{CheckMaterialCode.MaterialCode}淇℃伅涓嶅瓨鍦�");
-                }
-                //鑾峰彇鎵�鏈堿GV鐐逛綅
-                List<Dt_AGVStationInfo> aGVStationInfos = _agvStationInfoRepository.QueryData(x => !string.IsNullOrEmpty(x.MESPointCode));
-                
-                //鍒ゆ柇鏄惁瀛樺湪閲嶅
-                MESProInDTO? proInDTO = proInDTOs.FirstOrDefault(x=>x.IsMantissa==false && proInOrderInfos.Select(x=>x.BarCode).Contains(x.BarCode));
-                if (proInDTO!=null)
-                {
-                    return content.Error($"{proInDTO.ProductOrderNo}鐢熶骇宸ュ崟{proInDTO.BarCode}鏉$爜宸插瓨鍦�");
-                }
-                Dt_MESProInOrderInfo? proInOrderInfo = proInOrderInfos.FirstOrDefault(x=>x.MESProInStatus==InOrderStatusEnum.鍏抽棴.ObjToInt() && proInDTOs.Select(x=>x.ProductOrderNo).Distinct().Contains(x.ProductOrderNo));
-                if (proInOrderInfo != null)
-                {
-                    return content.Error($"{proInOrderInfo.ProductOrderNo}鐢熶骇宸ュ崟宸插叧闂�");
-                }
-                List<Dt_MESProInOrderInfo> AddMESProInOrders = new List<Dt_MESProInOrderInfo>();
-                foreach (var item in proInDTOs)
-                {
-                    Dt_MaterielInfo materielInfo = materielInfos.FirstOrDefault(x=>x.MaterielCode== item.MaterialCode);
-                    if (materielInfo.MaterielSourceType!=MaterielTypeEnum.鎴愬搧.ObjToInt())
-                    {
-                        Dt_AGVStationInfo? CheckPointCode = aGVStationInfos.FirstOrDefault(x=>x.MESPointCode==item?.PointCode);
-                        if (CheckPointCode == null)
-                        {
-                            return content.Error($"鍛ㄨ浆浣峽nameof(MESReturnIssueDTO.PointCode)}{item?.PointCode}涓嶅瓨鍦�,浠呮垚鍝佺墿鏂欏彲涓嶄紶");
-                        }
-                    }
-                    Dt_MESProInOrderInfo AddproInOrderInfo = _mapper.Map<Dt_MESProInOrderInfo>(item);
-                    AddproInOrderInfo.WarehouseId = materielInfo.WarehouseId;
-                    AddproInOrderInfo.MESProOrderType = materielInfo.MaterielSourceType;
-                    AddMESProInOrders.Add(AddproInOrderInfo);
-                }
-                BaseDal.AddData(AddMESProInOrders);
-                content.OK("鎺ユ敹鎴愬姛");
-            }
-            catch (Exception ex)
-            {
-                content.Error(ex.Message);
-            }
-            return content;
-        }
         /// <summary>
         /// MES宸ュ崟鍋滄鎺ュ彛
         /// </summary>
@@ -107,14 +50,14 @@
                     return content.Error("浼犲叆淇℃伅涓嶈兘涓虹┖");
                 }
                 //鑾峰彇瀵瑰簲鍗曟嵁
-                List<Dt_MESProInOrderInfo>? mESProInOrderInfos = BaseDal.QueryData(x => x.ProductOrderNo == orderStopDTO.ProductOrderNo && x.MESProInStatus != OutOrderStatusEnum.鍏抽棴.ObjToInt());
+                List<Dt_MESProInOrderInfo>? mESProInOrderInfos = BaseDal.QueryData(x => x.ProductOrderNo == orderStopDTO.ProductOrderNo && x.MESProInStatus != InOrderStatusEnum.鍏抽棴.ObjToInt());
                 if (mESProInOrderInfos == null || mESProInOrderInfos.Count <= 0)
                 {
                     return content.Error($"鎴愬搧鎴栧崐鎴愬搧宸ュ崟{nameof(MESOrderStopDTO.ProductOrderNo)}{orderStopDTO.ProductOrderNo}涓嶅瓨鍦ㄦ垨宸插叧闂�");
                 }
                 mESProInOrderInfos.ForEach(x =>
                 {
-                    x.MESProInStatus = OutOrderStatusEnum.鍏抽棴.ObjToInt();
+                    x.MESProInStatus = InOrderStatusEnum.鍏抽棴.ObjToInt();
                 });
                 BaseDal.UpdateData(mESProInOrderInfos);
                 content.OK($"宸ュ崟{nameof(MESOrderStopDTO.ProductOrderNo)}{orderStopDTO.ProductOrderNo}鍋滄鎴愬姛");
@@ -125,5 +68,49 @@
             }
             return content;
         }
+        /// <summary>
+        /// MES宸ュ崟鍋滄鎺ュ彛
+        /// </summary>
+        /// <summary>
+        public WebResponseContent MESBoxCode(string boxCode)
+        {
+            WebResponseContent content = new WebResponseContent();
+            try
+            {
+                if (boxCode.IsNullOrEmpty())
+                {
+                    return content.Error("浼犲叆淇℃伅涓嶈兘涓虹┖");
+                }
+                //鑾峰彇瀵瑰簲鍗曟嵁
+                Dt_MESProInOrderInfo mESProInOrderInfo = BaseDal.QueryFirst(x => x.BarCode == boxCode);
+                if (mESProInOrderInfo == null)
+                {
+                    return content.Error($"鎴愬搧鏉$爜{boxCode}涓嶅瓨鍦�");
+                }
+                if (mESProInOrderInfo.MESProInStatus==InOrderStatusEnum.鍏ュ簱瀹屾垚.ObjToInt())
+                {
+                    return content.Error($"鎴愬搧鏉$爜{boxCode}宸插叆搴�");
+                }
+                mESProInOrderInfo.MESProInStatus = InOrderStatusEnum.鍏ュ簱瀹屾垚.ObjToInt();
+                MESResponse response = _invokeMESService.MESBoxCodeNotice(boxCode).DeserializeObject<MESResponse>() ?? throw new Exception("鏈幏鍙栧埌MES杩斿洖淇℃伅");
+                if (!response.Result)
+                {
+                    throw new Exception($"MES閰嶉�佸嚭鍙戞帴鍙h皟鐢ㄦ姤閿�,MES杩斿洖淇℃伅{DecodeUnicode(response.Msg)}");
+                }
+                BaseDal.UpdateData(mESProInOrderInfo);
+                content.OK($"鎴愬搧鏉$爜{boxCode}鎵爜鍏ュ簱");
+            }
+            catch (Exception ex)
+            {
+                content.Error(ex.Message);
+            }
+            return content;
+        }
+        public static string DecodeUnicode(string input)
+        {
+            return Regex.Replace(input, @"\\u([0-9a-fA-F]{4})", match => {
+                return ((char)Convert.ToInt32(match.Groups[1].Value, 16)).ToString();
+            });
+        }
     }
 }

--
Gitblit v1.9.3