From fe941b73b9496f6cfab1a8957f319f74ea09fe1d Mon Sep 17 00:00:00 2001
From: Huangxiaoqiang-03 <1247017146@qq.com>
Date: 星期一, 04 十一月 2024 17:34:32 +0800
Subject: [PATCH] 1

---
 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs |  135 +++++++++++++++++++++++----------------------
 1 files changed, 69 insertions(+), 66 deletions(-)

diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs"
index 40dbb76..d213931 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs"
@@ -123,36 +123,39 @@
         {
             return BaseDal.QueryFirst(x => x.RoadwayNo == locationInfo.RoadwayNo && x.Column == locationInfo.Column && x.Layer == locationInfo.Layer && x.Depth != locationInfo.Depth && x.Row != locationInfo.Row && (SqlFunc.Abs(x.Row - locationInfo.Row) == 1));
         }
-        public void UpdateLocationLock(Dt_LocationInfo locationInfo, int? TaskNum)
+        public void UpdateLocationLock(Dt_LocationInfo locations, int TaskNum,int changType,bool black)
         {
             try
             {
-                if (locationInfo.Depth == 2)
+                Dt_LocationInfo result = isDepth(locations);
+                int beforeStatusEnd = 0;
+                if (black)
                 {
-                    Dt_LocationInfo dt_LocationInfo = null;
-                    int beforeStatus = 0;
-                    if (locationInfo.Row == 1 || locationInfo.Row == 5)
+                    if (result != null && (result.LocationStatus == LocationStatusEnum.Free.ObjToInt()|| result.LocationStatus == LocationStatusEnum.Lock.ObjToInt()))
                     {
-                        dt_LocationInfo = BaseDal.QueryFirst(x => x.Row == locationInfo.Row + 1 && x.Layer == locationInfo.Layer && x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo);
-                        beforeStatus = dt_LocationInfo.LocationStatus;
-                        if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus != LocationStatusEnum.InStock.ObjToInt())
-                        {
-                            dt_LocationInfo.LocationStatus = LocationStatusEnum.Lock.ObjToInt();
-                            BaseDal.UpdateData(dt_LocationInfo);
-                        }
+                        beforeStatusEnd = result.LocationStatus;
+
+                        result.LocationStatus = LocationStatusEnum.Lock.ObjToInt();
+
+                        BaseDal.UpdateData(result);
+
+                        _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result, beforeStatusEnd, changType, "", TaskNum);
                     }
-                    else if (locationInfo.Row == 4 || locationInfo.Row == 8)
-                    {
-                        dt_LocationInfo = BaseDal.QueryFirst(x => x.Row == locationInfo.Row + 1 && x.Layer == locationInfo.Layer && x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo);
-                        beforeStatus = dt_LocationInfo.LocationStatus;
-                        if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus != LocationStatusEnum.InStock.ObjToInt())
-                        {
-                            dt_LocationInfo.LocationStatus = LocationStatusEnum.Lock.ObjToInt();
-                            BaseDal.UpdateData(dt_LocationInfo);
-                        }
-                    }
-                    _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, beforeStatus, StockChangeType.Lock.ObjToInt(), "", TaskNum);
                 }
+                else
+                {
+                    if (result != null && result.LocationStatus == LocationStatusEnum.Free.ObjToInt())
+                    {
+                        beforeStatusEnd = result.LocationStatus;
+
+                        result.LocationStatus = LocationStatusEnum.Lock.ObjToInt();
+
+                        BaseDal.UpdateData(result);
+
+                        _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result, beforeStatusEnd, changType, "", TaskNum);
+                    }
+                }
+                
             }
             catch (Exception ex)
             {
@@ -160,35 +163,20 @@
             }
 
         }
-        public void UpdateLocationFree(Dt_LocationInfo locationInfo, int? TaskNum)
+        public void UpdateLocationFree(Dt_LocationInfo locations, int TaskNum, int changType,bool black)
         {
             try
             {
-                if (locationInfo.Depth == 2)
+                Dt_LocationInfo result = isDepth(locations);
+                if (result != null)
                 {
-                    Dt_LocationInfo dt_LocationInfo = null;
-                    int beforeStatus = 0;
-                    if (locationInfo.Row == 1 || locationInfo.Row == 5)
-                    {
-                        dt_LocationInfo = BaseDal.QueryFirst(x => x.Row == locationInfo.Row + 1 && x.Layer == locationInfo.Layer && x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo);
-                        beforeStatus = dt_LocationInfo.LocationStatus;
-                        if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus != LocationStatusEnum.InStock.ObjToInt())
-                        {
-                            dt_LocationInfo.LocationStatus = LocationStatusEnum.Free.ObjToInt();
-                            BaseDal.UpdateData(dt_LocationInfo);
-                        }
-                    }
-                    else if (locationInfo.Row == 4 || locationInfo.Row == 8)
-                    {
-                        dt_LocationInfo = BaseDal.QueryFirst(x => x.Row == locationInfo.Row + 1 && x.Layer == locationInfo.Layer && x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo);
-                        beforeStatus = dt_LocationInfo.LocationStatus;
-                        if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus != LocationStatusEnum.InStock.ObjToInt())
-                        {
-                            dt_LocationInfo.LocationStatus = LocationStatusEnum.Free.ObjToInt();
-                            BaseDal.UpdateData(dt_LocationInfo);
-                        }
-                    }
-                    _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(dt_LocationInfo, beforeStatus, StockChangeType.Lock.ObjToInt(), "", TaskNum);
+                    int beforeStatusEnd = result.LocationStatus;
+
+                    result.LocationStatus = LocationStatusEnum.Free.ObjToInt();
+
+                    BaseDal.UpdateData(result);
+
+                    _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(result, beforeStatusEnd, changType, "", TaskNum);
                 }
             }
             catch (Exception ex)
