From f56f8d4bf3bf088579a169519ef2547d40586f76 Mon Sep 17 00:00:00 2001
From: dengjunjie <dengjunjie@hnkhzn.com>
Date: 星期五, 10 四月 2026 18:42:53 +0800
Subject: [PATCH] 添加平库货位上下架容器接口

---
 代码管理/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs |  141 ++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 133 insertions(+), 8 deletions(-)

diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs"
index dcabee7..55e58ab 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs"
@@ -57,6 +57,7 @@
         private readonly IApiInfoService _apiInfoService;
         private readonly IStationMangerService _stationMangerService;
         private readonly IStationInfoService _stationInfo;
+        private readonly ITaskErrorMessageService _taskErrorMessageService;
         private readonly IMapper _mapper;
 
         private Dictionary<string, OrderByType> _taskOrderBy = new()
@@ -76,7 +77,7 @@
         /// </summary>
         public IRepository<Dt_Task> Repository => BaseDal;
 
-        public TaskService(IRepository<Dt_Task> BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, IRepository<Dt_TaskExecuteDetail> taskExecuteDetailRepository, IMapper mapper, IKLSLocationInfoService kLSLocationInfoService, IRGVLocationInfoService rGVLocationInfoService, IHKLocationInfoService hKLocationInfoService, IApiInfoService apiInfoService, ITrackloginfoService trackloginfoService, IStationMangerService stationMangerService, IStationInfoService stationInfo) : base(BaseDal)
+        public TaskService(IRepository<Dt_Task> BaseDal, IRouterService routerService, ITaskExecuteDetailService taskExecuteDetailService, IRepository<Dt_TaskExecuteDetail> taskExecuteDetailRepository, IMapper mapper, IKLSLocationInfoService kLSLocationInfoService, IRGVLocationInfoService rGVLocationInfoService, IHKLocationInfoService hKLocationInfoService, IApiInfoService apiInfoService, ITrackloginfoService trackloginfoService, IStationMangerService stationMangerService, IStationInfoService stationInfo, ITaskErrorMessageService taskErrorMessageService) : base(BaseDal)
         {
             _routerService = routerService;
             _taskExecuteDetailService = taskExecuteDetailService;
@@ -89,6 +90,7 @@
             _trackloginfoService = trackloginfoService;
             _stationMangerService = stationMangerService;
             _stationInfo = stationInfo;
+            _taskErrorMessageService = taskErrorMessageService;
         }
         public WebResponseContent ReceiveWMSTask([NotNull] List<WMSTasksDTO> taskDTOs)
         {
@@ -189,9 +191,9 @@
                                 content = HKF01Transport(task, item.taskType);
                                 break;
                             case (int)TaskTypeEnum.F04:
-                            case (int)TaskTypeEnum.F03:
-                            case (int)TaskTypeEnum.F02:
                             case (int)TaskTypeEnum.RK3F:
+                            case (int)TaskTypeEnum.F02:
+                            case (int)TaskTypeEnum.F03:
                             case (int)TaskTypeEnum.CK3F:
                                 content = CJCarryTaske(task, item.taskType);
                                 objects.Add(content.Data);
@@ -1237,11 +1239,11 @@
         public WebResponseContent InboundElevatorExit(string LocationCode, string containerCode)
         {
             WebResponseContent content = new WebResponseContent();
-            inboundElevatorExitDTO inboundElevator=new inboundElevatorExitDTO();
+            inboundElevatorExitDTO inboundElevator = new inboundElevatorExitDTO();
             try
             {
                 Dt_ApiInfo? apiInfo = _apiInfoService.Repository.QueryFirst(x => x.ApiCode == nameof(inboundElevatorExitDTO)) ?? throw new Exception("鏈壘鍒�4F鎻愬崌鏈哄嚭鍙f墭鐩樺彿涓婃姤WMS鎺ュ彛閰嶇疆淇℃伅锛佽妫�鏌ユ帴鍙i厤缃�");
-                inboundElevator.containerCode= containerCode;
+                inboundElevator.containerCode = containerCode;
                 inboundElevator.toLocationCode = LocationCode;
                 string response = HttpHelper.Post(apiInfo.ApiAddress, inboundElevator.Serialize());
                 content.OK(data: response);
@@ -1278,6 +1280,7 @@
                 string dataJson = wMSReturn.result.ToString();
                 Exists? exists = JsonConvert.DeserializeObject<Exists>(dataJson);
                 if (exists == null) throw new Exception($"WMS杩斿洖缁撴灉鐨剅esult杞崲澶辫触");
+                if (exists.taskExists) return WebResponseContent.Instance.OK();
                 return WebResponseContent.Instance.OK(exists.errorAreaCode);
             }
             catch (Exception ex)
@@ -1299,6 +1302,41 @@
             throw new NotImplementedException();
         }
         /// <summary>
+        /// 骞冲簱璐т綅涓婁笅鏋跺鍣�
+        /// </summary>
+        /// <param name="wMSUpOrDown"></param>
+        /// <returns></returns>
+        public WebResponseContent UpOrDownContainer(WMSUpOrDownContainerDTO wMSUpOrDown)
+        {
+            WebResponseContent content = new WebResponseContent();
+            try
+            {
+                Dt_StationInfo stationInfo = _stationInfo.Repository.QueryFirst(x => x.StationCode == wMSUpOrDown.locationCode) ?? throw new Exception($"鏈壘鍒拌揣浣嶃�恵wMSUpOrDown.locationCode}銆戜俊鎭�");
+                if (wMSUpOrDown.direction == 1)
+                {
+                    stationInfo.StationStatus = LocationStatusEnum.InStock.ObjToInt();
+                    stationInfo.PalletCode = wMSUpOrDown.containerCode;
+                }
+                else
+                {
+                    stationInfo.StationStatus = LocationStatusEnum.Free.ObjToInt();
+                    stationInfo.PalletCode = "";
+                }
+                _stationInfo.UpdateData(stationInfo);
+                content.OK();
+            }
+            catch (Exception ex)
+            {
+                content.Error(ex.Message);
+            }
+            finally
+            {
+                _trackloginfoService.AddTrackLog(wMSUpOrDown, content, "骞冲簱璐т綅涓婁笅鏋跺鍣�", "", "");
+            }
+            return content;
+        }
+
+        /// <summary>
         /// 瀹瑰櫒娴佸姩璇锋眰
         /// </summary>
         /// <param name="wMSContainerFlow"></param>
@@ -1306,6 +1344,7 @@
         /// <exception cref="NotImplementedException"></exception>
         public WebResponseContent ContainerRequest(WMSContainerFlow wMSContainerFlow)
         {
+            WebResponseContent content = new WebResponseContent();
             try
             {
                 Dt_StationManger stationManger = _stationMangerService.Repository.QueryFirst(x => x.StationCode == wMSContainerFlow.slotCode) ?? throw new Exception($"鏈壘鍒扮珯鍙般�恵wMSContainerFlow.slotCode}銆戜俊鎭�");
@@ -1313,20 +1352,26 @@
                 if (wMSContainerFlow.direction == "200")
                 {
                     stationManger.IsOccupied = LocationStatusEnum.Free.ObjToInt();
+                    stationManger.Remark = "";
                     FOURBOToccupyStation fOURBOToccupyStation = new FOURBOToccupyStation()
                     {
                         stationCode = wMSContainerFlow.slotCode,
                     };
                     string response = HttpHelper.Post(apiInfo.ApiAddress, fOURBOToccupyStation.Serialize());
                     FOURBOTReturn fOURBOTReturn = response.DeserializeObject<FOURBOTReturn>();
+                    content.OK(data: fOURBOTReturn);
                     if (fOURBOTReturn.returnCode != 0) throw new Exception(fOURBOTReturn.returnUserMsg);
                     _stationMangerService.UpdateData(stationManger);
                 }
-                return WebResponseContent.Instance.OK();
+                return content.OK();
             }
             catch (Exception ex)
             {
-                return WebResponseContent.Instance.Error(ex.Message);
+                return content.Error(ex.Message);
+            }
+            finally
+            {
+                _trackloginfoService.AddTrackLog(wMSContainerFlow, content, "瀹瑰櫒娴佸姩璇锋眰", "", "");
             }
         }
         /// <summary>
@@ -1379,11 +1424,21 @@
                 //task.TaskState = (int)TaskStatusEnum.Execut;
                 //BaseDal.UpdateData(task);
                 #endregion
+
+                #region 涓婃灦涓渶瑕佸皢绔欏彴鐘舵�佹敼涓哄崰鐢� 缁戝畾瀹瑰櫒缂栫爜
+                stationManger.IsOccupied = LocationStatusEnum.Lock.ObjToInt();
+                stationManger.Remark = iQC.ContainerCode;
+                _stationMangerService.UpdateData(stationManger);
+                #endregion
                 return WebResponseContent.Instance.OK();
             }
             catch (Exception ex)
             {
                 return WebResponseContent.Instance.Error(ex.Message);
+            }
+            finally
+            {
+                _trackloginfoService.AddTrackLog(iQC, content, "IQC璐ㄦ缁撴灉鍙嶉", "", "");
             }
         }
 
