From 51af2794f47d5b68496edbc09d0ccb168347f02b Mon Sep 17 00:00:00 2001
From: HuBingJie <3146306518@qq.com>
Date: 星期六, 22 十一月 2025 10:19:05 +0800
Subject: [PATCH] 1

---
 项目代码/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs |  143 +++++++++++++++++++++++++++++++++++++----------
 1 files changed, 113 insertions(+), 30 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs"
index cd6f546..ead1c5c 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs"
@@ -21,6 +21,7 @@
 using Microsoft.AspNetCore.Mvc;
 using Newtonsoft.Json;
 using SqlSugar;
+using System.Diagnostics;
 using System.DirectoryServices.Protocols;
 using System.Net;
 using System.Reflection.Emit;
@@ -266,7 +267,7 @@
                 BaseDal.DeleteData(task);
                 BaseDal.DeleteAndMoveIntoHty(task, App.User.UserId == 0 ? OperateTypeEnum.鑷姩瀹屾垚 : OperateTypeEnum.浜哄伐瀹屾垚);
 
-                WebResponseContent content=MES_TransferCompletionFeedback(task);
+                WebResponseContent content = MES_TransferCompletionFeedback(task);
                 //content.Status = true;
 
                 if (!content.Status)
@@ -274,7 +275,7 @@
                     _unitOfWorkManage.RollbackTran();
                     return content;
                 }
-                    
+
                 _unitOfWorkManage.CommitTran();
                 return webResponse.OK();
             }
@@ -319,6 +320,7 @@
                 _locationInfoRepository.UpdateData(dt_LocationInfo);
                 //淇敼搴撳瓨鐘舵��
                 _stockRepository.UpdateData(stockInfo);
+                task.TaskStatus = (int)TaskInStatusEnum.InFinish;
                 //鍒犻櫎浠诲姟娣诲姞鍘嗗彶
                 BaseDal.DeleteAndMoveIntoHty(task, App.User.UserId > 0 ? OperateTypeEnum.浜哄伐瀹屾垚 : OperateTypeEnum.鑷姩瀹屾垚);
 
@@ -565,15 +567,93 @@
                     return webResponse.Error($"鏈壘鍒颁换鍔″彿涓恒�恵taskNum}銆戠殑浠诲姟淇℃伅");
                 }
 
-                // TODO: 杩欓噷鍚庣画闇�瑕佹坊鍔犲叿浣撶殑鍙栨秷浠诲姟涓氬姟閫昏緫
-                // 渚嬪锛氭洿鏂颁换鍔$姸鎬併�侀噴鏀捐揣浣嶃�侀�氱煡WCS绛�
-                
-                return webResponse.OK("浠诲姟鍙栨秷鎴愬姛");
+                bool res;
+                switch (task.TaskType)
+                {
+                    case (int)TaskInboundTypeEnum.Inbound:
+                        res = task.TaskStatus == TaskInStatusEnum.Line_InExecuting.ObjToInt();
+                        break;
+                    case (int)TaskOutboundTypeEnum.Outbound:
+                        res = task.TaskStatus == TaskOutStatusEnum.OutNew.ObjToInt();
+                        break;
+                    case (int)TaskRelocationTypeEnum.Relocation:
+                        res = task.TaskStatus == TaskRelocationStatusEnum.RelocationNew.ObjToInt();
+                        break;
+                    default:
+                        res = false;
+                        break;
+                }
+                if (!res) return WebResponseContent.Instance.Error("浠诲姟鐘舵�佸紓甯�");
+
+                Dt_StockInfo stockInfo = _stockRepository.QueryFirst(x => x.PalletCode == task.PalletCode);
+
+                _unitOfWorkManage.BeginTran();
+
+                int stockmsseg;
+                int locationmsseg;
+                bool taskmsseg;
+                if (task.TaskType == TaskOutboundTypeEnum.Outbound.ObjToInt() || task.TaskType == TaskRelocationTypeEnum.Relocation.ObjToInt())
+                {
+                    stockmsseg = _stockRepository.Db.Updateable<Dt_StockInfo>()
+                  .SetColumns(x => x.StockStatus == StockStatusEmun.鍏ュ簱瀹屾垚.ObjToInt())
+                  .Where(x => x.PalletCode == task.PalletCode)
+                  .ExecuteCommand();
+                    locationmsseg = _locationInfoRepository.Db.Updateable<Dt_LocationInfo>()
+          .SetColumns(x => x.LocationStatus == LocationStatusEnum.InStock.ObjToInt())
+          .Where(x => x.LocationCode == stockInfo.LocationCode)
+          .ExecuteCommand();
+                    taskmsseg = BaseDal.DeleteData(task);
+                }
+                else
+                {
+                    locationmsseg = _locationInfoRepository.Db.Updateable<Dt_LocationInfo>()
+                    .SetColumns(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt())
+                    .Where(x => x.LocationCode == stockInfo.LocationCode)
+                    .ExecuteCommand();
+                    stockmsseg = _stockRepository.DeleteData(stockInfo).ObjToInt();
+                    taskmsseg = BaseDal.DeleteData(task);
+                }
+                BaseDal.DeleteAndMoveIntoHty(task, App.User.UserId > 0 ? OperateTypeEnum.浜哄伐瀹屾垚 : OperateTypeEnum.鑷姩瀹屾垚);
+                //鑾峰彇鎺ュ彛杩涜璋冨彇
+                var ConfigsAPIInfo = _dt_ApiInfoService.GetConfigsByAPIInfo(CateGoryConst.CONFIG_MES_IPAddress, SysConfigConst.WCSCancelinventory);      //鑾峰彇鍒皐cs鍏ㄩ儴绫诲瀷鐨勬帴鍙�
+                string WCSReceiveTaskAPI = ConfigsAPIInfo.ApiAddress + ConfigsAPIInfo.ApiName;
+                if (WCSReceiveTaskAPI == null)
+                {
+                    return webResponse.Error($"浠诲姟鍙嶉MES澶辫触锛屾湭閰嶇疆MES浠诲姟瀹屾垚鍙嶉鎺ュ彛");
+                }
+                var respon = HttpHelper.Get(WCSReceiveTaskAPI, JsonConvert.SerializeObject(task.TaskNum));
+                if (respon != null)
+                {
+                    var response = JsonConvert.DeserializeObject<ApiResponse<object>>(respon);
+                    //    if (response.Success)
+                    //    {
+                    //        return webResponse.OK();
+                    //    }
+                    //    else
+                    //    {
+                    //        return webResponse.Error($"璋冨彇鎺ュ彛澶辫触锛屽弽棣堝弬鏁板師鍥狅細{response.Message}");
+                    //    }
+                    //}
+                    //else
+                    //{
+                    //    return webResponse.Error($"璋冨彇鎺ュ彛澶辫触锛屽弽棣堝弬鏁颁负绌�");
+                    //}
+                    if (stockmsseg > 0 && locationmsseg > 0 && taskmsseg)
+                    {
+                        _unitOfWorkManage.CommitTran();
+                        return webResponse.OK("浠诲姟鍙栨秷鎴愬姛");
+
+                    }
+
+                }
             }
             catch (Exception ex)
             {
+                _unitOfWorkManage.RollbackTran();
                 return webResponse.Error($"鍙栨秷浠诲姟澶辫触锛屽師鍥狅細{ex.Message}");
             }
