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