From 8953f14db850deaf66782197a5d2bff35fe41e1a Mon Sep 17 00:00:00 2001
From: pulg <plg@Haninfo>
Date: 星期三, 02 七月 2025 18:02:09 +0800
Subject: [PATCH] Merge branch 'master' of http://121.37.118.194:8000/r/WMSPrjInstance/HH-0014_NongFu_QingXi

---
 HH.WCS.QingXiNongfu/core/Monitor.cs |  117 +++++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 83 insertions(+), 34 deletions(-)

diff --git a/HH.WCS.QingXiNongfu/core/Monitor.cs b/HH.WCS.QingXiNongfu/core/Monitor.cs
index 8890639..3b7bdac 100644
--- a/HH.WCS.QingXiNongfu/core/Monitor.cs
+++ b/HH.WCS.QingXiNongfu/core/Monitor.cs
@@ -430,13 +430,17 @@
                 var orders = WCSHelper.GetWorkOrder2();
                 var thisOrder = orders.Find(x => x.SQL_WorkNo == WorkNo);
                 LogHelper.Info("绉诲簱瑙i攣 --褰撳墠宸ュ崟 sid:" + thisOrder?.S_ID);
-                if (thisOrder != null)
-                {
-                    var other = orders.Find(x => x.SQL_WorkNo != WorkNo && x.start_area == thisOrder.start_area && x.start_row == thisOrder.start_row);
-                    LogHelper.Info($"绉诲簱瑙i攣 --鍏朵粬宸ュ崟 x.start_area == {thisOrder.start_area} start_row == {thisOrder.start_row} SID:" + other?.S_ID);
-                    if (other != null)
-                        j瑙i攣璧风偣搴撳尯鎺�= false;
-                }
+                var allarea_rows = orders.FindAll(x => x.S_ID != thisOrder.S_ID && x.start_area == thisOrder.start_area && x.start_row == thisOrder.start_row);
+                LogHelper.Info("绉诲簱瑙i攣 --褰撳墠宸ュ崟 鐨勫悓搴撳尯鎺�鍏朵粬宸ュ崟:" + JsonConvert.SerializeObject(allarea_rows));
+                if (allarea_rows.Any())
+                    j瑙i攣璧风偣搴撳尯鎺�= false;
+                //if (thisOrder != null)
+                //{
+                //    var other = orders.Find(x => x.SQL_WorkNo != WorkNo && x.start_area == thisOrder.start_area && x.start_row == thisOrder.start_row);
+                //    LogHelper.Info($"绉诲簱瑙i攣 --鍏朵粬宸ュ崟 x.start_area == {thisOrder.start_area} start_row == {thisOrder.start_row} SID:" + other?.S_ID);
+                //    if (other != null)
+                //        j瑙i攣璧风偣搴撳尯鎺�= false;
+                //}
             }
             //if (sign == 1)
             //{