@@ -204,15 +192,18 @@
                 if (locationInfo.Row == 1 || locationInfo.Row == 5)
                 {
                     Dt_LocationInfo dt_LocationInfo = BaseDal.QueryFirst(x => x.Row == locationInfo.Row + 1 && x.Layer == locationInfo.Layer && x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo);
-                    if (dt_LocationInfo != null&& dt_LocationInfo.LocationStatus==LocationStatusEnum.InStock.ObjToInt())
+
+                    if (dt_LocationInfo != null)
                     {
                         return dt_LocationInfo;
                     }
+
                 }
                 else if (locationInfo.Row == 4 || locationInfo.Row == 8)
                 {
                     Dt_LocationInfo dt_LocationInfo = BaseDal.QueryFirst(x => x.Row == locationInfo.Row + 1 && x.Layer == locationInfo.Layer && x.Column == locationInfo.Column && x.RoadwayNo == locationInfo.RoadwayNo);
-                    if (dt_LocationInfo != null && dt_LocationInfo.LocationStatus == LocationStatusEnum.InStock.ObjToInt())
+
+                    if (dt_LocationInfo != null)
                     {
                         return dt_LocationInfo;
                     }
@@ -220,33 +211,45 @@
             }
             return null;
         }
-        public void RelocationLock(Dt_LocationInfo locationInfo, Dt_LocationInfo locationInfos,int TaskNum)
+        public void RelocationLock(Dt_LocationInfo locationInfo, Dt_LocationInfo locationInfos, int TaskNum)
         {
-            int beforeStatus = locationInfo.LocationStatus;
-            int beforeStatu = locationInfos.LocationStatus;
+            int beforeStartStatus = locationInfo.LocationStatus;
+            int beforeEndStatus = locationInfos.LocationStatus;
 
             locationInfo.LocationStatus = LocationStatusEnum.Lock.ObjToInt();
-            locationInfos.LocationStatus = LocationStatusEnum.Lock.ObjToInt();
+
+            if (beforeStartStatus == LocationStatusEnum.Pallet.ObjToInt())
+            {
+                locationInfos.LocationStatus = LocationStatusEnum.PalletLock.ObjToInt();
+            }
+            else
+            {
+                locationInfos.LocationStatus = LocationStatusEnum.Lock.ObjToInt();
+            }
 
             BaseDal.UpdateData(locationInfo);
-
             BaseDal.UpdateData(locationInfos);
-            _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, beforeStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum);
-            _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfos, beforeStatu, StockChangeType.Relocation.ObjToInt(), "", TaskNum);
+
+            _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, beforeStartStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum);
+            _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfos, beforeEndStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum);
         }
-        public void RelocationFree(Dt_LocationInfo locationInfo, Dt_LocationInfo locationInfos, int TaskNum)
+        public void RelocationFree(Dt_LocationInfo locations, int TaskNum)
         {
-            int beforeStatus = locationInfo.LocationStatus;
-            int beforeStatu = locationInfos.LocationStatus;
+            int beforeEndStatus = locations.LocationStatus;
 
-            locationInfo.LocationStatus = LocationStatusEnum.Free.ObjToInt();
-            locationInfos.LocationStatus = LocationStatusEnum.InStock.ObjToInt();
+            if(locations.LocationStatus== LocationStatusEnum.Lock.ObjToInt())
+            {
+                locations.LocationStatus = LocationStatusEnum.InStock.ObjToInt();
+            }
+            else
+            {
+                locations.LocationStatus = LocationStatusEnum.Pallet.ObjToInt();
+            }
+            
 
-            BaseDal.UpdateData(locationInfo);
-            BaseDal.UpdateData(locationInfos);
+            BaseDal.UpdateData(locations);
 
-            _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, beforeStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum);
-            _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfos, beforeStatu, StockChangeType.Relocation.ObjToInt(), "", TaskNum);
+            _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locations, beforeEndStatus, StockChangeType.Relocation.ObjToInt(), "", TaskNum);
         }
     }
 }

--
Gitblit v1.9.3