From 1dd9f4bf540a74a7de2daeeebf38491f86befa08 Mon Sep 17 00:00:00 2001
From: huanghongfeng <huanghongfeng@hnkhzn.com>
Date: 星期三, 27 十一月 2024 09:31:07 +0800
Subject: [PATCH] 1

---
 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs |   50 +++++++++++++++++++++++++-------------------------
 1 files changed, 25 insertions(+), 25 deletions(-)

diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs"
index 3093bdf..87b1314 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_TaskInfoService/TaskService.cs"
@@ -49,6 +49,7 @@
 using WIDESEA_ITaskInfoService;
 using WIDESEA_Model.Models;
 using WIDESEA_TaskInfoRepository;
+using static WIDESEA_ITaskInfoService.ITaskService;
 
 namespace WIDESEA_TaskInfoService
 {
@@ -125,35 +126,34 @@
             Dt_StockInfo stockInfo = _stockService.StockInfoService.Repository.GetStockInfo(task.PalletCode);
             //鏌ヨ揣浣�
             Dt_LocationInfo locationInfo = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == task.TargetAddress);
-
+            Dt_StockInfoDetail dt_StockInfodetail = _stockService.StockInfoDetailService.Repository.QueryFirst(x => x.OrderNo == task.PalletCode);
             CheckCompleted(stockInfo, locationInfo);
 
+            if (stockInfo.MaterialType == (int)InventoryMaterialType.绌烘墭)
+            {
+                string currentTime = DateTime.Now.ToString("HHmmss");
+                stockInfo.PalletCode = "KTP" + currentTime;
+            }
+            stockInfo.LocationCode = task.TargetAddress;
             stockInfo.StockStatus = StockStatusEmun.宸插叆搴�.ObjToInt();
              _stockService.StockInfoService.Repository.UpdateData(stockInfo);
-            if (_stockService.StockInfoService.Repository.UpdateData(stockInfo))
-            {
-                string[] Pallet = stockInfo.PalletCode.Split("-");
-                Dt_StockInfoDetail dt_StockInfoDetail = new()
-                {
-                    StockId = stockInfo.Id,
-                    MaterielCode = Pallet[0],    //鐗╂枡缂栧彿
-                    MaterielName = Pallet[1],    //鏉愯川
-                    OrderNo = stockInfo.PalletCode,        //鍗曟嵁锛堟墭鐩樻潯鐮侊級
-                    BatchNo = Pallet[2],         //鎵规鍙�
-                    SerialNumber = Pallet[2],    //搴忓垪鍙�
-                    StockQuantity = decimal.Parse(Pallet[3]),    //搴忓垪鍙�
-                    OutboundQuantity = decimal.Parse(Pallet[3]),    //搴忓垪鍙�
-                    Status = (int)StockStatusEmun.宸插叆搴�,
-                    Creater = "WMS",
-                    CreateDate = DateTime.Now,
-                };
-                _stockService.StockInfoDetailService.AddData(dt_StockInfoDetail);
-            }
 
+            if(dt_StockInfodetail != null)
+            {
+                dt_StockInfodetail.Status = StockStatusEmun.宸插叆搴�.ObjToInt();
+                _stockService.StockInfoDetailService.Repository.UpdateData(dt_StockInfodetail);
+            }
             beforeQuantity = stockInfo.Details.Where(x => x.Id != 0).Sum(x => x.StockQuantity);
 
             int beforeStatus = locationInfo.LocationStatus;
-            locationInfo.LocationStatus = LocationStatusEnum.InStock.ObjToInt();
+            if (stockInfo.MaterialType == (int)InventoryMaterialType.绌烘墭)
+            {
+                locationInfo.LocationStatus = LocationStatusEnum.Pallet.ObjToInt();
+            }
+            else
+            {
+                locationInfo.LocationStatus = LocationStatusEnum.InStock.ObjToInt();
+            }
             _basicService.LocationInfoService.UpdateLocationFree(locationInfo, task.TaskNum, StockChangeType.Inbound.ObjToInt(), false);
 
             _basicService.LocationInfoService.Repository.UpdateData(locationInfo);
@@ -297,12 +297,12 @@
             return WebResponseContent.Instance.OK();
         }
 
-        public WebResponseContent RelocationTaskCompleted(string PalletCode,string SourceAddress, string TargetAddress)
+        public WebResponseContent RelocationTaskCompleted(GenerateInv2 generate)
         {
-            Dt_StockInfo stockInfo = _stockService.StockInfoService.Repository.GetStockInfo(PalletCode);
+            Dt_StockInfo stockInfo = _stockService.StockInfoService.Repository.GetStockInfo(generate.PalletCode);
 
-            Dt_LocationInfo locationpoint = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == SourceAddress);
-            Dt_LocationInfo locationEnd = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == TargetAddress);
+            Dt_LocationInfo locationpoint = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == generate.SourceAddress);
+            Dt_LocationInfo locationEnd = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == generate.TargetAddress);
             List<Dt_LocationInfo> loca = new List<Dt_LocationInfo>();
 
             stockInfo.LocationCode = locationEnd.LocationCode;

--
Gitblit v1.9.3