| | |
| | | using HslCommunication; |
| | | using MailKit.Search; |
| | | using Newtonsoft.Json; |
| | | using System; |
| | | using System.Collections.Generic; |
| | |
| | | |
| | | namespace WIDESEA_SquareCabinServices |
| | | { |
| | | public class DeliveryOrderServices : ServiceBase<Dt_DeliveryOrder, IRepository<Dt_DeliveryOrder>>, IDeliveryOrderServices |
| | | public partial class DeliveryOrderServices : ServiceBase<Dt_DeliveryOrder, IRepository<Dt_DeliveryOrder>>, IDeliveryOrderServices |
| | | { |
| | | static string SearchDate = ""; |
| | | private readonly IBasicService _basicService; |
| | |
| | | private readonly IInventoryInfoService _inventoryInfoService; |
| | | private readonly IDeliveryOrderDetailServices _deliveryOrderDetailServices; |
| | | private readonly ISupplyTaskService _supplyTaskService; |
| | | private readonly ICabinOrderServices _cabinOrderServices; |
| | | public IRepository<Dt_DeliveryOrder> Repository => BaseDal; |
| | | public DeliveryOrderServices(IRepository<Dt_DeliveryOrder> BaseDal, IBasicService basicService, IUnitOfWorkManage unitOfWorkManage, IInventory_BatchServices inventory_BatchServices, IInventoryInfoService inventoryInfoService, IDeliveryOrderDetailServices deliveryOrderDetailServices, ISupplyTaskService supplyTaskService) : base(BaseDal) |
| | | public DeliveryOrderServices(IRepository<Dt_DeliveryOrder> BaseDal, IBasicService basicService, IUnitOfWorkManage unitOfWorkManage, IInventory_BatchServices inventory_BatchServices, IInventoryInfoService inventoryInfoService, IDeliveryOrderDetailServices deliveryOrderDetailServices, ISupplyTaskService supplyTaskService, ICabinOrderServices cabinOrderServices) : base(BaseDal) |
| | | { |
| | | _basicService = basicService; |
| | | _unitOfWorkManage = unitOfWorkManage; |
| | |
| | | _supplyTaskService = supplyTaskService; |
| | | _inventory_BatchServices = inventory_BatchServices; |
| | | _inventoryInfoService = inventoryInfoService; |
| | | _cabinOrderServices = cabinOrderServices; |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | //} |
| | | |
| | | |
| | | |
| | | public WebResponseContent GetUpstreamOutOrder() |
| | | { |
| | | var responseContent = new WebResponseContent(); |
| | | try |
| | | { |
| | | var url = "http://121.37.118.63:80/GYZ2/95fck/outOrder"; |
| | | |
| | | var requestData = new |
| | | { |
| | | searchDate = "2022-10-10 20:45:16" |
| | | }; |
| | | |
| | | var result = HttpHelper.Post(url, requestData.ToJsonString()); |
| | | var response = JsonConvert.DeserializeObject<UpstreamResponse<UpstramOutOrderInfo>>(result); |
| | | |
| | | if (response.resultCode != "0") |
| | | { |
| | | SendErrorToUpstream(3, "", response.resultMsg ?? "䏿¸¸æ¥å£è¿å失败", ""); |
| | | return responseContent.Error(response.resultMsg ?? "䏿¸¸æ¥å£è¿å失败"); |
| | | } |
| | | |
| | | if (response.data == null || !response.data.Any()) |
| | | { |
| | | return responseContent.OK("æ æ°åºåºåæ°æ®"); |
| | | } |
| | | |
| | | // å·²åå¨åºåºåå· |
| | | var existingOutOrderNos = BaseDal.Db.Queryable<Dt_DeliveryOrder>() |
| | | .Select(x => x.Out_no) |
| | | .ToList(); |
| | | |
| | | // æ°åºåºå |
| | | var newOutOrders = response.data |
| | | .Where(outorder => !existingOutOrderNos.Contains(outorder.order_no)) |
| | | .ToList(); |
| | | |
| | | if (!newOutOrders.Any()) |
| | | { |
| | | return responseContent.OK("ææåºåºåå·²åå¨ï¼æ éæ°å¢"); |
| | | } |
| | | |
| | | Db.Ado.BeginTran(); |
| | | try |
| | | { |
| | | List<Dt_DeliveryOrder> _DeliveryOrders = new List<Dt_DeliveryOrder>(); |
| | | |
| | | foreach (var outorder in newOutOrders) |
| | | { |
| | | var entityOrder = new Dt_DeliveryOrder |
| | | { |
| | | Out_no = outorder.order_no, |
| | | Out_type = outorder.order_type, |
| | | Client_no = outorder.client_no, |
| | | Client_name = outorder.client_name, |
| | | Account_time = outorder.account_time, |
| | | Warehouse_no = outorder.warehouse_no, |
| | | OutStatus = "æªå®æ", |
| | | Details = new List<Dt_DeliveryOrderDetail>() |
| | | }; |
| | | |
| | | // éååºåºæç» |
| | | foreach (var item in outorder.details) |
| | | { |
| | | // 1ï¸â£ è½¬ä¸ºæ£æ°ï¼ä¸æ¸¸å¯è½ä¼ è´æ°ï¼ |
| | | item.order_qty = Math.Abs(item.order_qty); |
| | | decimal orderQty = (decimal)item.order_qty; |
| | | |
| | | // 2ï¸â£ æ¥ç©æåºç¡ä¿¡æ¯ï¼è·åç®±è§ï¼ |
| | | var medication = BaseDal.Db.Queryable<Dt_MedicineGoods>() |
| | | .Where(m => m.Goods_no == item.goods_no) |
| | | .First(); |
| | | |
| | | if (medication == null) |
| | | { |
| | | SendErrorToUpstream(3, "", $"æ¾ä¸å°ç©æä¿¡æ¯ï¼{item.goods_no}", ""); |
| | | continue; |
| | | } |
| | | |
| | | decimal boxQty = medication.BoxQty <= 0 ? 1 : medication.BoxQty; |
| | | |
| | | // 3ï¸â£ è®¡ç®æ´ä»¶ä¸æ£ä»¶æ°é |
| | | var fullBoxes = (int)(orderQty / boxQty); // æ´ä»¶ç®±æ° |
| | | var partialQty = orderQty % boxQty; // æ£ä»¶æ°é |
| | | |
| | | // è¥ä¸æ¸¸ç»äºæ¹æ¬¡å·ï¼åä¼å
å¹é
|
| | | string requestedBatch = string.IsNullOrEmpty(item.batch_num) ? null : item.batch_num; |
| | | |
| | | // helper: æ¥è¯¢åºå彿°ï¼æå
¥åºæ¶é´ååºï¼ |
| | | Func<int, List<Dt_InventoryInfo>> queryInventoryByStockStatus = (stockStatus) => |
| | | { |
| | | var q = BaseDal.Db.Queryable<Dt_InventoryInfo>() |
| | | .Where(i => i.MaterielCode == item.goods_no && |
| | | (i.StockQuantity - i.OutboundQuantity) > 0 && |
| | | i.StockStatus == stockStatus); |
| | | |
| | | if (!string.IsNullOrEmpty(requestedBatch)) |
| | | q = q.Where(i => i.BatchNo == requestedBatch); |
| | | |
| | | return q.OrderBy(i => i.InDate).ToList(); |
| | | }; |
| | | |
| | | // 4ï¸â£åé
æ£ä»¶ï¼ä¼å
ç«åº Status=1ï¼ |
| | | decimal remainingPartial = partialQty; |
| | | if (remainingPartial > 0) |
| | | { |
| | | var invList_ly = queryInventoryByStockStatus(1); |
| | | foreach (var inv in invList_ly) |
| | | { |
| | | if (remainingPartial <= 0) break; |
| | | |
| | | decimal available = (decimal)(inv.StockQuantity - inv.OutboundQuantity); |
| | | if (available <= 0) continue; |
| | | |
| | | decimal use = Math.Min(available, remainingPartial); |
| | | |
| | | var detail = new Dt_DeliveryOrderDetail |
| | | { |
| | | Goods_no = item.goods_no, |
| | | Order_qty = use, |
| | | Batch_num = inv.BatchNo, |
| | | Exp_date = inv.ValidityPeriod, |
| | | OotDetailStatus = "æ°å»º", |
| | | Status = 0, //ç«åº |
| | | Reservoirarea = inv.LocationCode |
| | | }; |
| | | entityOrder.Details.Add(detail); |
| | | |
| | | inv.OutboundQuantity += (float)use; |
| | | BaseDal.Db.Updateable(inv).ExecuteCommand(); |
| | | |
| | | remainingPartial -= use; |
| | | } |
| | | |
| | | // ç«åºä¸å¤ â å¹³åºè¡¥ (Status=2) |
| | | if (remainingPartial > 0) |
| | | { |
| | | var invList_pk = queryInventoryByStockStatus(2); |
| | | foreach (var inv in invList_pk) |
| | | { |
| | | if (remainingPartial <= 0) break; |
| | | |
| | | decimal available = (decimal)(inv.StockQuantity - inv.OutboundQuantity); |
| | | if (available <= 0) continue; |
| | | |
| | | decimal use = Math.Min(available, remainingPartial); |
| | | |
| | | var detail = new Dt_DeliveryOrderDetail |
| | | { |
| | | Goods_no = item.goods_no, |
| | | Order_qty = use, |
| | | Batch_num = inv.BatchNo, |
| | | Exp_date = inv.ValidityPeriod, |
| | | OotDetailStatus = "æ°å»º", |
| | | Status = 2, //å¹³åº |
| | | Reservoirarea = inv.LocationCode |
| | | }; |
| | | entityOrder.Details.Add(detail); |
| | | |
| | | inv.OutboundQuantity += (float)use; |
| | | BaseDal.Db.Updateable(inv).ExecuteCommand(); |
| | | |
| | | remainingPartial -= use; |
| | | } |
| | | } |
| | | |
| | | if (remainingPartial > 0) |
| | | { |
| | | SendErrorToUpstream(3, "", $"åºåºå[{outorder.order_no}]ç©æ[{item.goods_no}]æ£ä»¶åºåä¸è¶³ï¼æªåé
ï¼{remainingPartial}", ""); |
| | | } |
| | | } |
| | | |
| | | //åé
æ´ä»¶ï¼ä¼å
å¹³åº Status=2ï¼ |
| | | int remainingFullBoxes = fullBoxes; |
| | | if (remainingFullBoxes > 0) |
| | | { |
| | | var invList_pk = queryInventoryByStockStatus(2); |
| | | foreach (var inv in invList_pk) |
| | | { |
| | | if (remainingFullBoxes <= 0) break; |
| | | |
| | | decimal available = (decimal)(inv.StockQuantity - inv.OutboundQuantity); |
| | | if (available < boxQty) continue; |
| | | |
| | | int canProvideBoxes = (int)(available / boxQty); |
| | | if (canProvideBoxes <= 0) continue; |
| | | |
| | | int useBoxes = Math.Min(canProvideBoxes, remainingFullBoxes); |
| | | decimal useQty = useBoxes * boxQty; |
| | | |
| | | var detail = new Dt_DeliveryOrderDetail |
| | | { |
| | | Goods_no = item.goods_no, |
| | | Order_qty = useQty, |
| | | Batch_num = inv.BatchNo, |
| | | Exp_date = inv.ValidityPeriod, |
| | | OotDetailStatus = "æ°å»º", |
| | | Status = 2, //å¹³åº |
| | | Reservoirarea = inv.LocationCode |
| | | }; |
| | | entityOrder.Details.Add(detail); |
| | | |
| | | inv.OutboundQuantity += (float)useQty; |
| | | BaseDal.Db.Updateable(inv).ExecuteCommand(); |
| | | |
| | | remainingFullBoxes -= useBoxes; |
| | | } |
| | | |
| | | // å¹³åºä¸å¤ â ç«åºè¡¥ (Status=1) |
| | | if (remainingFullBoxes > 0) |
| | | { |
| | | var invList_ly = queryInventoryByStockStatus(1); |
| | | foreach (var inv in invList_ly) |
| | | { |
| | | if (remainingFullBoxes <= 0) break; |
| | | |
| | | decimal available = (decimal)(inv.StockQuantity - inv.OutboundQuantity); |
| | | if (available < boxQty) continue; |
| | | |
| | | int canProvideBoxes = (int)(available / boxQty); |
| | | if (canProvideBoxes <= 0) continue; |
| | | |
| | | int useBoxes = Math.Min(canProvideBoxes, remainingFullBoxes); |
| | | decimal useQty = useBoxes * boxQty; |
| | | |
| | | var detail = new Dt_DeliveryOrderDetail |
| | | { |
| | | Goods_no = item.goods_no, |
| | | Order_qty = useQty, |
| | | Batch_num = inv.BatchNo, |
| | | Exp_date = inv.ValidityPeriod, |
| | | OotDetailStatus = "æ°å»º", |
| | | Status = 0, //ç«åºï¼è¡¥æ´ç®±ï¼ |
| | | Reservoirarea = inv.LocationCode |
| | | }; |
| | | entityOrder.Details.Add(detail); |
| | | |
| | | inv.OutboundQuantity += (float)useQty; |
| | | BaseDal.Db.Updateable(inv).ExecuteCommand(); |
| | | |
| | | remainingFullBoxes -= useBoxes; |
| | | } |
| | | } |
| | | |
| | | if (remainingFullBoxes > 0) |
| | | { |
| | | decimal unfilledQty = remainingFullBoxes * boxQty; |
| | | SendErrorToUpstream(3, "", $"åºåºå[{outorder.order_no}]ç©æ[{item.goods_no}]æ´ç®±åºåä¸è¶³ï¼æªåé
æ°éï¼{unfilledQty}", ""); |
| | | } |
| | | } |
| | | } |
| | | |
| | | _DeliveryOrders.Add(entityOrder); |
| | | } |
| | | |
| | | // æå
¥ä¸»è¡¨+æç» |
| | | BaseDal.Db.InsertNav(_DeliveryOrders) |
| | | .Include(x => x.Details) |
| | | .ExecuteCommand(); |
| | | |
| | | Db.Ado.CommitTran(); |
| | | return responseContent.OK("忥åºåºåæå"); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | Db.Ado.RollbackTran(); |
| | | SendErrorToUpstream(3, "", ex.Message, ""); |
| | | return responseContent.Error("åæ¥å¤±è´¥: " + ex.Message); |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | SendErrorToUpstream(3, "", ex.Message, ""); |
| | | return responseContent.Error("åæ¥å¤±è´¥: " + ex.Message); |
| | | } |
| | | } |
| | | |
| | | /// <summary> |
| | | /// è¿æ»¤æ²¡æå¯¹ååè¿è¡ç»´æ¤çåºåºåè¿è¡è¿æ»¤ |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public WebResponseContent GetUpstreamOutOrder2() |
| | | public WebResponseContent GetUpstreamOutOrder() |
| | | { |
| | | var responseContent = new WebResponseContent(); |
| | | try |
| | |
| | | { |
| | | // 1ï¸â£ è½¬ä¸ºæ£æ°ï¼ä¸æ¸¸å¯è½ä¼ è´æ°ï¼ |
| | | item.order_qty = Math.Abs(item.order_qty); |
| | | |
| | | //åºåºæ°é |
| | | decimal orderQty = (decimal)item.order_qty; |
| | | |
| | | // 2ï¸â£ æ¥ç©æåºç¡ä¿¡æ¯ï¼è·åç®±è§ï¼ |
| | | var medication = BaseDal.Db.Queryable<Dt_MedicineGoods>() |
| | | .Where(m => m.Goods_no == item.goods_no) |
| | | var medication = BaseDal.Db.Queryable<Dt_MaterielInfo>() |
| | | .Where(m => m.MaterielCode == item.goods_no) |
| | | .First(); |
| | | #region æ£æ¥è¿ä¸ªåºåºåä¸çç©æä¿¡æ¯æ¯å¦åå¨ |
| | | //å¦æç©æä¿¡æ¯ä¸åå¨ï¼è·³è¿æ´ä¸ªå
¥åºå |
| | | if (medication == null) |
| | | { |
| | |
| | | break; |
| | | } |
| | | |
| | | |
| | | if (medication == null) |
| | | { |
| | | SendErrorToUpstream(3, "", $"æ¾ä¸å°ç©æä¿¡æ¯ï¼{item.goods_no}", ""); |
| | | continue; |
| | | } |
| | | #endregion |
| | | |
| | | // å¦æç®±è§å°äºçäº0ï¼ä½¿ç¨é»è®¤å¼1,å¦åå°±ç¨å®é
æ°é |
| | | decimal boxQty = medication.BoxQty <= 0 ? 1 : medication.BoxQty; |
| | | |
| | | // 3ï¸â£ è®¡ç®æ´ä»¶ä¸æ£ä»¶æ°é |
| | |
| | | string requestedBatch = string.IsNullOrEmpty(item.batch_num) ? null : item.batch_num; |
| | | |
| | | // helper: æ¥è¯¢åºå彿°ï¼æå
¥åºæ¶é´ååºï¼ |
| | | #region 使ç¨åºåä¿¡æ¯ä¸çstockStatusæ¥åºåå¹³åºåç«åº |
| | | // å®ä¹ä¸ä¸ªå§æåéï¼è¾å
¥intåæ°ï¼è¿åList<Dt_InventoryInfo> |
| | | Func<int, List<Dt_InventoryInfo>> queryInventoryByStockStatus = (stockStatus) => |
| | | { |
| | | // 1. å建åºç¡æ¥è¯¢ |
| | | var q = BaseDal.Db.Queryable<Dt_InventoryInfo>() |
| | | .Where(i => i.MaterielCode == item.goods_no && // ç©æç¼å·å¹é
|
| | | (i.StockQuantity - i.OutboundQuantity) > 0 && // å¯ç¨åºå>0 |
| | | i.StockStatus == stockStatus); // åºåç¶æå¹é
|
| | | //Func<int, List<Dt_InventoryInfo>> queryInventoryByStockStatus = (stockStatus) => |
| | | //{ |
| | | // // 1. å建åºç¡æ¥è¯¢ |
| | | // var q = BaseDal.Db.Queryable<Dt_InventoryInfo>() |
| | | // .Where(i => i.MaterielCode == item.goods_no && // ç©æç¼å·å¹é
|
| | | // (i.StockQuantity - i.OutboundQuantity) > 0 && // å¯ç¨åºå>0 |
| | | // i.StockStatus == stockStatus); // åºåç¶æå¹é
|
| | | |
| | | // 2. æ¡ä»¶çéï¼å¦æææ¹æ¬¡å·è¦æ±ï¼ |
| | | // // 2. æ¡ä»¶çéï¼å¦æææ¹æ¬¡å·è¦æ±ï¼ |
| | | // if (!string.IsNullOrEmpty(requestedBatch)) |
| | | // q = q.Where(i => i.BatchNo == requestedBatch); |
| | | |
| | | // // 3. æ§è¡æ¥è¯¢å¹¶è¿åç»æ |
| | | // return q.OrderBy(i => i.InDate).ToList(); // æå
¥åºæ¶é´æåº |
| | | //}; |
| | | #endregion |
| | | |
| | | #region 使ç¨åºæ¿ç¼å·æ¥åºåæ¯å¹³åºåç«åº |
| | | // helper: æ¥è¯¢åºå彿°ï¼æå
¥åºæ¶é´ååºï¼ |
| | | // ç¨åºæ¿ç¼å·åºåç«åºåå¹³åºï¼ç«åº WarehouseCode == "001" è¾å
¥trueå°±æ¯ç«åºå¦åå°±æ¯å¹³åº |
| | | Func<bool, List<Dt_InventoryInfo>> queryInventoryByWarehouseType = (isLiku) => |
| | | { |
| | | var q = BaseDal.Db.Queryable<Dt_InventoryInfo>() |
| | | .Where(i => i.MaterielCode == item.goods_no && |
| | | (i.StockQuantity - i.OutboundQuantity) > 0); |
| | | |
| | | if (isLiku) |
| | | q = q.Where(i => i.WarehouseCode == "001"); // ç«åº |
| | | else |
| | | q = q.Where(i => i.WarehouseCode != "001"); // å¹³åº |
| | | |
| | | if (!string.IsNullOrEmpty(requestedBatch)) |
| | | q = q.Where(i => i.BatchNo == requestedBatch); |
| | | |
| | | // 3. æ§è¡æ¥è¯¢å¹¶è¿åç»æ |
| | | return q.OrderBy(i => i.InDate).ToList(); // æå
¥åºæ¶é´æåº |
| | | return q.OrderBy(i => i.InDate).ToList(); |
| | | }; |
| | | // 4ï¸â£åé
æ£ä»¶ï¼ä¼å
ç«åº Status=0ï¼ |
| | | decimal remainingPartial = partialQty; |
| | | #endregion |
| | | // 4ï¸â£åé
æ£ä»¶ï¼ä¼å
ç«åº WarehouseCode == "001ï¼ |
| | | decimal remainingPartial = partialQty; //æ£ä»¶ |
| | | if (remainingPartial > 0) |
| | | { |
| | | var invList_ly = queryInventoryByStockStatus(0); |
| | | //è¿åä¸ä¸ªList<Dt_InventoryInfo>stockStatus==0çåºåå表 |
| | | var invList_ly = queryInventoryByWarehouseType(true); //ç«åº WarehouseCode == "001" |
| | | foreach (var inv in invList_ly) |
| | | { |
| | | if (remainingPartial <= 0) break; |
| | | |
| | | //å¯ç¨åºåæ°é |
| | | decimal available = (decimal)(inv.StockQuantity - inv.OutboundQuantity); |
| | | |
| | | if (available <= 0) continue; |
| | | |
| | | //表示ãå½åè¿éè¦åºåºçæ°éãæãå¾
åé
æ°éãã |
| | | decimal use = Math.Min(available, remainingPartial); |
| | | |
| | | var detail = new Dt_DeliveryOrderDetail |
| | |
| | | Exp_date = inv.ValidityPeriod, |
| | | OotDetailStatus = "æ°å»º", |
| | | Status = 0, //ç«åº |
| | | Reservoirarea = inv.LocationCode |
| | | Reservoirarea = inv.WarehouseCode |
| | | }; |
| | | entityOrder.Details.Add(detail); |
| | | |
| | | inv.OutboundQuantity += (float)use; |
| | | inv.OutboundQuantity += use; |
| | | BaseDal.Db.Updateable(inv).ExecuteCommand(); |
| | | |
| | | remainingPartial -= use; |
| | |
| | | // ç«åºä¸å¤ â å¹³åºè¡¥ (Status=2) |
| | | if (remainingPartial > 0) |
| | | { |
| | | var invList_pk = queryInventoryByStockStatus(2); |
| | | var invList_pk = queryInventoryByWarehouseType(false); //å¹³åº |
| | | foreach (var inv in invList_pk) |
| | | { |
| | | if (remainingPartial <= 0) break; |
| | |
| | | Exp_date = inv.ValidityPeriod, |
| | | OotDetailStatus = "æ°å»º", |
| | | Status = 2, //å¹³åº |
| | | Reservoirarea = inv.LocationCode |
| | | Reservoirarea = inv.WarehouseCode |
| | | }; |
| | | entityOrder.Details.Add(detail); |
| | | |
| | | inv.OutboundQuantity += (float)use; |
| | | inv.OutboundQuantity += use; |
| | | BaseDal.Db.Updateable(inv).ExecuteCommand(); |
| | | |
| | | remainingPartial -= use; |
| | |
| | | } |
| | | |
| | | //åé
æ´ä»¶ï¼ä¼å
å¹³åº Status=2ï¼ |
| | | int remainingFullBoxes = fullBoxes; |
| | | int remainingFullBoxes = fullBoxes;//æ´ä»¶ç®±æ° |
| | | if (remainingFullBoxes > 0) |
| | | { |
| | | var invList_pk = queryInventoryByStockStatus(2); |
| | | var invList_pk = queryInventoryByWarehouseType(true); |
| | | foreach (var inv in invList_pk) |
| | | { |
| | | if (remainingFullBoxes <= 0) break; |
| | |
| | | Exp_date = inv.ValidityPeriod, |
| | | OotDetailStatus = "æ°å»º", |
| | | Status = 2, //å¹³åº |
| | | Reservoirarea = inv.LocationCode |
| | | Reservoirarea = inv.WarehouseCode |
| | | }; |
| | | entityOrder.Details.Add(detail); |
| | | |
| | | inv.OutboundQuantity += (float)useQty; |
| | | inv.OutboundQuantity += useQty; |
| | | BaseDal.Db.Updateable(inv).ExecuteCommand(); |
| | | |
| | | remainingFullBoxes -= useBoxes; |
| | | } |
| | | |
| | | // å¹³åºä¸å¤ â ç«åºè¡¥ (Status=1) |
| | | // å¹³åºä¸å¤ â ç«åºè¡¥ (Status=0) |
| | | if (remainingFullBoxes > 0) |
| | | { |
| | | var invList_ly = queryInventoryByStockStatus(1); |
| | | var invList_ly = queryInventoryByWarehouseType(true); //ç«åº |
| | | foreach (var inv in invList_ly) |
| | | { |
| | | if (remainingFullBoxes <= 0) break; |
| | |
| | | }; |
| | | entityOrder.Details.Add(detail); |
| | | |
| | | inv.OutboundQuantity += (float)useQty; |
| | | inv.OutboundQuantity += useQty; |
| | | BaseDal.Db.Updateable(inv).ExecuteCommand(); |
| | | |
| | | remainingFullBoxes -= useBoxes; |
| | |
| | | string materialCode = "YY";//é»è®¤å¼ |
| | | //è·åå½å订åç第ä¸ä¸ªæç»é¡¹ |
| | | var firstDetail = order.Details.FirstOrDefault(); |
| | | if (firstDetail?.MedicineGoods != null && !string.IsNullOrEmpty(firstDetail.MedicineGoods.MaterialCode)) |
| | | if (firstDetail?.MedicineGoods != null && !string.IsNullOrEmpty(firstDetail.MedicineGoods.MaterielErpType)) |
| | | { |
| | | //妿æ¡ä»¶æ»¡è¶³ï¼å°ç©æä»£ç 设置为第ä¸ä¸ªæç»é¡¹å¯¹åºçè¯åç©æä»£ç |
| | | materialCode = firstDetail.MedicineGoods.MaterialCode; |
| | | materialCode = firstDetail.MedicineGoods.MaterielErpType; |
| | | } |
| | | // 3. ç»è£
DTO |
| | | var ediDto = new TowcsDto.ToediOutInfo |
| | |
| | | { |
| | | batchNo = d.Batch_num, |
| | | productCode = d.Goods_no, |
| | | productName = d.MedicineGoods?.Goods_spm, |
| | | productSpecifications = d.MedicineGoods?.Model, |
| | | productName = d.MedicineGoods?.MaterielName, |
| | | productSpecifications = d.MedicineGoods?.MaterielModel, |
| | | quantity = (int)d.Order_qty, |
| | | //stocktakingDetails = order.Out_type == "3" |
| | | // ? new List<ToOutediInStock> |
| | |
| | | .SetColumns(d => new Dt_DeliveryOrderDetail { Status = 1, OotDetailStatus = "已宿" }) |
| | | .Where(d => d.DeliveryOrderId == order.Id && d.Status == 0) |
| | | .ExecuteCommand(); |
| | | |
| | | Console.WriteLine($"订å {order.Out_no} æ¨éæå"); |
| | | } |
| | | else |
| | |
| | | } |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | /// <summary> |
| | | /// æ¨éå¼å¸¸ä¿¡æ¯ç»ä¸æ¸¸ç³»ç» 1.å
¥åºåæ¥å£ï¼2.å
¥åºåæ¥å®ææ¥å£ï¼3.åºåºåæ¥å£ï¼4.åºåºæ¥å®ææ¥å£ï¼5.è¯ååºç¡ä¿¡æ¯åæ¥æ¥å£ï¼6.ä¾åºåä¿¡æ¯æ¥å£ï¼7.客æ·ä¿¡æ¯æ¥å£ï¼8.åºåæ¥è¯¢æ¥å£ |
| | |
| | | } |
| | | } |
| | | |
| | | public WebResponseContent GetPdDeliveryOrders(SaveModel saveModel) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | int pageNo = saveModel.MainData["pageNo"].ObjToInt(); |
| | | string warehouseCode = saveModel.MainData["warehouseId"].ToString(); |
| | | string orderNo = saveModel.MainData["orderNo"].ToString(); |
| | | List<Dt_DeliveryOrder> dt_ReceiveOrders = new List<Dt_DeliveryOrder>(); |
| | | if (string.IsNullOrEmpty(orderNo)) |
| | | { |
| | | dt_ReceiveOrders = Db.Queryable<Dt_DeliveryOrder>().Where(x => (x.OutStatus == "æ°å»º" || x.OutStatus == "å¼å§") && x.Warehouse_no == warehouseCode && x.Out_type == "3").Includes(x => x.Details).OrderByDescending(x => x.CreateDate).ToPageList(pageNo, 5); |
| | | } |
| | | else |
| | | { |
| | | dt_ReceiveOrders = Db.Queryable<Dt_DeliveryOrder>().Where(x => (x.Out_no.Contains(orderNo) || x.Client_no.Contains(orderNo)) && (x.OutStatus == "æ°å»º" || x.OutStatus == "å¼å§" && x.Out_type == "3") && x.Warehouse_no == warehouseCode).OrderByDescending(x => x.CreateDate).Includes(x => x.Details).ToPageList(pageNo, 5); |
| | | } |
| | | |
| | | content.OK(data: dt_ReceiveOrders); |
| | | } |
| | | catch (Exception) |
| | | { |
| | | |
| | | throw; |
| | | } |
| | | return content; |
| | | } |
| | | |
| | | public WebResponseContent GetDeliveryOrders(SaveModel saveModel) |
| | | { |
| | |
| | | } |
| | | else |
| | | { |
| | | dt_ReceiveOrders = Db.Queryable<Dt_DeliveryOrder>().Where(x => (x.Out_no.Contains(orderNo) || x.Client_no.Contains(orderNo)) && (x.OutStatus == "æ°å»º" || x.OutStatus == "å¼å§" && x.Out_type != "3") && x.Warehouse_no == warehouseCode).OrderByDescending(x => x.CreateDate).Includes(x => x.Details).ToPageList(pageNo, 5); |
| | | dt_ReceiveOrders = Db.Queryable<Dt_DeliveryOrder>().Where(x => (x.Out_no.Contains(orderNo) || x.Client_no.Contains(orderNo)) && (x.OutStatus == "æ°å»º" || x.OutStatus == "å¼å§") && x.Out_type != "3" && x.Warehouse_no == warehouseCode).OrderByDescending(x => x.CreateDate).Includes(x => x.Details).ToPageList(pageNo, 5); |
| | | } |
| | | |
| | | content.OK(data: dt_ReceiveOrders); |
| | |
| | | return content; |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ¥è¯¢åºåº/çç¹å详æ
çåºåºåæç»ã |
| | | /// </summary> |
| | | /// <param name="pageNo"></param> |
| | | /// <param name="orderNo"></param> |
| | | /// <param name="isPick"></param> |
| | | /// <returns></returns> |
| | | public WebResponseContent GetDeliveryOrderDetail(int pageNo, string orderNo, bool isPick) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | |
| | | cabinOrder = Db.Queryable<Dt_DeliveryOrder>().Includes(x => x.Details).First(x => x.Out_no == orderNo && x.Out_type == "3"); |
| | | else |
| | | cabinOrder = Db.Queryable<Dt_DeliveryOrder>().Includes(x => x.Details).First(x => x.Out_no == orderNo && x.Out_type != "3"); |
| | | List<Dt_DeliveryOrderDetail>? cabinOrderDetails = cabinOrder.Details?.Where(x => x.Reservoirarea == pageNo.ToString()).ToList(); |
| | | content.OK(data: cabinOrderDetails); |
| | | List<Dt_DeliveryOrderDetail>? cabinOrderDetails = cabinOrder.Details?.Where(x => x.Reservoirarea == pageNo.ToString()).ToList(); |
| | | content.OK(data: cabinOrderDetails); |
| | | return content; |
| | | } |
| | | public WebResponseContent MatPicking(SaveModel saveModel) |
| | | |
| | | public WebResponseContent OutFinish(SaveModel saveModel) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | var LocationCode = saveModel.MainData["LocationCode"].ToString(); |
| | | var orderNo = saveModel.MainData["orderNo"].ToString(); |
| | | var batchNo = saveModel.MainData["batchNo"].ToString(); |
| | | var Inqty = saveModel.MainData["Inqty"].ObjToInt(); |
| | | var warehouseCode = saveModel.MainData["warehouseCode"].ToString(); |
| | | Dt_DeliveryOrder cabinOrder = BaseDal.Db.Queryable<Dt_DeliveryOrder>().Where(x => x.Out_no == orderNo && x.Warehouse_no == warehouseCode && x.Out_type == "3").Includes(x => x.Details).First(); |
| | | if (cabinOrder == null) return WebResponseContent.Instance.Error($"çç¹å已宿"); |
| | | Dt_DeliveryOrderDetail cabinOrderDetail = cabinOrder.Details.Where(x => x.Batch_num == batchNo && x.Reservoirarea == warehouseCode).First(); |
| | | if (cabinOrderDetail == null) return WebResponseContent.Instance.Error($"çç¹åæç»å·²å®æ"); |
| | | var LocationCode = saveModel.MainData["locationCode"].ToString(); |
| | | var TaskId = saveModel.MainData["taskId"].ObjToInt(); |
| | | Dt_SupplyTask supplyTask = _supplyTaskService.Repository.QueryFirst(x => x.TaskId == TaskId && x.TaskStatus == SupplyStatusEnum.NewOut.ObjToInt()); |
| | | if (supplyTask == null) throw new Exception("å½ååºåºä»»å¡å·²å®æ"); |
| | | if (supplyTask.LocationCode != LocationCode) throw new Exception($"å½ååºåºè´§ä½ã{LocationCode}ãä¸ä»»å¡åé
è´§ä½ä¸å¹é
"); |
| | | supplyTask.TaskStatus = SupplyStatusEnum.OutFinish.ObjToInt(); |
| | | |
| | | Dt_DeliveryOrder cabinOrder = BaseDal.Db.Queryable<Dt_DeliveryOrder>().Where(x => x.Out_no == supplyTask.OrderNo && x.Warehouse_no == supplyTask.WarehouseCode).Includes(x => x.Details).First(); |
| | | if (cabinOrder == null) return WebResponseContent.Instance.Error($"åºåºå已宿"); |
| | | |
| | | Dt_DeliveryOrderDetail cabinOrderDetail = cabinOrder.Details.Where(x => x.Batch_num == supplyTask.BatchNo && x.Reservoirarea == supplyTask.WarehouseCode && x.Goods_no == supplyTask.MaterielCode).First(); |
| | | if (cabinOrderDetail == null) return WebResponseContent.Instance.Error($"åºåºåæç»å·²å®æ"); |
| | | Dt_MaterielInfo materielInfo = _basicService.MaterielInfoService.Repository.QueryFirst(x => x.MaterielCode == cabinOrderDetail.Goods_no); |
| | | if (materielInfo == null) return WebResponseContent.Instance.Error($"请维æ¤ç©æç¼å·ã{cabinOrderDetail.Goods_no}ãçç©æä¿¡æ¯"); |
| | | cabinOrderDetail.Order_Outqty += Inqty; |
| | | cabinOrderDetail.Order_Outqty += supplyTask.StockQuantity; |
| | | if (cabinOrderDetail.Order_Outqty > cabinOrderDetail.Order_qty) |
| | | return WebResponseContent.Instance.Error($"å®çæ°éä¸å¯è¶
åºè´¦é¢æ°é"); |
| | | return WebResponseContent.Instance.Error($"åºåºæ°éä¸å¯è¶
åºåæ®æ°é"); |
| | | |
| | | |
| | | #region å¤çåºåºåï¼è´§ä½ï¼åºåï¼åºåæ¹æ¬¡ä¿¡æ¯ |
| | | _unitOfWorkManage.BeginTran(); |
| | |
| | | { |
| | | _deliveryOrderDetailServices.Repository.UpdateData(cabinOrderDetail); |
| | | } |
| | | var cabinOrder1 = BaseDal.Db.Queryable<Dt_DeliveryOrder>().Where(x => x.Out_no == cabinOrder.Out_no && x.Out_type == "3").Includes(x => x.Details).First(); |
| | | var cabinOrder1 = BaseDal.Db.Queryable<Dt_DeliveryOrder>().Where(x => x.Out_no == cabinOrder.Out_no && x.Out_type != "3").Includes(x => x.Details).First(); |
| | | if (cabinOrder1.Details == null || cabinOrder1.Details.Count < 1) cabinOrder.OutStatus = "已宿"; |
| | | if (cabinOrder.OutStatus == "已宿") |
| | | Repository.DeleteAndMoveIntoHty(cabinOrder, OperateTypeEnum.èªå¨å®æ); |
| | | else |
| | | Repository.UpdateData(cabinOrder); |
| | | Repository.UpdateData(cabinOrder); |
| | | #endregion |
| | | |
| | | #region åºå |
| | | Dt_InventoryInfo inventoryInfo = _inventoryInfoService.Repository.QueryFirst(x => x.BatchNo == cabinOrderDetail.Batch_num && x.MaterielCode == cabinOrderDetail.Goods_no && x.LocationCode == LocationCode); |
| | | if (inventoryInfo == null) return WebResponseContent.Instance.Error($"æªæ¾å°è´§ä½ã{LocationCode}ãçåºåä¿¡æ¯"); |
| | | inventoryInfo.SupplyQuantity += Inqty; |
| | | _inventoryInfoService.UpdateData(inventoryInfo); |
| | | inventoryInfo.StockQuantity -= supplyTask.StockQuantity; |
| | | if (inventoryInfo.StockQuantity <= 0) |
| | | _inventoryInfoService.DeleteData(inventoryInfo); |
| | | else |
| | | _inventoryInfoService.UpdateData(inventoryInfo); |
| | | #endregion |
| | | |
| | | #region ä»»å¡è®°å½ |
| | | Dt_SupplyTask supplyTask = new Dt_SupplyTask() |
| | | #region è´§ä½ |
| | | var location = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == LocationCode); |
| | | if (location == null) return WebResponseContent.Instance.Error($"请维æ¤è´§ä½ç¼å·ã{LocationCode}ãçè´§ä½ä¿¡æ¯"); |
| | | if (location.EnableStatus == EnableStatusEnum.Disable.ObjToInt()) |
| | | return WebResponseContent.Instance.Error($"è´§ä½ç¼å·ã{LocationCode}ãå·²ç¦ç¨ï¼è¯·æ¢å¤æ£å¸¸å使ç¨"); |
| | | Dt_InventoryInfo inventoryInfo1 = _inventoryInfoService.Repository.QueryFirst(x => x.LocationCode == LocationCode); |
| | | if (inventoryInfo1 == null) |
| | | { |
| | | WarehouseCode = cabinOrderDetail.Reservoirarea, |
| | | BatchNo = inventoryInfo.BatchNo, |
| | | MaterielName = inventoryInfo.MaterielName, |
| | | MaterielCode = inventoryInfo.MaterielCode, |
| | | MaterielSpec = inventoryInfo.MaterielSpec, |
| | | TaskType = TaskTypeEnum.OutInventory.ObjToInt(), |
| | | CreateDate = DateTime.Now, |
| | | Creater = App.User.UserName, |
| | | LocationCode = LocationCode, |
| | | OrderNo = cabinOrder.Out_no, |
| | | StockQuantity = inventoryInfo.StockQuantity, |
| | | SupplyQuantity = Inqty, |
| | | Remark = "çç¹" |
| | | }; |
| | | _supplyTaskService.AddData(supplyTask); |
| | | location.LocationStatus = LocationStatusEnum.Free.ObjToInt(); |
| | | _basicService.LocationInfoService.UpdateData(location); |
| | | } |
| | | #endregion |
| | | |
| | | _supplyTaskService.UpdateData(supplyTask); |
| | | |
| | | #region åºåæ¹æ¬¡ |
| | | Dt_Inventory_Batch inventory_Batch = _inventory_BatchServices.Repository.QueryFirst(x => x.BatchNo == inventoryInfo.BatchNo && x.MaterielCode == inventoryInfo.MaterielCode); |
| | | if (inventory_Batch != null) |
| | | { |
| | | inventory_Batch.SupplyQuantity += Inqty; |
| | | _inventory_BatchServices.UpdateData(inventory_Batch); |
| | | inventory_Batch.StockQuantity -= supplyTask.StockQuantity; |
| | | if (inventory_Batch.StockQuantity <= 0) |
| | | _inventory_BatchServices.DeleteData(inventory_Batch); |
| | | else |
| | | _inventory_BatchServices.UpdateData(inventory_Batch); |
| | | } |
| | | #endregion |
| | | |
| | | _unitOfWorkManage.CommitTran(); |
| | | #endregion |
| | | |
| | | content.OK(cabinOrderDetail.Order_Outqty.ToString()); |
| | | content.OK(); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | |
| | | } |
| | | return content; |
| | | } |
| | | public WebResponseContent FeedbackOut(SaveModel saveModel) |
| | | |
| | | |
| | | /// <summary> |
| | | /// å¹³åºäººå·¥æ£æåºåºå¤çï¼å³äººå·¥æ«ç åºåºæ¶è°ç¨ï¼ |
| | | /// </summary> |
| | | /// <param name="saveModel"></param> |
| | | /// <returns></returns> |
| | | public WebResponseContent MatPicking(SaveModel saveModel) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | |
| | | MaterielName = inventoryInfo.MaterielName, |
| | | MaterielCode = inventoryInfo.MaterielCode, |
| | | MaterielSpec = inventoryInfo.MaterielSpec, |
| | | TaskStatus = SupplyStatusEnum.OutFinish.ObjToInt(), |
| | | TaskType = TaskTypeEnum.OutPick.ObjToInt(), |
| | | CreateDate = DateTime.Now, |
| | | Creater = App.User.UserName, |