修改了重新计算工单的接口
This commit is contained in:
parent
9d15441ad6
commit
a63c015e53
@ -1582,70 +1582,68 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe
|
||||
@Override
|
||||
@DSTransactional
|
||||
public boolean computeTicket(String ticketId) {
|
||||
// 查子表
|
||||
List<DlRepairTitem> list = titemService.list(new LambdaQueryWrapper<DlRepairTitem>().eq(DlRepairTitem::getTicketId, ticketId));
|
||||
// 计算子表
|
||||
if (CollectionUtil.isEmpty(list)) {
|
||||
// 取主表
|
||||
DlRepairTickets tickets = baseMapper.selectById(ticketId);
|
||||
// 取子表
|
||||
List<DlRepairTitem> titems = titemService.list(new LambdaQueryWrapper<DlRepairTitem>().eq(DlRepairTitem::getTicketId, ticketId));
|
||||
if (CollectionUtil.isEmpty(titems)) {
|
||||
throw exception0(500, "没有项目、配件或其他");
|
||||
}
|
||||
List<DlRepairTitem> updateItems = list.stream().map(item -> {
|
||||
DlRepairTitem titem = new DlRepairTitem();
|
||||
titem.setId(item.getId());
|
||||
// 取出折扣
|
||||
BigDecimal discount = item.getItemDiscount() == null ? new BigDecimal("1") : item.getItemDiscount();
|
||||
// 计算子表
|
||||
Map<String, BigDecimal> titemsMap = titems.stream().collect(Collectors.toMap(
|
||||
DlRepairTitem::getId,
|
||||
item -> {
|
||||
BigDecimal discount = item.getItemDiscount() == null ? BigDecimal.ONE : item.getItemDiscount();
|
||||
BigDecimal itemPrice = item.getItemPrice() == null ? BigDecimal.ZERO : item.getItemPrice();
|
||||
titem.setItemMoney(itemPrice.multiply(BigDecimal.valueOf(item.getItemCount())).multiply(discount));
|
||||
return titem;
|
||||
}).collect(Collectors.toList());
|
||||
// 更新
|
||||
titemService.updateBatchById(updateItems);
|
||||
return itemPrice.multiply(BigDecimal.valueOf(item.getItemCount())).multiply(discount);
|
||||
}
|
||||
));
|
||||
titems.forEach(item -> {
|
||||
item.setItemMoney(titemsMap.get(item.getId()));
|
||||
});
|
||||
titemService.updateBatchById(titems);
|
||||
|
||||
// 计算主表
|
||||
// 查新的子表信息
|
||||
List<DlRepairTitem> newList = titemService.list(new LambdaQueryWrapper<DlRepairTitem>().eq(DlRepairTitem::getTicketId, ticketId));
|
||||
DlRepairTickets tickets = new DlRepairTickets();
|
||||
// 计算子项总数
|
||||
int count = newList.stream().mapToInt(DlRepairTitem::getItemCount).sum();
|
||||
tickets.setId(ticketId);
|
||||
tickets.setCount(count);
|
||||
// 分类计算各自的总价和最终工单总价
|
||||
Map<String, List<DlRepairTitem>> map = newList.stream().collect(Collectors.groupingBy(DlRepairTitem::getItemType));
|
||||
// 01项目,02,配件,03,其他
|
||||
tickets.setTotalPrice(BigDecimal.ZERO);
|
||||
map.forEach((k, v) -> {
|
||||
BigDecimal reduce = v.stream().map(DlRepairTitem::getItemMoney).reduce(BigDecimal.ZERO, BigDecimal::add);
|
||||
tickets.setTotalPrice(tickets.getTotalPrice().add(reduce));
|
||||
if (k.equals("01")) {
|
||||
tickets.setProjectPrice(reduce);
|
||||
} else if (k.equals("02")) {
|
||||
tickets.setPartPrice(reduce);
|
||||
} else if (k.equals("03")) {
|
||||
tickets.setOtherPrice(reduce);
|
||||
// 总数量
|
||||
tickets.setCount(titems.stream().mapToInt(DlRepairTitem::getItemCount).sum());
|
||||
// 各类总价
|
||||
Map<String, BigDecimal> typePrice = titems.stream()
|
||||
.collect(Collectors.groupingBy(DlRepairTitem::getItemType,
|
||||
Collectors.mapping(DlRepairTitem::getItemMoney,
|
||||
Collectors.reducing(BigDecimal.ZERO, BigDecimal::add))));
|
||||
BigDecimal itemTotalPrice = new BigDecimal("0");
|
||||
for (Map.Entry<String, BigDecimal> entry : typePrice.entrySet()) {
|
||||
itemTotalPrice = itemTotalPrice.add(entry.getValue());
|
||||
switch (entry.getKey()){
|
||||
case "01":
|
||||
tickets.setProjectPrice(entry.getValue());
|
||||
break;
|
||||
case "02":
|
||||
tickets.setPartPrice(entry.getValue());
|
||||
break;
|
||||
case "03":
|
||||
tickets.setOtherPrice(entry.getValue());
|
||||
break;
|
||||
}
|
||||
});
|
||||
|
||||
// 工单总价还需要变,把其他新加的费用也需要算上
|
||||
// 查主表
|
||||
DlRepairTickets oldTicket = baseMapper.selectById(ticketId);
|
||||
}
|
||||
// 其他费用
|
||||
// 管理费
|
||||
BigDecimal managerMoney = ObjectUtil.isNotEmpty(oldTicket.getManagerMoney()) ? oldTicket.getManagerMoney() : new BigDecimal("0");
|
||||
BigDecimal managerMoney = ObjectUtil.isNotEmpty(tickets.getManagerMoney()) ? tickets.getManagerMoney() : new BigDecimal("0");
|
||||
// 救援费
|
||||
BigDecimal rescueMoney = ObjectUtil.isNotEmpty(oldTicket.getRescueMoney()) ? oldTicket.getRescueMoney() : new BigDecimal("0");
|
||||
BigDecimal rescueMoney = ObjectUtil.isNotEmpty(tickets.getRescueMoney()) ? tickets.getRescueMoney() : new BigDecimal("0");
|
||||
// 三包费
|
||||
BigDecimal threePackMoney = ObjectUtil.isNotEmpty(oldTicket.getThreePackMoney()) ? oldTicket.getThreePackMoney() : new BigDecimal("0");
|
||||
BigDecimal threePackMoney = ObjectUtil.isNotEmpty(tickets.getThreePackMoney()) ? tickets.getThreePackMoney() : new BigDecimal("0");
|
||||
// 定损费
|
||||
BigDecimal confirmFaultMoney = ObjectUtil.isNotEmpty(oldTicket.getConfirmFaultMoney()) ? oldTicket.getConfirmFaultMoney() : new BigDecimal("0");
|
||||
BigDecimal confirmFaultMoney = ObjectUtil.isNotEmpty(tickets.getConfirmFaultMoney()) ? tickets.getConfirmFaultMoney() : new BigDecimal("0");
|
||||
|
||||
tickets.setTotalPrice(tickets.getTotalPrice().add(managerMoney).add(rescueMoney).add(threePackMoney).add(confirmFaultMoney));
|
||||
tickets.setTotalPrice(itemTotalPrice.add(managerMoney).add(rescueMoney).add(threePackMoney).add(confirmFaultMoney));
|
||||
baseMapper.updateById(tickets);
|
||||
|
||||
// 因为订单是在工单创建的时候就新增了,后面加的配件之类的金额没有同步到订单,这里同步一下
|
||||
// 更新订单
|
||||
RepairOrderInfo orderInfo = repairOrderInfoService.getOne(new LambdaQueryWrapper<RepairOrderInfo>().eq(RepairOrderInfo::getGoodsId, ticketId));
|
||||
RepairOrderInfo newOrderInfo = new RepairOrderInfo();
|
||||
newOrderInfo.setId(orderInfo.getId());
|
||||
// 更新商品原价和实付金额
|
||||
newOrderInfo.setGoodsPrice(tickets.getTotalPrice());
|
||||
newOrderInfo.setPayMoney(tickets.getTotalPrice());
|
||||
repairOrderInfoService.updateById(newOrderInfo);
|
||||
orderInfo.setGoodsPrice(tickets.getTotalPrice());
|
||||
orderInfo.setPayMoney(tickets.getTotalPrice());
|
||||
repairOrderInfoService.updateById(orderInfo);
|
||||
|
||||
return baseMapper.updateById(tickets) > 0;
|
||||
}
|
||||
@ -1829,9 +1827,9 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe
|
||||
/**
|
||||
* 根据工单ID查客户和车辆信息
|
||||
*
|
||||
* @param id id
|
||||
* @author 小李
|
||||
* @date 19:07 2024/11/18
|
||||
* @param id id
|
||||
**/
|
||||
@Override
|
||||
public CustomerAndCarVO getCusAndCarById(String id) {
|
||||
|
Loading…
Reference in New Issue
Block a user