From c05003c73bbe527478bccc55efe25c19068b6f50 Mon Sep 17 00:00:00 2001
From: Huangxiaoqiang-03 <1247017146@qq.com>
Date: 星期三, 23 十月 2024 17:30:42 +0800
Subject: [PATCH] 1

---
 代码管理/WMS/WIDESEA_WMSServer/WIDESEA_BasicService/Service/LocationInfoService.cs |  141 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 139 insertions(+), 2 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 cfdfdeb..40dbb76 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"
@@ -1,16 +1,19 @@
-锘縰sing SqlSugar;
+锘縰sing AutoMapper;
+using SqlSugar;
 using System;
 using System.Collections.Generic;
 using System.Linq;
 using System.Text;
 using System.Threading.Tasks;
 using WIDESEA_Core;
+using WIDESEA_Core.BaseRepository;
 using WIDESEA_Core.BaseServices;
 using WIDESEA_Core.Enums;
 using WIDESEA_Core.Helper;
 using WIDESEA_Core.Utilities;
 using WIDESEA_DTO.Basic;
 using WIDESEA_IBasicRepository;
+using WIDESEA_IRecordService;
 using WIDESEA_IBasicService;
 using WIDESEA_Model.Models;
 
@@ -18,7 +21,12 @@
 {
     public partial class LocationInfoService : ServiceBase<Dt_LocationInfo, ILocationInfoRepository>, ILocationInfoService
     {
-
+        private readonly IRecordService _recordService;
+        public LocationInfoService(ILocationInfoRepository BaseDal, IBasicRepository basicRepository, IRecordService recordService) : base(BaseDal)
+        {
+            _basicRepository = basicRepository;
+            _recordService = recordService;
+        }
         private Dictionary<string, OrderByType> _emptyAssignOrderBy = new Dictionary<string, OrderByType>()
         {
             { nameof(Dt_LocationInfo.Depth), OrderByType.Desc },
@@ -59,6 +67,10 @@
             }
 
             return null;
+        }
+        public virtual Dt_LocationInfo? AssignLocation(string RoadwayNo)
+        {
+            return StoredAssignLocation(RoadwayNo);
         }
 
         private Dt_LocationInfo EmptyAssignLocation(string roadway)
@@ -111,5 +123,130 @@
         {
             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)
+        {
+            try
+            {
+                if (locationInfo.Depth == 2)
+                {
+                    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.Lock.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.Lock.ObjToInt();
+                            BaseDal.UpdateData(dt_LocationInfo);
+                        }
+                    }
+                    _recordService.LocationStatusChangeRecordSetvice.AddLocationStatusChangeRecord(locationInfo, beforeStatus, StockChangeType.Lock.ObjToInt(), "", TaskNum);
+                }
+            }
+            catch (Exception ex)
+            {
+                throw ex;
+            }
+
+        }
+        public void UpdateLocationFree(Dt_LocationInfo locationInfo, int? TaskNum)
+        {
+            try
+            {
+                if (locationInfo.Depth == 2)
+                {
+                    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);
+                }
+            }
+            catch (Exception ex)
+            {
+                throw ex;
+            }
+
+        }
+        public Dt_LocationInfo isDepth(Dt_LocationInfo locationInfo)
+        {
+            if (locationInfo.Depth == 2)
+            {
+                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())
+                    {
+                        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())
+                    {
+                        return dt_LocationInfo;
+                    }
+                }
+            }
+            return null;
+        }
+        public void RelocationLock(Dt_LocationInfo locationInfo, Dt_LocationInfo locationInfos,int TaskNum)
+        {
+            int beforeStatus = locationInfo.LocationStatus;
+            int beforeStatu = locationInfos.LocationStatus;
+
+            locationInfo.LocationStatus = LocationStatusEnum.Lock.ObjToInt();
+            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);
+        }
+        public void RelocationFree(Dt_LocationInfo locationInfo, Dt_LocationInfo locationInfos, int TaskNum)
+        {
+            int beforeStatus = locationInfo.LocationStatus;
+            int beforeStatu = locationInfos.LocationStatus;
+
+            locationInfo.LocationStatus = LocationStatusEnum.Free.ObjToInt();
+            locationInfos.LocationStatus = LocationStatusEnum.InStock.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);
+        }
     }
 }

--
Gitblit v1.9.3