优化该箱

This commit is contained in:
tongfei
2024-03-06 11:16:26 +08:00
parent 008640be06
commit 02acd059dd
4 changed files with 181 additions and 48 deletions

View File

@@ -184,6 +184,13 @@
<param name="qty"></param> <param name="qty"></param>
<returns></returns> <returns></returns>
</member> </member>
<member name="M:WMS.Web.Domain.Entitys.Box.BoxInventory(WMS.Web.Domain.Entitys.BoxInventory)">
<summary>
箱库存同步箱信息
</summary>
<param name="inventory"></param>
<returns></returns>
</member>
<member name="T:WMS.Web.Domain.Entitys.BoxDetails"> <member name="T:WMS.Web.Domain.Entitys.BoxDetails">
<summary> <summary>
老ops箱信息明细 老ops箱信息明细
@@ -4275,6 +4282,14 @@
箱服务信息 箱服务信息
</summary> </summary>
</member> </member>
<member name="M:WMS.Web.Domain.Services.BoxService.BoxInventorySync(System.Collections.Generic.List{WMS.Web.Domain.Entitys.BoxInventory},System.Boolean)">
<summary>
箱库存同步箱信息
</summary>
<param name="list"></param>
<param name="isTransaction"></param>
<returns></returns>
</member>
<member name="T:WMS.Web.Domain.Services.ChangeMoveBoxService"> <member name="T:WMS.Web.Domain.Services.ChangeMoveBoxService">
改箱 移箱服务 改箱 移箱服务
</member> </member>
@@ -4301,32 +4316,6 @@
<param name="loginInfo"></param> <param name="loginInfo"></param>
<returns></returns> <returns></returns>
</member> </member>
<member name="M:WMS.Web.Domain.Services.ChangeMoveBoxService.ChangeBox_BackRecord(WMS.Web.Domain.Entitys.BackRecord,WMS.Web.Core.Dto.Login.LoginInDto,System.Boolean)">
<summary>
出入库回退改箱
</summary>
<param name="backRecord"></param>
<param name="loginInfo"></param>
<param name="isTransaction"></param>
<returns></returns>
</member>
<member name="M:WMS.Web.Domain.Services.ChangeMoveBoxService.ChangeBox_InStock(WMS.Web.Domain.Entitys.InStock,WMS.Web.Core.Dto.Login.LoginInDto,System.Boolean)">
<summary>
非采购入库
</summary>
<param name="inStock"></param>
<param name="loginInfo"></param>
<param name="isTransaction"></param>
<returns></returns>
</member>
<member name="M:WMS.Web.Domain.Services.ChangeMoveBoxService.ChangeBox_OutStock(WMS.Web.Domain.Entitys.OutStock,System.Boolean)">
<summary>
出库
</summary>
<param name="outStock"></param>
<param name="isTransaction"></param>
<returns></returns>
</member>
<member name="M:WMS.Web.Domain.Services.ExportExcelService.Export``1(System.Collections.Generic.List{``0},System.String,System.Int32,System.Int32,WMS.Web.Domain.Values.FileDownLoadOrderType,Npoi.Mapper.Mapper,System.Nullable{System.Int32})"> <member name="M:WMS.Web.Domain.Services.ExportExcelService.Export``1(System.Collections.Generic.List{``0},System.String,System.Int32,System.Int32,WMS.Web.Domain.Values.FileDownLoadOrderType,Npoi.Mapper.Mapper,System.Nullable{System.Int32})">
<summary> <summary>
列表页导出 列表页导出

View File

@@ -138,10 +138,10 @@ namespace WMS.Web.Domain.Services
// return changeBoxSave_Result; // return changeBoxSave_Result;
//#endregion //#endregion
//改箱保存操作 ////改箱保存操作--弃用
var changeBoxSave_Result = await _changeMoveBoxService.ChangeBox_BackRecord(entity, loginInfo, isTransaction); //var changeBoxSave_Result = await _changeMoveBoxService.ChangeBox_BackRecord(entity, loginInfo, isTransaction);
if (!changeBoxSave_Result.IsSuccess) //if (!changeBoxSave_Result.IsSuccess)
return changeBoxSave_Result; // return changeBoxSave_Result;
//保存成功后:变更库存 //保存成功后:变更库存
var boxInventoryResult = await _boxInventoryService.GenerateBackBox(entity, isTransaction); var boxInventoryResult = await _boxInventoryService.GenerateBackBox(entity, isTransaction);

