| | |
| | | import com.vincent.rsf.server.api.service.PdaOutStockService; |
| | | import com.vincent.rsf.server.manager.entity.*; |
| | | import com.vincent.rsf.server.manager.enums.AsnExceStatus; |
| | | import com.vincent.rsf.server.manager.enums.TaskResouceType; |
| | | import com.vincent.rsf.server.manager.enums.TaskStsType; |
| | | import com.vincent.rsf.server.manager.enums.WaveExceStatus; |
| | | import com.vincent.rsf.server.manager.service.*; |
| | | import lombok.Synchronized; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | |
| | | } |
| | | List<Long> ids = waveOrderRelas.stream().map(WaveOrderRela::getOrderId).collect(Collectors.toList()); |
| | | ArrayList<AsnOrderItem> list = new ArrayList<>(); |
| | | List<AsnOrder> asnOrderList = asnOrderService.list(new LambdaQueryWrapper<AsnOrder>().in(AsnOrder::getId, ids)); |
| | | for (AsnOrder asnOrder : asnOrderList) { |
| | | List<WkOrder> wkOrderList = asnOrderService.list(new LambdaQueryWrapper<WkOrder>().in(WkOrder::getId, ids)); |
| | | for (WkOrder wkOrder : wkOrderList) { |
| | | AsnOrderItem orderItem = asnOrderItemService.getOne(new LambdaQueryWrapper<AsnOrderItem>() |
| | | .eq(AsnOrderItem::getAsnId, asnOrder.getId()) |
| | | .eq(AsnOrderItem::getAsnId, wkOrder.getId()) |
| | | .eq(AsnOrderItem::getMatnrCode, taskItem.getMatnrCode()) |
| | | .eq(AsnOrderItem::getSplrBatch, taskItem.getBatch()) |
| | | ); |
| | |
| | | if (num.compareTo(orderDemandQty) < 0){ |
| | | throw new CoolException("播种数量大于单据出库数量,请检查"); |
| | | } |
| | | AsnOrder asnOrder = asnOrderService.getById(orderItem.getAsnId()); |
| | | if (Cools.isEmpty(asnOrder)){ |
| | | WkOrder wkOrder = asnOrderService.getById(orderItem.getAsnId()); |
| | | if (Cools.isEmpty(wkOrder)){ |
| | | throw new CoolException("出库单主单未找到"); |
| | | } |
| | | asnOrder.setQty(new BigDecimal(asnOrder.getQty().toString()).add(orderDemandQty).doubleValue()); |
| | | if (!asnOrderService.updateById(asnOrder)){ |
| | | wkOrder.setQty(new BigDecimal(wkOrder.getQty().toString()).add(orderDemandQty).doubleValue()); |
| | | if (!asnOrderService.updateById(wkOrder)){ |
| | | throw new CoolException("出库单更新状态失败"); |
| | | } |
| | | orderItem.setQty(new BigDecimal(orderItem.getQty().toString()).add(orderDemandQty).doubleValue()); |
| | |
| | | //检查单据是否完成 |
| | | Boolean orderChecked = checkOrderComplete(orderItem); |
| | | if (orderChecked){ |
| | | asnOrder.setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_DONE.val); |
| | | if (!asnOrderService.updateById(asnOrder)){ |
| | | wkOrder.setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_DONE.val); |
| | | if (!asnOrderService.updateById(wkOrder)){ |
| | | throw new CoolException("出库单更新状态失败"); |
| | | } |
| | | } |
| | |
| | | |
| | | private Boolean checkWaveComplete(TaskItem taskItem) { |
| | | Wave wave = waveService.getById(taskItem.getSourceId()); |
| | | List<AsnOrder> asnOrderList = asnOrderService.list(new LambdaQueryWrapper<AsnOrder>().eq(AsnOrder::getWaveId, wave.getId())); |
| | | return asnOrderList.stream().allMatch(item -> new BigDecimal(item.getAnfme().toString()).equals(new BigDecimal(item.getQty().toString()))); |
| | | List<WkOrder> wkOrderList = asnOrderService.list(new LambdaQueryWrapper<WkOrder>().eq(WkOrder::getWaveId, wave.getId())); |
| | | return wkOrderList.stream().allMatch(item -> new BigDecimal(item.getAnfme().toString()).equals(new BigDecimal(item.getQty().toString()))); |
| | | } |
| | | |
| | | private Boolean checkOrderComplete(AsnOrderItem orderItem) { |