@@ -1395,6 +1450,7 @@
         /// <exception cref="NotImplementedException"></exception>
         public WebResponseContent multiSetNodeStatus(FOURBOTStorageStatusNotify fOURBOTStorageStatusNotify)
         {
+            WebResponseContent content = new WebResponseContent();
             try
             {
                 var Agvlocation = _rGVLocationInfoService.Repository.QueryData(x => fOURBOTStorageStatusNotify.storageCode.Contains(x.LocationCode));
@@ -1403,12 +1459,16 @@
                     item.EnableStatus = (int)(fOURBOTStorageStatusNotify.disable == 0 ? EnableStatusEnum.Normal : EnableStatusEnum.Disable);
                 }
                 _rGVLocationInfoService.UpdateData(Agvlocation);
-                return WebResponseContent.Instance.OK();
+                return content.OK();
             }
             catch (Exception ex)
             {
 
                 return WebResponseContent.Instance.Error(ex.Message);
+            }
+            finally
+            {
+                _trackloginfoService.AddTrackLog(fOURBOTStorageStatusNotify, content, "鎵归噺鏇存柊鍌ㄤ綅鐘舵��", "", "");
             }
         }
 
@@ -1438,6 +1498,71 @@
             }
         }
 
+        /// <summary>
+        /// 鏍¢獙浠诲姟鐩稿叧鐨勫簱浣嶇姸鎬佸拰缁戝畾鍏崇郴
+        /// </summary>
+        /// <param name="taskType">浠诲姟绫诲瀷</param>
+        /// <param name="taskDTO">浠诲姟DTO</param>
+        /// <returns>杩斿洖璧风偣搴撲綅鍜岀粓鐐瑰簱浣嶄俊鎭�</returns>
+        /// <exception cref="Exception">鏍¢獙澶辫触鏃舵姏鍑哄紓甯�</exception>
+        private WebResponseContent ValidateLocationForTask(int taskType, TaskDTO taskDTO)
+        {
+            WebResponseContent content = new WebResponseContent();
+            try
+            {
+                #region 
+                // 鍏ュ簱绫讳换鍔★紙闇�瑕佹牎楠岀粓鐐瑰簱浣嶏級
+                if (taskType == (int)TaskTypeEnum.CK3F || taskType == (int)TaskTypeEnum.F03)
+                {
+                    var toStation = _stationInfo.Repository.QueryFirst(x => x.StationName == taskDTO.toLocationCode)
+                          ?? throw new Exception($"鏈壘鍒扮粓鐐瑰簱浣嶃�恵taskDTO.toLocationCode}銆戯紒");
+
+                    if (toStation.StationStatus != (int)LocationStatusEnum.Free)
+                        throw new Exception($"缁堢偣搴撲綅銆恵taskDTO.toLocationCode}銆戝簱浣嶇姸鎬佷笉鍙叆搴擄紒");
+                }
+                // 鍑哄簱绫讳换鍔★紙闇�瑕佹牎楠岃捣鐐瑰簱浣嶏級
+                else if (taskType == (int)TaskTypeEnum.RK3F || taskType == (int)TaskTypeEnum.F04)
+                {
+                    var fromStation = _stationInfo.Repository.QueryFirst(x => x.StationName == taskDTO.fromLocationCode)
+                        ?? throw new Exception($"鏈壘鍒拌捣鐐瑰簱浣嶃�恵taskDTO.fromLocationCode}銆戯紒");
+
+                    if (fromStation.StationStatus != (int)LocationStatusEnum.InStock)
+                        throw new Exception($"璧风偣搴撲綅銆恵taskDTO.fromLocationCode}銆戝綋鍓嶅簱浣嶇姸鎬佷笉鍙嚭搴擄紒");
+
+                    if (fromStation.PalletCode != taskDTO.containerCode)
+                        throw new Exception($"璧风偣搴撲綅銆恵taskDTO.fromLocationCode}銆戠粦瀹氭枡绠卞彿銆恵fromStation.PalletCode}銆戜笌浠诲姟鏂欑鍙枫�恵taskDTO.containerCode}銆戜笉鍖归厤锛�");
+                }
+                // 绉诲簱绫讳换鍔★紙闇�瑕佸悓鏃舵牎楠岃捣鐐瑰拰缁堢偣锛�
+                else if (taskType == (int)TaskTypeEnum.F02)
+                {
+                    // 鏍¢獙缁堢偣搴撲綅
+                    var toStation = _stationInfo.Repository.QueryFirst(x => x.StationName == taskDTO.toLocationCode)
+                        ?? throw new Exception($"鏈壘鍒扮粓鐐瑰簱浣嶃�恵taskDTO.toLocationCode}銆戯紒");
+
+                    if (toStation.StationStatus != (int)LocationStatusEnum.Free)
+                        throw new Exception($"缁堢偣搴撲綅銆恵taskDTO.toLocationCode}銆戝簱浣嶇姸鎬佷笉鍙叆搴擄紒");
+
+                    // 鏍¢獙璧风偣搴撲綅
+                    var fromStation = _stationInfo.Repository.QueryFirst(x => x.StationName == taskDTO.fromLocationCode)
+                        ?? throw new Exception($"鏈壘鍒拌捣鐐瑰簱浣嶃�恵taskDTO.fromLocationCode}銆戯紒");
+
+                    if (fromStation.StationStatus != (int)LocationStatusEnum.InStock)
+                        throw new Exception($"璧风偣搴撲綅銆恵taskDTO.fromLocationCode}銆戝綋鍓嶅簱浣嶇姸鎬佷笉鍙嚭搴擄紒");
+
+                    if (fromStation.PalletCode != taskDTO.containerCode)
+                        throw new Exception($"璧风偣搴撲綅銆恵taskDTO.fromLocationCode}銆戠粦瀹氭枡绠卞彿銆恵fromStation.PalletCode}銆戜笌浠诲姟鏂欑鍙枫�恵taskDTO.containerCode}銆戜笉鍖归厤锛�");
+                }
+                #endregion
+                return content.OK();
+            }
+            catch (Exception ex)
+            {
+
+                return content.Error(ex.Message);
+            }
+
+
+        }
 
 
     }

--
Gitblit v1.9.3