| | |
| | | using Microsoft.AspNetCore.Mvc.RazorPages; |
| | | using Microsoft.AspNetCore.Mvc; |
| | | using Microsoft.AspNetCore.Mvc.RazorPages; |
| | | using OfficeOpenXml.FormulaParsing.Excel.Functions.DateTime; |
| | | using SqlSugar; |
| | | using System; |
| | |
| | | return content; |
| | | } |
| | | /// <summary> |
| | | /// è·åå¯ç§»åºè´§ä½ |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public Dt_LocationInfo AssignLocation() |
| | | { |
| | | Dt_LocationInfo? locationInfo = null; |
| | | string CarChargingStation = AppSettings.Configuration[nameof(CarChargingStation)];//è·åç©¿æ¢è½¦å
çµä½ç½® |
| | | var ChargingStations = CarChargingStation.Split(","); |
| | | locationInfo = BaseDal.QueryFirst(x => !ChargingStations.Contains(x.LocationCode) && x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt()) && x.Row == 3, _emptyAssignOrderBy); |
| | | |
| | | if (locationInfo == null) |
| | | locationInfo = BaseDal.QueryFirst(x => !ChargingStations.Contains(x.LocationCode) && x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt() && x.Row == 1), _emptyAssignOrderBy); |
| | | if (locationInfo == null) |
| | | locationInfo = BaseDal.QueryFirst(x => !ChargingStations.Contains(x.LocationCode) && x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt() && x.Row == 2), _emptyAssignOrderBy); |
| | | return locationInfo; |
| | | } |
| | | |
| | | public Dt_LocationInfo AssignLocation(string[] Stations) |
| | | { |
| | | Dt_LocationInfo? locationInfo = null; |
| | | var locationInfos = BaseDal.QueryData(x => Stations.Contains(x.LocationCode) && x.CurrentQty < x.MaxQty - 1, _emptyAssignOrderBy); |
| | | if (locationInfos != null && locationInfos.Count > 0) |
| | | locationInfo = locationInfos[0]; |
| | | return locationInfo; |
| | | } |
| | | /// <summary> |
| | | /// è·å空æè´§ä½ |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public Dt_LocationInfo GetLocationPallet() |
| | | { |
| | | string CarChargingStation = AppSettings.Configuration[nameof(CarChargingStation)];//è·åç©¿æ¢è½¦å
çµä½ç½® |
| | | var ChargingStations = CarChargingStation.Split(","); |
| | | Dt_LocationInfo? locationInfo = null; |
| | | var locationInfos = BaseDal.QueryData(x => !ChargingStations.Contains(x.LocationCode) && x.LocationStatus == LocationStatusEnum.Pallet.ObjToInt() && x.CurrentQty < x.MaxQty, _emptyAssignOrderBy); |
| | | if (locationInfos.Count > 1 && locationInfos != null) locationInfo = locationInfos[0]; |
| | | return locationInfo; |
| | | } |
| | | /// <summary> |
| | | /// åé
è´§ä½ |
| | | /// </summary> |
| | | /// <param name="stockInfo">ç»çä¿¡æ¯</param> |
| | |
| | | /// <exception cref="Exception"></exception> |
| | | public Dt_LocationInfo AssignLocation(int inboundOrderCount) |
| | | { |
| | | Dt_LocationInfo locationInfo = BaseDal.QueryFirst(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt()) && x.Row == (inboundOrderCount > 1 ? 1 : 3), _emptyAssignOrderBy); |
| | | string CarChargingStation = AppSettings.Configuration[nameof(CarChargingStation)];//è·åç©¿æ¢è½¦å
çµä½ç½® |
| | | var ChargingStations = CarChargingStation.Split(","); |
| | | Dt_LocationInfo? locationInfo = null; |
| | | var locationInfos = BaseDal.QueryData(x => !ChargingStations.Contains(x.LocationCode) && x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt()) && x.CurrentQty < 1 && x.Row == (inboundOrderCount > 1 ? 1 : 3), _emptyAssignOrderBy); |
| | | if (locationInfos.Count > 1 && locationInfos != null) locationInfo = locationInfos[0]; |
| | | |
| | | if (locationInfo == null) locationInfo = BaseDal.QueryFirst(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt()), _emptyAssignOrderBy); |
| | | if (locationInfo == null) |
| | | { |
| | | locationInfos = BaseDal.QueryData(x => !ChargingStations.Contains(x.LocationCode) && x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt() && x.CurrentQty < 1), _emptyAssignOrderBy); |
| | | if (locationInfos.Count > 1 && locationInfos != null) locationInfo = locationInfos[0];//éé¢çä¸ä¸ªè´§ä½ç§»åº |
| | | } |
| | | |
| | | return locationInfo; |
| | | } |
| | |
| | | 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 WebResponseContent GetPosition(string position) |
| | | public WebResponseContent GetPosition(string position, string position1) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | Dt_LocationInfo locationInfo = BaseDal.QueryFirst(x => x.LocationCode == position); |
| | | if (locationInfo == null) throw new Exception("æªæ¾å°è´§ä½ä¿¡æ¯"); |
| | | //åé
ç©¿æ¢è½¦ç§»åºå°å |
| | | var locationInfos = BaseDal.QueryData(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && x.EnableStatus != EnableStatusEnum.Disable.ObjToInt() && x.LocationCode != locationInfo.LocationCode);//éæ ¹æ®å
¥åºé»è¾æ¹å¨ |
| | | var location = locationInfos.OrderBy(x => x.Layer).ThenBy(x => x.Column).ThenBy(x => x.Row).FirstOrDefault(); |
| | | //if (location != null) content.OK(message: location.LocationCode, data: location); |
| | | if (location != null) content.OK(location.LocationCode); |
| | | Dt_LocationInfo? locationInfo = null; |
| | | //Dt_LocationInfo locationInfo = BaseDal.QueryFirst(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt() && (x.EnableStatus == EnableStatusEnum.OnlyIn.ObjToInt() || x.EnableStatus == EnableStatusEnum.Normal.ObjToInt()) && (x.Row == 1 || x.Row == 3), _emptyAssignOrderBy); |
| | | string position2 = string.Empty; |
| | | string[] Codes = position1.Split("-"); |
| | | var row = Convert.ToInt16(Codes[0]); |
| | | if (row < 3) |
| | | { |
| | | position2 = row == 1 ? "002" + "-" + Codes[1] + "-" + Codes[2] : "001" + "-" + Codes[1] + "-" + Codes[2]; |
| | | } |
| | | if (string.IsNullOrEmpty(position2)) |
| | | { |
| | | locationInfo = BaseDal.QueryFirst(x => x.CurrentQty < x.MaxQty && x.LocationCode != position && x.LocationCode != position1, _emptyAssignOrderBy); |
| | | } |
| | | else |
| | | { |
| | | locationInfo = BaseDal.QueryFirst(x => x.CurrentQty < x.MaxQty && x.LocationCode != position && x.LocationCode != position1 && x.LocationCode != position2, _emptyAssignOrderBy); |
| | | } |
| | | if (locationInfo != null) content.OK(locationInfo.LocationCode); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | |
| | | } |
| | | return content; |
| | | } |
| | | /// <summary> |
| | | /// è·åè´§ä½ä¿¡æ¯ |
| | | /// </summary> |
| | | /// <param name="model"></param> |
| | | /// <returns></returns> |
| | | public WebResponseContent GetLocationInfo(SaveModel model) |
| | | { |
| | | WebResponseContent response = new WebResponseContent(); |
| | | try |
| | | { |
| | | List<Dt_LocationInfo> locationInfos = BaseDal.QueryData(x => true); |
| | | var Freelocations = locationInfos.Where(x => x.LocationStatus == LocationStatusEnum.Free.ObjToInt()).ToList(); |
| | | var Palletlocations = locationInfos.Where(x => x.LocationStatus == LocationStatusEnum.Pallet.ObjToInt()).ToList(); |
| | | var InStocklocations = locationInfos.Where(x => x.LocationStatus != LocationStatusEnum.Free.ObjToInt() && x.LocationStatus != LocationStatusEnum.Pallet.ObjToInt()).ToList(); |
| | | //Dictionary<string, object> keyValuePairs = new Dictionary<string, object>(); |
| | | //keyValuePairs.Add("空货ä½", Freelocations.Count); |
| | | //keyValuePairs.Add("空æç", Palletlocations.Count); |
| | | //keyValuePairs.Add("æè´§", InStocklocations.Count); |
| | | response.OK(data: new |
| | | { |
| | | FreeQty = Freelocations.Count, |
| | | PalletQty = Palletlocations.Count, |
| | | InStockQty = InStocklocations.Count, |
| | | }); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | response.Error(ex.Message); |
| | | } |
| | | return response; |
| | | } |
| | | } |
| | | } |