From e3c9cde82865df66a7018565c1b84ab2a04739ee Mon Sep 17 00:00:00 2001
From: 肖洋 <cathay_xy@163.com>
Date: 星期二, 07 一月 2025 16:03:28 +0800
Subject: [PATCH] WMS添加设备Model

---
 Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/RequestInTaskAsync.cs |   45 ++++++++++++++++++++++++++++-----------------
 1 files changed, 28 insertions(+), 17 deletions(-)

diff --git a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/RequestInTaskAsync.cs b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/RequestInTaskAsync.cs
index 21a8be2..ad48b3d 100644
--- a/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/RequestInTaskAsync.cs
+++ b/Code Management/WMS/WIDESEA_WMSServer/WIDESEA_StorageTaskServices/Task/Partial/RequestInTaskAsync.cs
@@ -39,19 +39,25 @@
     {
         WebResponseContent content = new WebResponseContent();
         // 鍒ゆ柇闇�涓嶉渶瑕佸幓鍖呰锛屼笉闇�瑕佸氨鍘诲父娓╀笁
-        var stationManagers = _stationManagerRepository.QueryData(x => x.stationPLC == "1018" && x.stationArea == "Cache");
-        var station = stationManagers.Select(x => x.stationChildCode).ToList();
+        var stationManagers = _stationManagerRepository.QueryData(x => x.stationPLC == "1018" && x.stationArea == "Cache" && x.productLine == input.ProductionLine);
 
-        // 鑾峰彇WCSip鍦板潃鐩稿叧閰嶇疆
+        //var station = stationManagers.Select(x => x.stationChildCode).ToList();
+
+        //// 鑾峰彇WCSip鍦板潃鐩稿叧閰嶇疆
         var wcsIpAddrss = GetWCSIpAddress();
-        if (wcsIpAddrss == null)
-        {
-            throw new InvalidOperationException("WCS IP 鏈厤缃�");
-        }
+        //if (wcsIpAddrss == null)
+        //{
+        //    throw new InvalidOperationException("WCS IP 鏈厤缃�");
+        //}
 
-        var abc = HttpHelper.PostAsync(wcsIpAddrss, station.ToJsonString()).Result;
-        content = JsonConvert.DeserializeObject<WebResponseContent>(abc);
-        if (content.Data.ObjToInt() > 0)
+        //var abc = HttpHelper.PostAsync(wcsIpAddrss, station.ToJsonString()).Result;
+        //content = JsonConvert.DeserializeObject<WebResponseContent>(abc);
+        //var num = content.Data.ObjToInt();
+
+
+        // TODO 鍒ゆ柇鍦ㄩ�旀暟閲�
+        var count = BaseDal.QueryData(x => x.TargetAddress == stationManagers[0].Roadway).Count;
+        if (count <= 10)
         {
             // 閫佽嚦鍖呰
             List<string> strings = stationManagers.Where(x => x.stationType == 0).Select(x => x.Roadway).ToList();
@@ -95,7 +101,11 @@
         if (!content.Status) return content.Error("宸ヨ壓鐢宠澶辫触");
 
         var resultProcessApply = JsonConvert.DeserializeObject<ResultProcessApply>(content.Data.ToString());
-        if (!resultProcessApply.Success) return content.Error("宸ヨ壓鐢宠澶辫触");
+        if (!resultProcessApply.Success)
+        {
+            return await HandleErrorCells(input, area);
+            //return content.Error("宸ヨ壓鐢宠澶辫触");
+        }
 
         var number = resultProcessApply.ProcessInfo.Where(x => x.ProcessCode.Contains(boxing.ProcessCode)).FirstOrDefault().Number.ToInt32();
         foreach (var item in resultProcessApply.ProcessInfo)
@@ -161,7 +171,7 @@
     /// <summary>
     /// 鐢佃姱NG閫佽嚦NG鍙�
     /// </summary>
-    private async Task<WebResponseContent> HandleErrorCells(RequestTaskDto input, Dt_AreaInfo area, List<SerialNoDto> serialNosError)
+    private async Task<WebResponseContent> HandleErrorCells(RequestTaskDto input, Dt_AreaInfo area, List<SerialNoDto> serialNosError = null)
     {
         WebResponseContent content = new WebResponseContent();
         // TODO 鍒涘缓浠诲姟閫佽嚦NG鎺掑嚭鍙�
@@ -170,11 +180,12 @@
         {
             throw new Exception("鏈壘鍒癗G鍏ュ簱绔欏彴閰嶇疆");
         }
-        List<string> NGStation = stationManagers.Roadway.Split(',').ToList();
-        if (NGStation.Count <= 0)
-        {
-            NGStation = stationManagers.stationNGChildCode.Split(',').ToList();
-        }
+        //List<string> NGStation = stationManagers.Roadway.Split(',').ToList();
+        //if (NGStation.Count <= 0)
+        //{
+        //    NGStation = stationManagers.stationNGChildCode.Split(',').ToList();
+        //}
+        List<string> NGStation = stationManagers.stationNGChildCode.Split(',').ToList();
         content = await CreateNewTask(input, NGStation, 2);
         return content.Error("瀛樺湪寮傚父鐢佃姱");
     }

--
Gitblit v1.9.3