@@ -1466,7 +1470,7 @@
                 try
                 {
                     // var yuworders = LocationHelper.GetList<YWLWorkOrder>(x => x.SQL_PLineNo == "鏃犺弻鏍囩鍑哄簱" && x.WorkType == 6 && x.SQL_State == "鎵ц涓�).FindAll(x => x.OutNum > 0 && DateTime.Now.Subtract(x.SQL_Modify_TIme ?? DateTime.Now).TotalSeconds > 10).OrderBy(x => x.TagOverTime).ToList();
-                    var yuworders = LocationHelper.GetList<YWLWorkOrder>(x => x.SQL_PLineNo == "鏃犺弻鏍囩鍑哄簱" && x.WorkType == 6 && x.SQL_State == "鎵ц涓�).FindAll(x => x.OutNum > 0 && DateTime.Now.Subtract(x.SQL_Modify_TIme ?? DateTime.Now).TotalSeconds > 10).OrderBy(x => x.TagOverTime).ToList();
+                    var yuworders = LocationHelper.GetList<YWLWorkOrder>(x => x.SQL_PLineNo == "鏃犺弻鏍囩鍑哄簱" && x.WorkType == 6 && x.SQL_State == "鎵ц涓�).FindAll(x => x.OutNum > 0).OrderBy(x => x.TagOverTime).ToList();
                     if (!yuworders.Any())
                     {
                         YwlBQ_CreInwork(locsFirst, WJ_BQ.RK_BQDDQ, WJ_BQ.RK_BBHJQ);
@@ -2288,12 +2292,12 @@
             if (order != null)
             {
                 var Porder = WCSHelper.GetWorkOrder(order.SQL_LinkLineNO);
-                if (Porder == null)
-                {
-                    LogHelper.CErrorLog("SX鏍囩鍑哄簱锛� + (order.SQL_LinkLineNO) + "娌℃湁銆愭墽琛屼腑銆戠殑宸ュ崟");
-                    yuworders.Remove(order);
-                    goto retuse;
-                }
+                //if (Porder == null)
+                //{
+                //    LogHelper.CErrorLog("SX鏍囩鍑哄簱锛� + (order.SQL_LinkLineNO) + "娌℃湁銆愭墽琛屼腑銆戠殑宸ュ崟");
+                //    yuworders.Remove(order);
+                //    goto retuse;
+                //}
                 var oto = new List<string>();
                 //if (!string.IsNullOrEmpty(order.TagOver))
                 //    oto = order.TagOver.Split(',').ToList();
@@ -2782,12 +2786,12 @@
             if (order != null)
             {
                 var Porder = WCSHelper.GetWorkOrder(order.SQL_LinkLineNO);
-                if (Porder == null)
-                {
-                    LogHelper.CErrorLog("鏃犺弻鏍囩鍑哄簱锛� + (order.SQL_LinkLineNO) + "娌℃湁銆愭墽琛屼腑銆戠殑宸ュ崟");
-                    yuworders.Remove(order);
-                    goto retuse;
-                }
+                //if (Porder == null)
+                //{
+                //    LogHelper.CErrorLog("鏃犺弻鏍囩鍑哄簱锛� + (order.SQL_LinkLineNO) + "娌℃湁銆愭墽琛屼腑銆戠殑宸ュ崟");
+                //    yuworders.Remove(order);
+                //    goto retuse;
+                //}
 
                 var oto = new List<string>();
                 //if (!string.IsNullOrEmpty(order.TagOver))
@@ -4341,6 +4345,8 @@
         /// </summary>
         internal static void YWL_ZX_Turn()
         {
+            var dbcd = new SqlHelper<object>().GetInstance();
+
             foreach (var ODs in LocationHelper.GetList<YWLZXtake>(X => X.S_ZX_STATE == "鎵ц").GroupBy(x => x.S_START_AREA))
             {
                 var locS = LocationHelper.GetAreaNormalLocList(ODs.Key);
@@ -4376,6 +4382,26 @@
                         }
                         else
                         {
+                            if (od.N_END_ROW > 0)
+                            {
+                                var EndRow = dbcd.Queryable<Location>().Where(l => l.S_AREA_CODE == od.S_END_AREA && l.N_ROW == od.N_END_ROW && l.N_CURRENT_NUM == 0).ToList();
+                                if (EndRow.Count() == 0)
+                                {
+                                    //缃负瀹屾垚銆�
+                                    od.S_ZX_STATE = "瀹屾垚";
+                                    WCSHelper.Do(db => db.Updateable(od).UpdateColumns(x => new { x.S_ZX_STATE }).ExecuteCommand());
+                                }
+                            }
+                            else
+                            {
+                                var EndRow = dbcd.Queryable<Location>().Where(l => l.S_AREA_CODE == od.S_END_AREA && l.N_CURRENT_NUM == 0).ToList();
+                                if (EndRow.Count() == 0)
+                                {
+                                    //缃负瀹屾垚銆�
+                                    od.S_ZX_STATE = "瀹屾垚";
+                                    WCSHelper.Do(db => db.Updateable(od).UpdateColumns(x => new { x.S_ZX_STATE }).ExecuteCommand());
+                                }
+                            }
                             var lastful = rows.FindAll(x => x.N_CURRENT_NUM > 0).OrderBy(x => x.N_COL).LastOrDefault();
                             if (lastful != null)
                             {
@@ -4406,27 +4432,49 @@
                                 string nextarea = !string.IsNullOrEmpty(od.S_ZZ_AREA) ? od.S_ZZ_AREA : od.S_END_AREA;
                                 var zzlocs = LocationHelper.GetAreaNormalLocList(nextarea);
                                 Location Endbit = null;
-                                foreach (var zzrs in zzlocs.GroupBy(x => x.N_ROW).OrderBy(x => x.Key))
+                                if (od.N_END_ROW == 0 && zzlocs.Any())
                                 {
-                                    var zzrloclist = zzrs.ToList();
-                                    var _cl2 = zzrloclist.FindAll(x => x.N_CURRENT_NUM > 0).OrderBy(x => x.N_COL).LastOrDefault();
-                                    if (_cl2 != null)
+                                    foreach (var zzrs in zzlocs.GroupBy(x => x.N_ROW).OrderBy(x => x.Key))
                                     {
-                                        var rel = LocationHelper.GetLocCntrRel(_cl2.S_LOC_CODE);
-                                        var cntrrel = ContainerHelper.GetCntrItemRel(rel.FirstOrDefault()?.S_CNTR_CODE).FirstOrDefault();
-                                        if (cntrrel == null)
-                                            continue;
-                                        if (cntrrel.S_ITEM_CODE == cir1.S_ITEM_CODE && cntrrel.S_ITEM_NAME == cir1.S_ITEM_NAME && cntrrel.S_CJ_NAME == cir1.S_CJ_NAME)
+                                        var zzrloclist = zzrs.ToList();
+                                        var _cl2 = zzrloclist.FindAll(x => x.N_CURRENT_NUM > 0).OrderBy(x => x.N_COL).LastOrDefault();
+                                        if (_cl2 != null)
                                         {
+                                            var rel = LocationHelper.GetLocCntrRel(_cl2.S_LOC_CODE);
+                                            var cntrrel = ContainerHelper.GetCntrItemRel(rel.FirstOrDefault()?.S_CNTR_CODE).FirstOrDefault();
+                                            if (cntrrel == null)
+                                                continue;
+                                            if (cntrrel.S_ITEM_CODE == cir1.S_ITEM_CODE && cntrrel.S_ITEM_NAME == cir1.S_ITEM_NAME && cntrrel.S_CJ_NAME == cir1.S_CJ_NAME)
+                                            {
+                                                Endbit = zzrloclist.Find(x => x.N_COL > (_cl2?.N_COL ?? 0));
+                                            }
+                                        }
+                                        else
                                             Endbit = zzrloclist.Find(x => x.N_COL > (_cl2?.N_COL ?? 0));
+                                        if (Endbit != null)
+                                        {
+                                            LogHelper.Info($"鍏ヤ腑杞尯{nextarea}浣跨敤{Endbit.S_LOC_CODE}");
+                                            break;
                                         }
                                     }
-                                    else
-                                        Endbit = zzrloclist.Find(x => x.N_COL > (_cl2?.N_COL ?? 0));
-                                    if (Endbit != null)
+                                }
+                                else
+                                {
+                                    if (zzlocs.Any() && od.N_END_ROW > 0)//鐢ㄤ簬搴撳唴 姣斿A搴撴煇鎺掔Щ鍒癆搴撶殑鍙︿竴鎺�                                     {
-                                        LogHelper.Info($"鍏ヤ腑杞尯{nextarea}浣跨敤{Endbit.S_LOC_CODE}");
-                                        break;
+                                        zzlocs = zzlocs.FindAll(e => e.N_ROW == od.N_END_ROW);
+                                        //
+                                        var EndMt = dbcd.Queryable<Location>().Where(l => l.S_AREA_CODE == od.S_END_AREA && l.N_ROW == od.N_END_ROW && l.N_CURRENT_NUM > 0).ToList();
+                                        if (EndMt.Any())
+                                        {
+                                            var ggh = EndMt.OrderByDescending(e => e.N_COL).FirstOrDefault();
+                                            zzlocs = zzlocs.FindAll(e => e.N_COL > ggh.N_COL).ToList();
+                                        }
+                                        if (zzlocs.Any())
+                                        {
+                                            Endbit = zzlocs.OrderBy(e => e.N_COL).FirstOrDefault();
+                                        }
+
                                     }
                                 }
                                 LogHelper.Info($"YWL_ZX_Turn from{od.S_START_AREA} mid:{od.S_ZZ_AREA} to{od.S_END_AREA} 鎵惧埌绉诲簱缁堢偣銆媨Endbit?.S_LOC_CODE}");
@@ -4441,6 +4489,7 @@
                             }
                         }
                     }
+
                 }
             }
         }

--
Gitblit v1.9.1