View File

@@ -8,6 +8,7 @@ using System.Text;
using System.Text.Json; using System.Text.Json;
using System.Threading.Tasks; using System.Threading.Tasks;
using WMS.Web.Core.Dto.Inventory; using WMS.Web.Core.Dto.Inventory;
using WMS.Web.Core.Help;
using WMS.Web.Core.Internal.Results; using WMS.Web.Core.Internal.Results;
using WMS.Web.Domain.Entitys; using WMS.Web.Domain.Entitys;
using WMS.Web.Domain.Infrastructure; using WMS.Web.Domain.Infrastructure;
@@ -28,14 +29,16 @@ namespace WMS.Web.Domain.Services
private readonly ISerialNumbersRepositories _serialNumbersRepositories; private readonly ISerialNumbersRepositories _serialNumbersRepositories;
private readonly IBoxInventoryRepositories _boxInventoryRepositories; private readonly IBoxInventoryRepositories _boxInventoryRepositories;
private readonly ILogger<BoxInventoryService> _logger; private readonly ILogger<BoxInventoryService> _logger;
private readonly IBoxService _boxService;
public BoxInventoryService(IMapper mapper, IBoxRepositories boxRepositories, ILogger<BoxInventoryService> logger, public BoxInventoryService(IMapper mapper, IBoxRepositories boxRepositories, ILogger<BoxInventoryService> logger,
IInventoryDetailsService inventoryDetailsService, IInventoryDetailsService inventoryDetailsService, IBoxService boxService,
IInventoryInOutDetailsService inventoryInOutDetailsService, IInventoryInOutDetailsService inventoryInOutDetailsService,
ISerialNumbersRepositories serialNumbersRepositories, ISerialNumbersRepositories serialNumbersRepositories,
IBoxInventoryRepositories boxInventoryRepositories) IBoxInventoryRepositories boxInventoryRepositories)
{ {
_mapper = mapper; _mapper = mapper;
_logger = logger; _logger = logger;
_boxService = boxService;
_boxRepositories = boxRepositories; _boxRepositories = boxRepositories;
_inventoryDetailsService = inventoryDetailsService; _inventoryDetailsService = inventoryDetailsService;
_serialNumbersRepositories = serialNumbersRepositories; _serialNumbersRepositories = serialNumbersRepositories;
@@ -587,6 +590,9 @@ namespace WMS.Web.Domain.Services
if (dtoDatas == null || dtoDatas.Count == 0) if (dtoDatas == null || dtoDatas.Count == 0)
return Result.ReFailure(ResultCodes.InventoryNoSourceError); return Result.ReFailure(ResultCodes.InventoryNoSourceError);
//这个实体给改箱的服务进行处理
var changeBox_inventoryList = new List<BoxInventory>();
var delete_ids = new List<int>(); var delete_ids = new List<int>();
var update_entitys = new List<BoxInventory>(); var update_entitys = new List<BoxInventory>();
var add_entitys = new List<BoxInventory>(); var add_entitys = new List<BoxInventory>();
@@ -633,10 +639,19 @@ namespace WMS.Web.Domain.Services
//4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改; //4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改;
var isAllNoInventory = sour_update_entity.Details.All(x => x.Qty == 0); var isAllNoInventory = sour_update_entity.Details.All(x => x.Qty == 0);
if (isAllNoInventory) if (isAllNoInventory)
{
//给改箱服务用按箱的话就要把明细里的数量修改为0
changeBox_inventoryList.Add(GenerateBoxInventory(sour_update_entity.Clone()));
delete_ids.Add(sour_update_entity.Id); delete_ids.Add(sour_update_entity.Id);
}
else else
{
//4.2添加要更新的箱库存实体 //4.2添加要更新的箱库存实体
update_entitys.Add(sour_update_entity); update_entitys.Add(sour_update_entity);
//给改箱服务用
changeBox_inventoryList.Add(sour_update_entity.Clone());
}
} }
#endregion #endregion
@@ -657,7 +672,7 @@ namespace WMS.Web.Domain.Services
//2.2.3.在变更目标箱的-仓库-仓位-组织 //2.2.3.在变更目标箱的-仓库-仓位-组织
tag_update_entity.StockCode = dto.StockCode; tag_update_entity.StockCode = dto.StockCode;
tag_update_entity.SubStockId = dto.SubStockId.Value; tag_update_entity.SubStockId = dto.SubStockId.Value;
tag_update_entity.OrgCode = dto.TargetBoxOrgCode; tag_update_entity.OrgCode = dto.TargetBoxOrgCode;
} }
tag_update_entity.Details = tagBox.Details; tag_update_entity.Details = tagBox.Details;
@@ -725,10 +740,18 @@ namespace WMS.Web.Domain.Services
//2.4箱库存:要修改的集合 //2.4箱库存:要修改的集合
update_entitys.Add(tag_update_entity); update_entitys.Add(tag_update_entity);
//给改箱服务用
changeBox_inventoryList.Add(tag_update_entity.Clone());
} }
#endregion #endregion
} }
//改箱
var changeBox_result = await _boxService.BoxInventorySync(changeBox_inventoryList, isTransaction);
if (!changeBox_result.IsSuccess)
return changeBox_result;
var isSuccess = true; var isSuccess = true;
//4.数据库更新操作:更新和添加 //4.数据库更新操作:更新和添加
if (add_entitys.Count != 0) if (add_entitys.Count != 0)
@@ -788,12 +811,15 @@ namespace WMS.Web.Domain.Services
/// <param name="boxs"></param> /// <param name="boxs"></param>
/// <param name="isTransaction"></param> /// <param name="isTransaction"></param>
/// <returns></returns> /// <returns></returns>
private async Task<Result> ExeMoveBox(List<BoxInventoryMoveGenerateDto> dtoDatas, List<BoxInventory> boxInventorys,bool isTransaction) private async Task<Result> ExeMoveBox(List<BoxInventoryMoveGenerateDto> dtoDatas, List<BoxInventory> boxInventorys, bool isTransaction)
{ {
//1.判断来源数据是否存在 //1.判断来源数据是否存在
if (dtoDatas == null || dtoDatas.Count == 0) if (dtoDatas == null || dtoDatas.Count == 0)
return Result.ReFailure(ResultCodes.InventoryNoSourceError); return Result.ReFailure(ResultCodes.InventoryNoSourceError);
//这个实体给改箱的服务进行处理
var changeBox_inventoryList = new List<BoxInventory>();
var delete_entitys = new List<BoxInventory>(); var delete_entitys = new List<BoxInventory>();
var add_entitys = new List<BoxInventory>(); var add_entitys = new List<BoxInventory>();
var InventoryDetailsGenerateDto = new List<InventoryDetailsGenerateDto>(); var InventoryDetailsGenerateDto = new List<InventoryDetailsGenerateDto>();
@@ -807,15 +833,18 @@ namespace WMS.Web.Domain.Services
//3.1上架的时候:箱一定是不存在于箱库存当中的,有则返回提示“已有箱库存,不需要再扫上架” //3.1上架的时候:箱一定是不存在于箱库存当中的,有则返回提示“已有箱库存,不需要再扫上架”
var ishave = boxInventorys.Where(x => x.BoxId == dto.BoxId).Any(); var ishave = boxInventorys.Where(x => x.BoxId == dto.BoxId).Any();
if (ishave) if (ishave)
return Result.ReFailure(ResultCodes.BoxInventoryHaveInventoryError); return Result.ReFailure(ResultCodes.BoxInventoryHaveInventoryError);
//3.2组装要新增的箱库存信息:箱和明细 //3.2组装要新增的箱库存信息:箱和明细
var addEntity = _mapper.Map<BoxInventory>(dto); var addEntity = _mapper.Map<BoxInventory>(dto);
addEntity.Details = _mapper.Map<List<BoxInventoryDetails>>(dto.Details); addEntity.Details = _mapper.Map<List<BoxInventoryDetails>>(dto.Details);
//3.4箱库存:要新增的集合 //3.4箱库存:要新增的集合
add_entitys.Add(addEntity); add_entitys.Add(addEntity);
//给改箱服务用
changeBox_inventoryList.Add(addEntity.Clone());
//4.1即时库存:组装入库 //4.1即时库存:组装入库
foreach (var item in dto.Details) foreach (var item in dto.Details)
{ {
@@ -845,6 +874,9 @@ namespace WMS.Web.Domain.Services
var box_inventory = boxInventorys.Where(x => x.BoxId == dto.BoxId).FirstOrDefault(); var box_inventory = boxInventorys.Where(x => x.BoxId == dto.BoxId).FirstOrDefault();
delete_entitys.Add(box_inventory); delete_entitys.Add(box_inventory);
//给改箱服务用按箱的话就要把明细里的数量修改为0
changeBox_inventoryList.Add(GenerateBoxInventory(box_inventory.Clone()));
//4.1即时库存:组装出库 //4.1即时库存:组装出库
foreach (var item in box_inventory.Details) foreach (var item in box_inventory.Details)
{ {
@@ -861,6 +893,12 @@ namespace WMS.Web.Domain.Services
} }
} }
} }
//改箱
var changeBox_result = await _boxService.BoxInventorySync(changeBox_inventoryList, isTransaction);
if (!changeBox_result.IsSuccess)
return changeBox_result;
var isSuccess = true; var isSuccess = true;
//4.数据库操作处理 //4.数据库操作处理
if (add_entitys.Count != 0) if (add_entitys.Count != 0)
@@ -920,6 +958,9 @@ namespace WMS.Web.Domain.Services
if (dtoDatas == null || dtoDatas.Count == 0) if (dtoDatas == null || dtoDatas.Count == 0)
return Result.ReFailure(ResultCodes.InventoryNoSourceError); return Result.ReFailure(ResultCodes.InventoryNoSourceError);
//这个实体给改箱的服务进行处理
var changeBox_inventoryList = new List<BoxInventory>();
var delete_ids = new List<int>(); var delete_ids = new List<int>();
var update_entitys = new List<BoxInventory>(); var update_entitys = new List<BoxInventory>();
var add_entitys = new List<BoxInventory>(); var add_entitys = new List<BoxInventory>();
@@ -971,6 +1012,9 @@ namespace WMS.Web.Domain.Services
#endregion #endregion
add_entitys.Add(addEntity); add_entitys.Add(addEntity);
//给改箱服务用
changeBox_inventoryList.Add(addEntity.Clone());
} }
else else
{ {
@@ -1014,22 +1058,25 @@ namespace WMS.Web.Domain.Services
update_entity.Details.ForEach(x => update_entity.Details.ForEach(x =>
{ {
var current_box_mat_serNums = dto.Details.Where(m => m.MaterialId == x.MaterialId).FirstOrDefault(); var current_box_mat_serNums = dto.Details.Where(m => m.MaterialId == x.MaterialId).FirstOrDefault();
if (current_box_mat_serNums != null && current_box_mat_serNums.MaterialId == x.MaterialId) if (current_box_mat_serNums != null && current_box_mat_serNums.MaterialId == x.MaterialId)
{ {
foreach (var serialitem in current_box_mat_serNums.SerialNumbers) foreach (var serialitem in current_box_mat_serNums.SerialNumbers)
{ {
var isHaveSerial= x.SerialNumbers.Where(sn => sn == serialitem).Any(); var isHaveSerial = x.SerialNumbers.Where(sn => sn == serialitem).Any();
if (!isHaveSerial) if (!isHaveSerial)
x.SerialNumbers.Add(serialitem); x.SerialNumbers.Add(serialitem);
} }
// x.SerialNumbers.AddRange(current_box_mat_serNums.SerialNumbers); // x.SerialNumbers.AddRange(current_box_mat_serNums.SerialNumbers);
} }
}); });
#endregion #endregion
update_entitys.Add(update_entity); update_entitys.Add(update_entity);
//给改箱服务用
changeBox_inventoryList.Add(update_entity.Clone());
} }
//4.1即时库存:组装入库 //4.1即时库存:组装入库
@@ -1092,13 +1139,28 @@ namespace WMS.Web.Domain.Services
//4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改; //4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改;
var isAllNoInventory = update_entity.Details.All(x => x.Qty == 0); var isAllNoInventory = update_entity.Details.All(x => x.Qty == 0);
if (isAllNoInventory) if (isAllNoInventory)
{
//给改箱服务用按箱的话就要把明细里的数量修改为0
changeBox_inventoryList.Add(GenerateBoxInventory(update_entity.Clone()));
delete_ids.Add(update_entity.Id); delete_ids.Add(update_entity.Id);
}
else else
{
//4.2添加要更新的箱库存实体 //4.2添加要更新的箱库存实体
update_entitys.Add(update_entity); update_entitys.Add(update_entity);
//给改箱服务用
changeBox_inventoryList.Add(update_entity.Clone());
}
} }
} }
//改箱
var changeBox_result = await _boxService.BoxInventorySync(changeBox_inventoryList, isTransaction);
if (!changeBox_result.IsSuccess)
return changeBox_result;
var isSuccess = true; var isSuccess = true;
//4.数据库更新操作:更新和添加 //4.数据库更新操作:更新和添加
if (add_entitys.Count != 0) if (add_entitys.Count != 0)
@@ -1161,6 +1223,9 @@ namespace WMS.Web.Domain.Services
if (dtoDatas == null || dtoDatas.Count == 0) if (dtoDatas == null || dtoDatas.Count == 0)
return Result.ReFailure(ResultCodes.InventoryNoSourceError); return Result.ReFailure(ResultCodes.InventoryNoSourceError);
//这个实体给改箱的服务进行处理
var changeBox_inventoryList = new List<BoxInventory>();
var delete_ids = new List<int>(); var delete_ids = new List<int>();
var update_entitys = new List<BoxInventory>(); var update_entitys = new List<BoxInventory>();
var InventoryDetailsGenerateDto = new List<InventoryDetailsGenerateDto>(); var InventoryDetailsGenerateDto = new List<InventoryDetailsGenerateDto>();
@@ -1219,6 +1284,9 @@ namespace WMS.Web.Domain.Services
//3.5要处理的修改集合 //3.5要处理的修改集合
update_entitys.Add(updateEntity); update_entitys.Add(updateEntity);
//给改箱服务用
changeBox_inventoryList.Add(updateEntity.Clone());
} }
//出库 //出库
else else
@@ -1262,13 +1330,27 @@ namespace WMS.Web.Domain.Services
//4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改; //4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改;
var isAllNoInventory = update_entity.Details.All(x => x.Qty == 0); var isAllNoInventory = update_entity.Details.All(x => x.Qty == 0);
if (isAllNoInventory) if (isAllNoInventory)
{
//给改箱服务用按箱的话就要把明细里的数量修改为0
changeBox_inventoryList.Add(GenerateBoxInventory(update_entity.Clone()));
delete_ids.Add(update_entity.Id); delete_ids.Add(update_entity.Id);
}
else else
{
//4.2添加要更新的箱库存实体 //4.2添加要更新的箱库存实体
update_entitys.Add(update_entity); update_entitys.Add(update_entity);
//给改箱服务用
changeBox_inventoryList.Add(update_entity.Clone());
}
} }
} }
//改箱
var changeBox_result = await _boxService.BoxInventorySync(changeBox_inventoryList, isTransaction);
if (!changeBox_result.IsSuccess)
return changeBox_result;
var isSuccess = true; var isSuccess = true;
//4.数据库更新操作:更新和添加 //4.数据库更新操作:更新和添加
if (update_entitys.Count != 0) if (update_entitys.Count != 0)
@@ -1331,18 +1413,21 @@ namespace WMS.Web.Domain.Services
var boxIds = out_SerialNumbers.GroupBy(x => x.BoxId).Select(x => x.Key).ToList(); var boxIds = out_SerialNumbers.GroupBy(x => x.BoxId).Select(x => x.Key).ToList();
var boxInventorys = await _boxInventoryRepositories.GetList(boxIds); var boxInventorys = await _boxInventoryRepositories.GetList(boxIds);
//这个实体给改箱的服务进行处理
var changeBox_inventoryList = new List<BoxInventory>();
var delete_ids1 = new List<int>(); var delete_ids1 = new List<int>();
var update_entitys1 = new List<BoxInventory>(); var update_entitys1 = new List<BoxInventory>();
var InventoryDetailsGenerateDto1 = new List<InventoryDetailsGenerateDto>(); var InventoryDetailsGenerateDto1 = new List<InventoryDetailsGenerateDto>();
foreach (var item in boxInventorys) foreach (var item in boxInventorys)
{ {
item.Details.ForEach(x => item.Details.ForEach(x =>
{ {
var current_sers_info = out_SerialNumbers.Where(o => o.BoxId == item.BoxId && o.MaterialId == x.MaterialId).ToList(); var current_sers_info = out_SerialNumbers.Where(o => o.BoxId == item.BoxId && o.MaterialId == x.MaterialId).ToList();
if (current_sers_info != null && current_sers_info.Count != 0) if (current_sers_info != null && current_sers_info.Count != 0)
{ {
x.Qty=x.Qty- current_sers_info.Count; x.Qty = x.Qty - current_sers_info.Count;
var crrent_sers = current_sers_info.Select(t => t.SerialNumber).ToList(); var crrent_sers = current_sers_info.Select(t => t.SerialNumber).ToList();
x.SerialNumbers.RemoveAll(r => crrent_sers.Contains(r)); x.SerialNumbers.RemoveAll(r => crrent_sers.Contains(r));
@@ -1362,12 +1447,26 @@ namespace WMS.Web.Domain.Services
//4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改; //4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改;
var isAllNoInventory = item.Details.All(x => x.Qty == 0); var isAllNoInventory = item.Details.All(x => x.Qty == 0);
if (isAllNoInventory) if (isAllNoInventory)
{
//给改箱服务用按箱的话就要把明细里的数量修改为0
changeBox_inventoryList.Add(GenerateBoxInventory(item.Clone()));
delete_ids1.Add(item.Id); delete_ids1.Add(item.Id);
}
else else
{
//4.2添加要更新的箱库存实体 //4.2添加要更新的箱库存实体
update_entitys1.Add(item); update_entitys1.Add(item);
//给改箱服务用
changeBox_inventoryList.Add(item.Clone());
}
} }
//改箱
var changeBox_result = await _boxService.BoxInventorySync(changeBox_inventoryList, isTransaction);
if (!changeBox_result.IsSuccess)
return changeBox_result;
var isSuccess = true; var isSuccess = true;
//4.数据库更新操作:更新和添加 //4.数据库更新操作:更新和添加
if (update_entitys1.Count != 0) if (update_entitys1.Count != 0)
@@ -1401,6 +1500,9 @@ namespace WMS.Web.Domain.Services
if (dtoDatas == null || dtoDatas.Count == 0) if (dtoDatas == null || dtoDatas.Count == 0)
return Result.ReFailure(ResultCodes.InventoryNoSourceError); return Result.ReFailure(ResultCodes.InventoryNoSourceError);
//这个实体给改箱的服务进行处理
var changeBox_inventoryList = new List<BoxInventory>();
var update_entitys = new List<BoxInventory>(); var update_entitys = new List<BoxInventory>();
var add_entitys = new List<BoxInventory>(); var add_entitys = new List<BoxInventory>();
var InventoryDetailsGenerateDto = new List<InventoryDetailsGenerateDto>(); var InventoryDetailsGenerateDto = new List<InventoryDetailsGenerateDto>();
@@ -1434,6 +1536,9 @@ namespace WMS.Web.Domain.Services
addEntity.Details = _mapper.Map<List<BoxInventoryDetails>>(dtoDets_merge); addEntity.Details = _mapper.Map<List<BoxInventoryDetails>>(dtoDets_merge);
add_entitys.Add(addEntity); add_entitys.Add(addEntity);
//给改箱服务用
changeBox_inventoryList.Add(addEntity.Clone());
//4.组装即时库存 //4.组装即时库存
foreach (var detItem in dto.Details) foreach (var detItem in dto.Details)
{ {
@@ -1470,6 +1575,9 @@ namespace WMS.Web.Domain.Services
addEntity.Details = _mapper.Map<List<BoxInventoryDetails>>(dtoDets_merge); addEntity.Details = _mapper.Map<List<BoxInventoryDetails>>(dtoDets_merge);
add_entitys.Add(addEntity); add_entitys.Add(addEntity);
//给改箱服务用
changeBox_inventoryList.Add(addEntity.Clone());
//3.3.遍历dto明细组装即时库存数据 //3.3.遍历dto明细组装即时库存数据
foreach (var dtoItem in dto.Details) foreach (var dtoItem in dto.Details)
{ {
@@ -1520,10 +1628,17 @@ namespace WMS.Web.Domain.Services
InventoryDetailsGenerateDto.Add(inventoryDet); InventoryDetailsGenerateDto.Add(inventoryDet);
} }
update_entitys.Add(update_entity); update_entitys.Add(update_entity);
//给改箱服务用
changeBox_inventoryList.Add(update_entity.Clone());
} }
} }
} }
//改箱
var changeBox_result = await _boxService.BoxInventorySync(changeBox_inventoryList, isTransaction);
if (!changeBox_result.IsSuccess)
return changeBox_result;
var isSuccess = true; var isSuccess = true;
//4.数据库更新操作:更新和添加 //4.数据库更新操作:更新和添加
if (add_entitys.Count != 0) if (add_entitys.Count != 0)
@@ -1583,6 +1698,10 @@ namespace WMS.Web.Domain.Services
if (dtoDatas == null || dtoDatas.Count == 0) if (dtoDatas == null || dtoDatas.Count == 0)
return Result.ReFailure(ResultCodes.InventoryNoSourceError); return Result.ReFailure(ResultCodes.InventoryNoSourceError);
//这个实体给改箱的服务进行处理
var changeBox_inventoryList = new List<BoxInventory>();
var delete_ids = new List<int>(); var delete_ids = new List<int>();
var update_entitys = new List<BoxInventory>(); var update_entitys = new List<BoxInventory>();
var InventoryDetailsGenerateDto = new List<InventoryDetailsGenerateDto>(); var InventoryDetailsGenerateDto = new List<InventoryDetailsGenerateDto>();
@@ -1601,6 +1720,9 @@ namespace WMS.Web.Domain.Services
//直接添加要删除的箱 //直接添加要删除的箱
delete_ids.Add(boxInventory.Id); delete_ids.Add(boxInventory.Id);
//给改箱服务用按箱的话就要把明细里的数量修改为0
changeBox_inventoryList.Add(GenerateBoxInventory(boxInventory.Clone()));
//4.组装即时库存 //4.组装即时库存
foreach (var detItem in dto.Details) foreach (var detItem in dto.Details)
{ {
@@ -1654,13 +1776,26 @@ namespace WMS.Web.Domain.Services
//4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改; //4.1判断要修改的箱库存对象是否所有的物料库存的数量都为0“是”则删除该箱库存,"否"则修改;
var isAllNoInventory = update_entity.Details.All(x => x.Qty == 0); var isAllNoInventory = update_entity.Details.All(x => x.Qty == 0);
if (isAllNoInventory) if (isAllNoInventory)
{
//给改箱服务用按箱的话就要把明细里的数量修改为0
changeBox_inventoryList.Add(GenerateBoxInventory(update_entity.Clone()));
delete_ids.Add(update_entity.Id); delete_ids.Add(update_entity.Id);
}
else else
{
//4.2添加要更新的箱库存实体 //4.2添加要更新的箱库存实体
update_entitys.Add(update_entity); update_entitys.Add(update_entity);
//给改箱服务用
changeBox_inventoryList.Add(update_entity.Clone());
}
} }
} }
//改箱
var changeBox_result= await _boxService.BoxInventorySync(changeBox_inventoryList, isTransaction);
if(!changeBox_result.IsSuccess)
return changeBox_result;
//4.数据库更新操作:更新和删除 //4.数据库更新操作:更新和删除
var isSuccess = true; var isSuccess = true;
@@ -1742,7 +1877,16 @@ namespace WMS.Web.Domain.Services
} }
} }
private BoxInventory GenerateBoxInventory(BoxInventory boxInventory)
{
// 使用 LINQ 将box里的明细全部设置为0
boxInventory.Details.Select(detail =>
{
detail.Qty = 0;
return detail;
}).ToList();
return boxInventory;
}
/// <summary> /// <summary>
/// 处理箱库存变更:出入库 /// 处理箱库存变更:出入库

View File

@@ -552,10 +552,10 @@ namespace WMS.Web.Domain.Services
// ganenrateChangeBoxs.Add(changeBox_tag); // ganenrateChangeBoxs.Add(changeBox_tag);
//} //}
//改箱保存操作 ////改箱保存操作--弃用
var changeBoxSave_Result = await _changeMoveBoxService.ChangeBox_InStock(entity, loginInfo, isTransaction); //var changeBoxSave_Result = await _changeMoveBoxService.ChangeBox_InStock(entity, loginInfo, isTransaction);
if (!changeBoxSave_Result.IsSuccess) //if (!changeBoxSave_Result.IsSuccess)
return changeBoxSave_Result; // return changeBoxSave_Result;
} }
//6.1序列号跟踪流程添加;备注:和上面的改箱操作后会记录序列号轨迹不冲突; //6.1序列号跟踪流程添加;备注:和上面的改箱操作后会记录序列号轨迹不冲突;