总检时,更新配件申请表中领料数量小于申请数量的配件到维修工单子表

This commit is contained in:
xiaofajia 2024-10-25 17:13:05 +08:00
parent d9af2bee73
commit eb5f52e67d

View File

@ -775,46 +775,51 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe
.setSql("now_repair_name = adviser_name")
.eq(DlRepairTickets::getId, respVO.getId())
);
// todo 这儿有点问题先搁置
/*
如果同一个配件申请了多次按理应该在工单中合在一起
但如果同一个配件在申请多次的情况下打的折扣不一样就不能合在一起
我怎么知道工单中的配件是那一次申请的
两个方案让工单的配件关联申请表或者让配件申请表记录打的折扣
*/
// // 先查满足条件的申请表
// ArrayList<String> status = new ArrayList<>();
// status.add("01"); // 待审核
// status.add("05"); // 已驳回
// // 查工单所有已通过的配件申请单
// List<DlTicketWares> list = ticketWaresService.list(new LambdaQueryWrapper<DlTicketWares>().and(item -> {
// item.eq(DlTicketWares::getTicketId, respVO.getId())
// .notIn(DlTicketWares::getStatus, status);
// }));
// // 查配件申请表的所有已领取数量小于申请数量的子表信息
// List<String> ids = list.stream().map(DlTicketWares::getId).collect(Collectors.toList());
// List<DlTwItem> twItems = twItemService.list(new LambdaQueryWrapper<DlTwItem>().and(item -> {
// item.in(DlTwItem::getTwId, ids)
// .apply("wares_already_count < wares_count");
// }));
// if (CollectionUtil.isNotEmpty(twItems)) {
// // 更新工单子表主要是把已领料的字段同步给工单配件的数量字段
// // 查询工单子表三个查询条件属于那个工单属于配件类型属于需要改变的即申请表的已领取数量小于申请数量的
// List<String> waresId = twItems.stream().map(DlTwItem::getWaresId).collect(Collectors.toList());
// List<DlRepairTitem> items = titemService.list(new LambdaQueryWrapper<DlRepairTitem>().and(item -> {
// item.eq(DlRepairTitem::getTicketId, respVO.getId())
// .eq(DlRepairTitem::getItemType, "02")
// .in(DlRepairTitem::getPartId, waresId);
// }));
// // 同一个配件可能申请过多次属于是一个工单配件可能是对应多个申请表配件
// items.stream().map(item -> {
// DlRepairTitem titem = new DlRepairTitem();
// titem.setId(item.getId());
// List<DlTwItem> wares = twItems.stream().filter(i -> i.getWaresId().equals(item.getPartId())).collect(Collectors.toList());
// int sum = wares.stream().mapToInt(DlTwItem::getWaresAlreadyCount).sum();
//
// })
// }
// 先查满足条件的申请表
ArrayList<String> status = new ArrayList<>();
status.add("01"); // 待审核
status.add("05"); // 已驳回
// 查工单所有已通过的配件申请单
List<DlTicketWares> list = ticketWaresService.list(new LambdaQueryWrapper<DlTicketWares>().and(item -> {
item.eq(DlTicketWares::getTicketId, respVO.getId())
.notIn(DlTicketWares::getStatus, status);
}));
// 查配件申请表的所有已领取数量小于申请数量的子表信息
List<String> ids = list.stream().map(DlTicketWares::getId).collect(Collectors.toList());
List<DlTwItem> twItems = twItemService.list(new LambdaQueryWrapper<DlTwItem>().and(item -> {
item.in(DlTwItem::getTwId, ids)
.apply("wares_already_count < wares_count");
}));
if (CollectionUtil.isNotEmpty(twItems)) {
// 更新工单子表主要是把已领料的字段同步给工单配件的数量字段
// 查询工单子表三个查询条件属于那个工单属于配件类型属于需要改变的即申请表的已领取数量小于申请数量的
Set<String> waresId = twItems.stream().map(DlTwItem::getWaresId).collect(Collectors.toSet());
List<DlRepairTitem> items = titemService.list(new LambdaQueryWrapper<DlRepairTitem>().and(item -> {
item.eq(DlRepairTitem::getTicketId, respVO.getId())
.eq(DlRepairTitem::getItemType, "02")
.in(DlRepairTitem::getPartId, waresId);
}));
// 同一个配件可能申请过多次属于是一个工单配件可能是对应多个申请表配件
List<DlRepairTitem> updateItems = items.stream().map(item -> {
DlRepairTitem titem = new DlRepairTitem();
titem.setId(item.getId());
List<DlTwItem> wares = twItems.stream().filter(i -> i.getWaresId().equals(item.getPartId())).collect(Collectors.toList());
int sum = wares.stream().mapToInt(DlTwItem::getWaresAlreadyCount).sum();
titem.setItemCount(sum);
BigDecimal discount = item.getItemDiscount() == null ? BigDecimal.ONE : item.getItemDiscount();
titem.setItemMoney(item.getItemPrice().multiply(BigDecimal.valueOf(sum)).multiply(discount));
return titem;
}).collect(Collectors.toList());
// 更新维修工单子表
titemService.updateBatchById(updateItems);
// 重新计算维修工单
boolean flag = computeTicket(respVO.getId());
if (!flag){
throw exception0(500, "系统异常");
}
}
// 通知服务顾问
DlRepairTickets tickets = baseMapper.selectById(respVO.getId());