+            _unitOfWorkManage.RollbackTran();
+            return webResponse.Error("浠诲姟鍙栨秷澶辫触");
         }
 
         /// <summary>
@@ -682,47 +762,50 @@
 
             try
             {
-                int result = GetLastPart(locationCode).ObjToInt(); // 杩斿洖 "C03"
+                Dt_StockInfo dt_StockInfo =  _stockRepository.QueryFirst(x => x.LocationCode.StartsWith("SC01") && x.StockStatus == 6);
+                int result = GetLastPart(dt_StockInfo.LocationCode).ObjToInt(); // 杩斿洖 "C03"
+
                 List<Dt_Task> dt_s = new List<Dt_Task>();
                 //鐢熸垚绉诲姩浠诲姟
                 Dt_Task dt_Task = new()
                 {
-                    PalletCode = "1111",
-                    TaskNum = 111,
+                    PalletCode = dt_StockInfo.PalletCode,
+                    TaskNum = GetTaskNum(nameof(SequenceEnum.SeqTaskNum)),
                     Roadway = "SC01",
                     TaskType = TaskOutboundTypeEnum.Outbound.ObjToInt(),
                     TaskStatus = TaskOutStatusEnum.OutNew.ObjToInt(),
-                    SourceAddress = locationCode,
-                    TargetAddress = "1002",
-                    CurrentAddress = locationCode,
-                    NextAddress = "1002",
+                    SourceAddress = dt_StockInfo.LocationCode,
+                    TargetAddress = "1006",
+                    CurrentAddress = dt_StockInfo.LocationCode,
+                    NextAddress = "1006",
                     Grade = 1,
                     Creater = "MES",
                     Depth = result,
                     CreateDate = DateTime.Now,
-                    MEStaskId = "111",
-                    MESbusinessId = "123456",
-                    MESsubPalletCode = "",
-                    OutboundPlatform = "1001"
+                    MEStaskId = "EXTASK20251020002",
+                    MESbusinessId = "EXBUS20251020002",
+                    MESsubPalletCode = dt_StockInfo.MESsubPalletCode,
+                    OutboundPlatform = "1005"
                 };
 
-                //鍒涘缓缁勭洏淇℃伅
-                var dt_Stock = new Dt_StockInfo
-                {
-                    PalletCode = dt_Task.PalletCode,
-                    PalletType = 1,
-                    LocationCode = locationCode,
-                    StockStatus = 6,
-                    Creater = "WMS",
-                    CreateDate = DateTime.Now,
-                    MESsubPalletCode = dt_Task.MESsubPalletCode,
-                };
+                ////鍒涘缓缁勭洏淇℃伅
+                //var dt_Stock = new Dt_StockInfo
+                //{
+                //    PalletCode = dt_Task.PalletCode,
+                //    PalletType = 1,
+                //    LocationCode = locationCode,
+                //    StockStatus = 6,
+                //    Creater = "WMS",
+                //    CreateDate = DateTime.Now,
+                //    MESsubPalletCode = dt_Task.MESsubPalletCode,
+                //};
 
-                Dt_LocationInfo dt_LocationInfo = _locationInfoRepository.QueryFirst(x => x.LocationCode == locationCode);
+                Dt_LocationInfo dt_LocationInfo = _locationInfoRepository.QueryFirst(x => x.LocationCode == dt_StockInfo.LocationCode);
                 dt_LocationInfo.LocationStatus = (int)LocationStatusEnum.InStockLock;
+                dt_StockInfo.StockStatus = 7;
 
                 bool l = _locationInfoRepository.UpdateData(dt_LocationInfo);
-                int s = _stockRepository.AddData(dt_Stock);
+                bool s = _stockRepository.UpdateData(dt_StockInfo);
                 int t = BaseDal.AddData(dt_Task);
                 bool ss = s.ObjToBool();
                 bool tt = t.ObjToBool();

--
Gitblit v1.9.3