From 515866f63c9fbdb83de3f2016e4eaf2af99490d7 Mon Sep 17 00:00:00 2001
From: hutongqing <hutongqing@hnkhzn.com>
Date: 星期三, 15 一月 2025 11:32:52 +0800
Subject: [PATCH] Merge branch 'master' of http://115.159.85.185:8098/r/MeiRuiAn/HuaiAn

---
 代码管理/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/板材仓/ConveyorLineJob_BC.cs |   31 +++++++++++++++++++++++++------
 1 files changed, 25 insertions(+), 6 deletions(-)

diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/\346\235\277\346\235\220\344\273\223/ConveyorLineJob_BC.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/\346\235\277\346\235\220\344\273\223/ConveyorLineJob_BC.cs"
index 9c98f0c..f6d4ff9 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/\346\235\277\346\235\220\344\273\223/ConveyorLineJob_BC.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/\346\235\277\346\235\220\344\273\223/ConveyorLineJob_BC.cs"
@@ -104,7 +104,7 @@
                             {
                                 #region 鐢熸垚浠诲姟鍚庣粰杈撻�佺嚎鍚姩淇″彿
                                 Dt_Task task = _taskRepository.QueryFirst(x => x.CurrentAddress == item.StationCode && _taskService.TaskInboundTypes.Contains(x.TaskType) /*&& x.DeviceCode == item.StationDeviceCode*/ && (x.TaskState == TaskStatusEnum.New.ObjToInt()) && x.WarehouseId == warehouseDevice.WarehouseId);
-                                if (task != null && conveyorLineInfoWrite.Spare2 == 0)
+                                if (task != null && conveyorLineInfoWrite.Spare2 == 0 && conveyorLineStatus.Goods)
                                 {
                                     List<string> stations = _routerExtension.GetEndPoint(item.StationCode, TaskTypeEnum.Inbound.ObjToInt()).Select(x => x.NextPosi).ToList();
                                     WebResponseContent responseContent = _taskService.RequestWMSAssignRoadway(stations, task.TaskNum, conveyorLineInfoRead.Spare2);
@@ -112,6 +112,13 @@
                                     {
                                         device.SetValue(W_ConveyorLineDB.Spare2, 1, item.StationCode);
                                         _taskService.UpdateTask(task, TaskStatusEnum.Line_Execute, deviceCode: item.StationDeviceCode, roadwayNo: responseContent.Data.ToString() ?? "");
+                                    }
+                                }
+                                else
+                                {
+                                    if (conveyorLineInfoWrite.Spare2 != 0)
+                                    {
+                                        WriteDebug(device.DeviceName, $"鍚姩淇″彿宸插啓鍏�");
                                     }
                                 }
                                 #endregion
@@ -173,6 +180,10 @@
                                         device.SetValue(W_ConveyorLineDB.ACK, true, item.StationCode);
                                         _taskService.UpdateTask(task, taskState, currentAddress: currentAddress, nextAddress: nextAddress, targetAddress: targetAddress, deviceCode: deviceCode);
                                     }
+                                    else
+                                    {
+                                        WriteInfo(device.DeviceName, $"鏈壘鍒版墭鐩榹conveyorLineInfoRead.Barcode}瀵瑰簲鐨勪换鍔′俊鎭�");
+                                    }
                                     #endregion
                                 }
                                 else//鐢熶骇閫�搴�
@@ -185,11 +196,17 @@
                                         WebResponseContent responseContent = _taskService.RequestWMSAssignRoadway(stations, task.TaskNum, conveyorLineInfoRead.Spare2);
                                         if (responseContent.Status)
                                         {
+                                            //string currentAddress = task.CurrentAddress;
+                                            //string nextAddress = task.NextAddress;
+                                            //string targetAddress = task.TargetAddress;
+                                            string roadwayNo = task.Roadway;
+
                                             string currentAddress = task.CurrentAddress;
                                             string nextAddress = task.NextAddress;
                                             string targetAddress = task.TargetAddress;
+                                            string deviceCode = task.DeviceCode;
                                             TaskStatusEnum taskState = TaskStatusEnum.Line_Executing;
-                                            List<Dt_Router> routers = _routerService.QueryNextRoutes(item.StationCode, task.Roadway, task.TaskType);
+                                            List<Dt_Router> routers = _routerService.QueryNextRoutes(item.StationCode, responseContent.Data.ToString(), task.TaskType);
                                             Dt_Router? router = routers.FirstOrDefault();
                                             if (routers == null || routers.Count == 0 || router == null)
                                             {
@@ -204,13 +221,15 @@
 
                                             if (router.IsEnd)
                                             {
-                                                string? targetLoca = _taskService.RequestAssignLocationByHeight(task.TaskNum, task.Roadway, conveyorLineInfoRead.Spare2);
+                                                string? targetLoca = _taskService.RequestAssignLocationByHeight(task.TaskNum, responseContent.Data.ToString(), conveyorLineInfoRead.Spare2);
                                                 if (!string.IsNullOrEmpty(targetLoca))
                                                 {
                                                     currentAddress = item.StackerCraneStationCode;
-                                                    nextAddress = targetAddress;
-                                                    taskState = TaskStatusEnum.SC_Execute;
                                                     targetAddress = targetLoca;
+                                                    nextAddress = targetLoca;
+                                                    taskState = TaskStatusEnum.SC_Execute;
+                                                    deviceCode = item.StackerCraneCode;
+                                                    roadwayNo = responseContent.Data.ToString();
                                                     device.SetValue(W_ConveyorLineDB.EndPos, task.CurrentAddress, item.StationCode);
                                                 }
                                                 else
@@ -227,7 +246,7 @@
                                             device.SetValue(W_ConveyorLineDB.StartPos, task.CurrentAddress, item.StationCode);
                                             device.SetValue(W_ConveyorLineDB.Spare1, ConveyorWorkTypeEnum.Outbound.ObjToInt(), item.StationCode);
                                             device.SetValue(W_ConveyorLineDB.ACK, true, item.StationCode);
-                                            _taskService.UpdateTask(task, taskState, currentAddress: currentAddress, nextAddress: nextAddress, targetAddress: targetAddress);
+                                            _taskService.UpdateTask(task, taskState, currentAddress: currentAddress, nextAddress: nextAddress, targetAddress: targetAddress, deviceCode: deviceCode, roadwayNo: roadwayNo);
                                         }
                                         #endregion
                                     }

--
Gitblit v1.9.3