| | |
| | | public string AccessingTunnel(int WarehouseId, int LocationType) |
| | | { |
| | | List<Dt_LocationInfo> locationData = BaseDal.QueryData(x => x.WarehouseId == WarehouseId); |
| | | var roadwayGroups = locationData.Where(x => x.LocationType == LocationType).GroupBy(x => x.RoadwayNo) |
| | | var roadwayGroups = locationData.Where(x => x.LocationType == LocationType && x.LocationStatus== (int)LocationStatusEnum.Free && x.EnableStatus== (int)EnableStatusEnum.Normal).GroupBy(x => x.RoadwayNo) |
| | | .Select(g => new |
| | | { |
| | | RoadwayNo = g.Key, |
| | |
| | | if (LocationType == 2) minRequired = 6; |
| | | |
| | | var selectedRoadway = roadwayGroups.FirstOrDefault(g => g.LocationCount >= minRequired); |
| | | return selectedRoadway.RoadwayNo; |
| | | if(selectedRoadway!=null) return selectedRoadway.RoadwayNo; |
| | | |
| | | } |
| | | else |
| | | { |
| | | var selectedRoadway = roadwayGroups.FirstOrDefault(g => g.LocationCount >= minRequired); |
| | | if(selectedRoadway != null) |
| | | if(selectedRoadway == null) |
| | | { |
| | | return selectedRoadway.RoadwayNo; |
| | | selectedRoadway = roadwayGroups.FirstOrDefault(g => g.RoadwayNo == "5" && g.LocationCount != 0); |
| | | |
| | | } |
| | | else |
| | | { |
| | | selectedRoadway = roadwayGroups.FirstOrDefault(g => g.RoadwayNo =="5" && g.LocationCount != 0); |
| | | } |
| | | return selectedRoadway.RoadwayNo; |
| | | if(selectedRoadway != null) return selectedRoadway.RoadwayNo; |
| | | } |
| | | |
| | | return "0"; |
| | | } |
| | | |
| | | |
| | | public Dt_LocationInfo? ShallowGetLocation(string roadway, int Locationtype,int row ,int Layer, int Column) |
| | | { |
| | | return BaseDal.QueryData(x => x.RoadwayNo == roadway && x.LocationType == Locationtype && x.Row==row && x.Layer== Layer && x.Column== Column).FirstOrDefault(); |
| | | } |
| | | |
| | | public Dt_LocationInfo? FindStorageLocation(string LocationCode) |
| | | { |
| | | return BaseDal.QueryData(x => x.LocationCode == LocationCode).FirstOrDefault(); |
| | | } |
| | | |
| | | |
| | |
| | | if (emptyLocations[i].Depth == 1)//夿æ¯å¦1æ·±è´§ä½ |
| | | { |
| | | //æ¥è¯¢æ·±åºä½ |
| | | int emprow = emptyLocations[i].Row == 2 ? 1 : 4; |
| | | //int emprow = emptyLocations[i].Row == 2 ? 1 : 4; |
| | | int emprow = judgmentRow(emptyLocations[i].RoadwayNo,emptyLocations[i].Row); |
| | | |
| | | Dt_LocationInfo? sencondDepthLocationShen = emptyLocations.FirstOrDefault(x => x.Row == emprow && x.Layer == emptyLocations[i].Layer && x.Column == emptyLocations[i].Column); |
| | | if (sencondDepthLocationShen != null && sencondDepthLocationShen.LocationStatus == LocationStatusEnum.Free.ObjToInt()) |
| | |
| | | { |
| | | locationCaches.Add(new LocationCache { DateTime = DateTime.Now, LocationCode = emptyLocations[i].LocationCode }); |
| | | return emptyLocations[i]; |
| | | }else if (emptyLocations[i].RoadwayNo=="5" && emptyLocations[i].LocationStatus == LocationStatusEnum.Free.ObjToInt()) |
| | | { |
| | | locationCaches.Add(new LocationCache { DateTime = DateTime.Now, LocationCode = emptyLocations[i].LocationCode }); |
| | | return emptyLocations[i]; |
| | | } |
| | | } |
| | | } |
| | | else |
| | | { |
| | | //æ¥è¯¢2深货ä½å¯¹åºç1æ·±è´§ä½æ¯å¦ä¸ºç©º |
| | | int emprow = emptyLocations[i].Row == 4 ? 3 : 2; |
| | | //int emprow = emptyLocations[i].Row == 4 ? 3 : 2; |
| | | int emprow = judgmentRow(emptyLocations[i].RoadwayNo, emptyLocations[i].Row); |
| | | |
| | | Dt_LocationInfo? sencondDepthLocationQian = emptyLocations.FirstOrDefault(x => x.Row == emprow && x.Layer == emptyLocations[i].Layer && x.Column == emptyLocations[i].Column); |
| | | if (sencondDepthLocationQian != null && sencondDepthLocationQian.LocationStatus == LocationStatusEnum.Free.ObjToInt()) |
| | |
| | | } |
| | | } |
| | | |
| | | public int judgmentRow(string RoadwayNo, int locrow) |
| | | { |
| | | if (RoadwayNo == "1" || RoadwayNo == "3") |
| | | { |
| | | if(locrow==1 || locrow == 4) |
| | | { |
| | | return locrow == 1 ? 2 : 3; |
| | | } |
| | | else |
| | | { |
| | | return locrow == 2 ? 1 : 4; |
| | | } |
| | | |
| | | } |
| | | else if (RoadwayNo == "2" || RoadwayNo == "4") |
| | | { |
| | | if (locrow == 5 || locrow == 8) |
| | | { |
| | | return locrow == 5 ? 6 : 7; |
| | | } |
| | | else |
| | | { |
| | | return locrow == 6 ? 5 : 8; |
| | | } |
| | | |
| | | } |
| | | else |
| | | { |
| | | return 0; |
| | | } |
| | | } |
| | | |
| | | public class LocationCache |
| | | { |
| | | public string LocationCode { get; set; } |
| | | |
| | | public DateTime DateTime { get; set; } |
| | | } |
| | | |
| | | |
| | | |
| | | public WebResponseContent GetArea() |
| | | { |
| | | // WarehouseIdåç»ï¼ç¶åæ¯RoadwayNo |
| | | var result = BaseDal.QueryData() |
| | | .GroupBy(x => x.WarehouseId) |
| | | .Select(g => new { |
| | | WarehouseId = g.Key, |
| | | RoadwayNo = g.Select(x => x.RoadwayNo).Distinct().ToList() |
| | | }) |
| | | .ToList(); |
| | | return WebResponseContent.Instance.OK("æå", result); |
| | | } |
| | | |
| | | public WebResponseContent GetLocationStatus(int WarehouseId, string RoadwayNo) |
| | | { |
| | | // æ ¼å¼{å±,{è¿ä¸å±çåæ°æ®}} |
| | | var locations = BaseDal.QueryData(x => x.WarehouseId == WarehouseId && x.RoadwayNo == RoadwayNo) |
| | | .Select(x => new |
| | | { |
| | | x.RoadwayNo, |
| | | x.LocationCode, |
| | | x.WarehouseId, |
| | | x.Row, |
| | | x.Column, |
| | | x.Layer, |
| | | x.Depth, |
| | | x.LocationType, |
| | | x.LocationStatus, |
| | | x.EnableStatus |
| | | }) |
| | | .ToList(); |
| | | |
| | | // å¦ææ²¡ææ¾å°æ°æ®ï¼è¿å空å表è䏿¯null |
| | | if (locations == null || !locations.Any()) |
| | | { |
| | | return WebResponseContent.Instance.OK("æªæ¾å°å¯¹åºå··éçè´§ä½æ°æ®", new List<object>()); |
| | | } |
| | | |
| | | // ä¿®æ¹ä¸ºå±ä¸é¢æ¾ææåçä¿¡æ¯ |
| | | var result = locations |
| | | .GroupBy(x => x.Layer) // æå±åç» |
| | | .Select(layerGroup => new |
| | | { |
| | | layer = layerGroup.Key, |
| | | columns = layerGroup.GroupBy(x => x.Column) // æ¯å±ä¸æååç» |
| | | .Select(columnGroup => new |
| | | { |
| | | column = columnGroup.Key, |
| | | depths = columnGroup.Select(d => new |
| | | { |
| | | row = d.Row, |
| | | LocationCode = d.LocationCode, |
| | | depth = d.Depth, |
| | | locationType = d.LocationType, |
| | | locationStatus = d.LocationStatus, |
| | | enableStatus = d.EnableStatus |
| | | }).ToList() |
| | | }).ToList() |
| | | }).ToList(); |
| | | |
| | | return WebResponseContent.Instance.OK("æå", result); |
| | | } |
| | | |
| | | public WebResponseContent GetWarehouseCapacity() |
| | | { |
| | | // æ¥è¯¢ææä»åºçè´§ä½æ°æ® |
| | | var allLocations = BaseDal.QueryData() |
| | | .Select(x => new |
| | | { |
| | | x.WarehouseId, |
| | | x.LocationStatus |
| | | }) |
| | | .ToList(); |
| | | |
| | | // å¦ææ²¡ææ°æ®ï¼è¿å空å表 |
| | | if (allLocations == null || !allLocations.Any()) |
| | | { |
| | | return WebResponseContent.Instance.OK("æªæ¾å°ä»»ä½è´§ä½æ°æ®", new List<object>()); |
| | | } |
| | | |
| | | // è®¡ç®æ¯ä¸ªä»åºç容éä½¿ç¨æ
åµ |
| | | var result = allLocations |
| | | .GroupBy(x => x.WarehouseId) |
| | | .Select(g => new |
| | | { |
| | | WarehouseId = g.Key, |
| | | FreeLocations = g.Count(x => x.LocationStatus == 0), |
| | | RemainingCapacityPercentage = (int)Math.Round((double)g.Count(x => x.LocationStatus == 0) / g.Count() * 100) |
| | | }) |
| | | .ToList(); |
| | | |
| | | return WebResponseContent.Instance.OK("æå", result); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// ä¸é®å¯ç¨å··éææè´§ä½ |
| | | /// </summary> |
| | | /// <param name="warehouseId">ä»åºID</param> |
| | | /// <param name="roadwayNo">å··éç¼å·</param> |
| | | /// <returns></returns> |
| | | public WebResponseContent EnableAllLocationsInRoadway(string roadwayNo) |
| | | { |
| | | if (string.IsNullOrEmpty(roadwayNo)) |
| | | return WebResponseContent.Instance.Error("å··éç¼å·ä¸è½ä¸ºç©º"); |
| | | |
| | | var locations = Repository.QueryData(x => |
| | | x.RoadwayNo == roadwayNo && |
| | | x.EnableStatus != EnableStatusEnum.Normal.ObjToInt()); |
| | | |
| | | if (locations == null || locations.Count == 0) |
| | | return WebResponseContent.Instance.OK("è¯¥å··éæ²¡æéè¦å¯ç¨çè´§ä½"); |
| | | |
| | | locations.ForEach(x => x.EnableStatus = EnableStatusEnum.Normal.ObjToInt()); |
| | | Repository.UpdateData(locations); |
| | | |
| | | return WebResponseContent.Instance.OK($"æåå¯ç¨å··é[{roadwayNo}]ç{locations.Count}个货ä½"); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// ä¸é®ç¦ç¨å··éææè´§ä½ |
| | | /// </summary> |
| | | /// <param name="warehouseId">ä»åºID</param> |
| | | /// <param name="roadwayNo">å··éç¼å·</param> |
| | | /// <returns></returns> |
| | | public WebResponseContent DisableAllLocationsInRoadway(string roadwayNo) |
| | | { |
| | | if (string.IsNullOrEmpty(roadwayNo)) |
| | | return WebResponseContent.Instance.Error("å··éç¼å·ä¸è½ä¸ºç©º"); |
| | | var locations = Repository.QueryData(x => |
| | | x.RoadwayNo == roadwayNo && |
| | | x.EnableStatus != EnableStatusEnum.Disable.ObjToInt()); |
| | | if (locations == null || locations.Count == 0) |
| | | return WebResponseContent.Instance.OK("è¯¥å··éæ²¡æéè¦ç¦ç¨çè´§ä½"); |
| | | // æ£æ¥è´§ä½æ¯å¦æåºå |
| | | var locationIds = locations.Select(x => x.Id).ToList(); |
| | | locations.ForEach(x => x.EnableStatus = EnableStatusEnum.Disable.ObjToInt()); |
| | | Repository.UpdateData(locations); |
| | | return WebResponseContent.Instance.OK($"æåç¦ç¨å··é[{roadwayNo}]ç{locations.Count}个货ä½"); |
| | | } |
| | | } |
| | | } |