调整出库任务单结构
This commit is contained in:
@@ -103,29 +103,41 @@ namespace WMS.Web.Domain.Services
|
||||
if (data_list.Count != 0)
|
||||
{
|
||||
//2.1提取出wms任务单明细信息
|
||||
foreach (var e in erp_list)
|
||||
foreach (var outStockTask in data_list)
|
||||
{
|
||||
//代表单据已经存在 那么就对单据进行修改
|
||||
var data = data_list.FirstOrDefault(f => f.Details.SelectMany(s => s.SourceBillNos).Contains(e.SourceBillNo));
|
||||
var detail = data.Details.FirstOrDefault(w => w.MaterialId == e.MaterialId);
|
||||
//存在就修改,没有就添加
|
||||
if (detail != null)
|
||||
var sourcNos = outStockTask.Details.SelectMany(s => s.ErpDetails).Select(s => s.SourceBillNo).ToList();
|
||||
var erps = erp_list.Where(w => sourcNos.Contains(w.SourceBillNo)).ToList();
|
||||
foreach (var erp in erps)
|
||||
{
|
||||
if (detail.AccruedQty_Dic.ContainsKey(e.SourceBillNo))
|
||||
detail.AccruedQty_Dic[e.SourceBillNo] = e.AccruedQty;
|
||||
var detail = outStockTask.Details.FirstOrDefault(w => w.MaterialId == erp.MaterialId);
|
||||
if (detail == null)
|
||||
{
|
||||
//添加一条物料明细
|
||||
detail = _mapper.Map<OutStockTaskDetails>(erp);
|
||||
var erpDetail = _mapper.Map<OutStockTaskErpDetails>(erp);
|
||||
detail.ErpDetails.Add(erpDetail);
|
||||
outStockTask.Details.Add(detail);
|
||||
}
|
||||
else
|
||||
detail.AccruedQty_Dic.Add(e.SourceBillNo, e.AccruedQty);
|
||||
//对集合里的应发做出累加
|
||||
detail.AccruedQty = detail.AccruedQty_Dic.Sum(s => s.Value);
|
||||
}
|
||||
else
|
||||
{
|
||||
var de = _mapper.Map<OutStockTaskDetails>(e);
|
||||
de.AccruedQty_Dic.Add(de.SourceBillNos.First(), de.AccruedQty);
|
||||
data.Details.Add(de);
|
||||
{
|
||||
//找到物料明细下面对应的来源单明细 然后修改
|
||||
var erpDetail = detail.ErpDetails.FirstOrDefault(f => f.SourceBillNo.Equals(erp.SourceBillNo));
|
||||
if (erpDetail == null)
|
||||
{
|
||||
erpDetail = _mapper.Map<OutStockTaskErpDetails>(erp);
|
||||
detail.ErpDetails.Add(erpDetail);
|
||||
outStockTask.Details.Add(detail);
|
||||
}
|
||||
else
|
||||
{
|
||||
erpDetail.AccruedQty = erp.AccruedQty;
|
||||
detail.AccruedQty = detail.ErpDetails.Sum(s => s.AccruedQty);
|
||||
}
|
||||
}
|
||||
//操作完后剔除
|
||||
erp_removeList.Add(erp);
|
||||
}
|
||||
|
||||
erp_removeList.Add(e);
|
||||
}
|
||||
//2.2.提交修改
|
||||
var isSuccess = await _outStockTaskRepositories.EditEntityList(data_list, isTransaction);
|
||||
@@ -150,9 +162,13 @@ namespace WMS.Web.Domain.Services
|
||||
//找到当前对应来源单据编号的集合数据
|
||||
var current_erp_details = erp_list.Where(x => x.SourceBillNo == item).ToList();
|
||||
//给到dto的实体明细中
|
||||
entity.Details = _mapper.Map<List<OutStockTaskDetails>>(current_erp_details);
|
||||
foreach (var de in entity.Details)
|
||||
de.AccruedQty_Dic.Add(de.SourceBillNos.First(), de.AccruedQty);
|
||||
foreach (var erp in current_erp_details)
|
||||
{
|
||||
var detail = _mapper.Map<OutStockTaskDetails>(erp);
|
||||
var erpDetail = _mapper.Map<OutStockTaskErpDetails>(erp);
|
||||
detail.ErpDetails.Add(erpDetail);
|
||||
entity.Details.Add(detail);
|
||||
}
|
||||
add_entitys.Add(entity);
|
||||
}
|
||||
//3.1提交新增
|
||||
@@ -294,15 +310,15 @@ namespace WMS.Web.Domain.Services
|
||||
foreach (var entity in taskList)
|
||||
{
|
||||
if (entity.Type == OutStockType.Sal)
|
||||
DeliveryNotice_Nos.AddRange(entity.Details.SelectMany(s => s.SourceBillNos));
|
||||
DeliveryNotice_Nos.AddRange(entity.Details.SelectMany(s => s.ErpDetails).Select(s=>s.SourceBillNo));
|
||||
else if (entity.Type == OutStockType.Stkdirecttransfers)
|
||||
TransferDirect_Nos.AddRange(entity.Details.SelectMany(s => s.SourceBillNos));
|
||||
TransferDirect_Nos.AddRange(entity.Details.SelectMany(s => s.ErpDetails).Select(s => s.SourceBillNo));
|
||||
else if (entity.Type == OutStockType.StktransferInst)
|
||||
TransferOut_Nos.AddRange(entity.Details.SelectMany(s => s.SourceBillNos));
|
||||
TransferOut_Nos.AddRange(entity.Details.SelectMany(s => s.ErpDetails).Select(s => s.SourceBillNo));
|
||||
else if (entity.Type == OutStockType.Assembled)
|
||||
AssembledApp_Nos.AddRange(entity.Details.SelectMany(s => s.SourceBillNos));
|
||||
AssembledApp_Nos.AddRange(entity.Details.SelectMany(s => s.ErpDetails).Select(s => s.SourceBillNo));
|
||||
else if (entity.Type == OutStockType.Miscellaneous)
|
||||
MisDeliveryOut_Nos.AddRange(entity.Details.SelectMany(s => s.SourceBillNos));
|
||||
MisDeliveryOut_Nos.AddRange(entity.Details.SelectMany(s => s.ErpDetails).Select(s => s.SourceBillNo));
|
||||
}
|
||||
|
||||
if (DeliveryNotice_Nos.Count() > 0)
|
||||
|
||||
Reference in New Issue
Block a user