|  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | 
|---|
|  |  |  | import com.vincent.rsf.framework.common.Cools; | 
|---|
|  |  |  | import com.vincent.rsf.framework.exception.CoolException; | 
|---|
|  |  |  | import com.vincent.rsf.server.api.entity.dto.ReceiptDetlsDto; | 
|---|
|  |  |  | import com.vincent.rsf.server.common.config.SysStockProperties; | 
|---|
|  |  |  | import com.vincent.rsf.server.common.utils.CommonUtil; | 
|---|
|  |  |  | import com.vincent.rsf.server.common.utils.DateUtils; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.controller.params.WarehouseAreaParam; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.entity.*; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.enums.AsnExceStatus; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.enums.PakinIOStatus; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.enums.WarehouseAreasType; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.enums.*; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.service.*; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.service.impl.WarehouseAreasItemServiceImpl; | 
|---|
|  |  |  | import com.vincent.rsf.server.system.constant.GlobalConfigCode; | 
|---|
|  |  |  | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Objects; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @author Ryan | 
|---|
|  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private SysStockProperties flowProperties; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WaitPakinService waitPakinService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WaitPakinItemService waitPakinItemService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WaitPakinLogService waitPakinLogService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WaitPakinItemLogService waitPakinItemLogService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ConfigService configService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WarehouseAreasService warehouseAreasService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WarehouseAreasItemServiceImpl warehouseAreasItemService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private CompanysService companysService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TransferService transferService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OutStockService outStockService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @author Ryan | 
|---|
|  |  |  | 
|---|
|  |  |  | * @description: 直接组托开关为true,将收货单直接加入临时库存 | 
|---|
|  |  |  | * @version 1.0 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | //    @Scheduled(cron = "0 0/05 * * * ?  ") | 
|---|
|  |  |  | @Scheduled(cron = "0/25 * * * * ?") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public synchronized void IgnoreReceipt() { | 
|---|
|  |  |  | 
|---|
|  |  |  | if (Objects.isNull(config)) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!Boolean.parseBoolean(config.getVal())) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<AsnOrder> orders = asnOrderService.list(new LambdaQueryWrapper<AsnOrder>().eq(AsnOrder::getExceStatus, AsnExceStatus.ASN_EXCE_STATUS_UN_EXCE.val)); | 
|---|
|  |  |  | //自动收货单 | 
|---|
|  |  |  | List<WkOrder> orders = asnOrderService.list(new LambdaQueryWrapper<WkOrder>() | 
|---|
|  |  |  | .eq(WkOrder::getType, OrderType.ORDER_IN.type) | 
|---|
|  |  |  | .eq(WkOrder::getExceStatus, AsnExceStatus.ASN_EXCE_STATUS_UN_EXCE.val)); | 
|---|
|  |  |  | if (!orders.isEmpty()) { | 
|---|
|  |  |  | for (AsnOrder order : orders) { | 
|---|
|  |  |  | List<AsnOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getAsnId, order.getId())); | 
|---|
|  |  |  | for (WkOrder order : orders) { | 
|---|
|  |  |  | if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_OTHER_TERANSFER.type)) { | 
|---|
|  |  |  | WkOrder one = outStockService.getOne(new LambdaQueryWrapper<WkOrder>() | 
|---|
|  |  |  | .eq(WkOrder::getPoId, order.getPoId()) | 
|---|
|  |  |  | .eq(WkOrder::getWkType, OrderWorkType.ORDER_WORK_TYPE_STOCK_TERANSFER.type)); | 
|---|
|  |  |  | if (Objects.isNull(one)) { | 
|---|
|  |  |  | throw new CoolException("数据错误"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!one.getExceStatus().equals(AsnExceStatus.OUT_STOCK_STATUS_TASK_DONE.val)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<WkOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, order.getId())); | 
|---|
|  |  |  | if (orderItems.isEmpty()) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<WarehouseAreasItem> items = new ArrayList<>(); | 
|---|
|  |  |  | for (AsnOrderItem item : orderItems) { | 
|---|
|  |  |  | for (WkOrderItem item : orderItems) { | 
|---|
|  |  |  | WarehouseAreas one = warehouseAreasService.getOne(new LambdaQueryWrapper<WarehouseAreas>() | 
|---|
|  |  |  | .eq(WarehouseAreas::getType, WarehouseAreasType.WAREHOUSE_AREAS_TYPE_RECEIPT.type), false); | 
|---|
|  |  |  | Long areaId = Objects.isNull(one) ? null : one.getId(); | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new CoolException("物料不存在!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //更新收货区库存 | 
|---|
|  |  |  | extracted(one, item, order, matnr); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | updateReceipt(one, item, order, matnr); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | throw new CoolException(e.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!asnOrderItemService.update(new LambdaUpdateWrapper<AsnOrderItem>().set(AsnOrderItem::getQty, item.getAnfme()).eq(AsnOrderItem::getId, item.getId()))) { | 
|---|
|  |  |  | if (!asnOrderItemService.update(new LambdaUpdateWrapper<WkOrderItem>().set(WkOrderItem::getQty, item.getAnfme()).eq(WkOrderItem::getId, item.getId()))) { | 
|---|
|  |  |  | throw new CoolException("收货单明细完成数量修改失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | //                    throw new CoolException("收货单保存至收货区执行失败!!"); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!asnOrderService.update(new LambdaUpdateWrapper<AsnOrder>() | 
|---|
|  |  |  | .set(AsnOrder::getQty, order.getQty()) | 
|---|
|  |  |  | .set(AsnOrder::getExceStatus, AsnExceStatus.ASN_EXCE_STATUS_RECEIPT_DONE.val) | 
|---|
|  |  |  | .eq(AsnOrder::getId, order.getId()))) { | 
|---|
|  |  |  | if (!asnOrderService.update(new LambdaUpdateWrapper<WkOrder>() | 
|---|
|  |  |  | .set(WkOrder::getQty, order.getAnfme()) | 
|---|
|  |  |  | .set(WkOrder::getExceStatus, AsnExceStatus.ASN_EXCE_STATUS_RECEIPT_DONE.val) | 
|---|
|  |  |  | .eq(WkOrder::getId, order.getId()))) { | 
|---|
|  |  |  | throw new CoolException("收货单状态修改失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | * @description: 收货区库存更新 | 
|---|
|  |  |  | * @version 1.0 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void extracted(WarehouseAreas areasItem, AsnOrderItem orderItem, AsnOrder asnOrder, Matnr matnr) { | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void updateReceipt(WarehouseAreas areasItem, WkOrderItem orderItem, WkOrder wkOrder, Matnr matnr) throws Exception { | 
|---|
|  |  |  | Companys companys = new Companys(); | 
|---|
|  |  |  | if (StringUtils.isNoneBlank(orderItem.getSplrCode())) { | 
|---|
|  |  |  | companys = companysService.getOne(new LambdaQueryWrapper<Companys>().eq(Companys::getCode, orderItem.getSplrCode())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WarehouseAreasItem item = new WarehouseAreasItem(); | 
|---|
|  |  |  | item.setTrackCode(orderItem.getBarcode()) | 
|---|
|  |  |  | .setAreaName(areasItem.getName()) | 
|---|
|  |  |  | .setAreaId(areasItem.getId()) | 
|---|
|  |  |  | .setAsnItemId(orderItem.getId()) | 
|---|
|  |  |  | .setAsnCode(asnOrder.getCode()) | 
|---|
|  |  |  | .setAsnId(asnOrder.getId()) | 
|---|
|  |  |  | .setAsnCode(wkOrder.getCode()) | 
|---|
|  |  |  | .setAsnId(wkOrder.getId()) | 
|---|
|  |  |  | .setProdTime(orderItem.getProdTime()) | 
|---|
|  |  |  | .setPlatItemId(orderItem.getPlatItemId()) | 
|---|
|  |  |  | .setPlatOrderCode(orderItem.getPlatOrderCode()) | 
|---|
|  |  |  | .setPlatWorkCode(orderItem.getPlatWorkCode()) | 
|---|
|  |  |  | .setProjectCode(orderItem.getProjectCode()) | 
|---|
|  |  |  | .setSplrId(companys.getId()) | 
|---|
|  |  |  | //库存单位为最小单位 | 
|---|
|  |  |  | .setUnit(orderItem.getStockUnit()) | 
|---|
|  |  |  | .setStockUnit(orderItem.getStockUnit()) | 
|---|
|  |  |  | 
|---|
|  |  |  | .setMatnrId(matnr.getId()) | 
|---|
|  |  |  | .setIsptResult(orderItem.getIsptResult()) | 
|---|
|  |  |  | .setMaktx(matnr.getName()) | 
|---|
|  |  |  | .setSplrBatch(orderItem.getSplrBatch()) | 
|---|
|  |  |  | .setWeight(matnr.getWeight()) | 
|---|
|  |  |  | .setFieldsIndex(orderItem.getFieldsIndex()) | 
|---|
|  |  |  | .setShipperId(matnr.getShipperId()); | 
|---|
|  |  |  | WarehouseAreasItem serviceOne = warehouseAreasItemService.getOne(new LambdaQueryWrapper<WarehouseAreasItem>() | 
|---|
|  |  |  | .eq(WarehouseAreasItem::getMatnrCode, item.getMatnrCode()) | 
|---|
|  |  |  | .eq(!Cools.isEmpty(item.getFieldsIndex()), WarehouseAreasItem::getFieldsIndex, item.getFieldsIndex()) | 
|---|
|  |  |  | .eq(WarehouseAreasItem::getAsnCode, item.getAsnCode()) | 
|---|
|  |  |  | .eq(!Cools.isEmpty(item.getIsptResult()), WarehouseAreasItem::getIsptResult, item.getIsptResult()) | 
|---|
|  |  |  | .eq(StringUtils.isNotBlank(item.getSplrBatch()), WarehouseAreasItem::getSplrBatch, item.getSplrBatch())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | LambdaQueryWrapper<WarehouseAreasItem> queryWrapper = new LambdaQueryWrapper<WarehouseAreasItem>() | 
|---|
|  |  |  | .eq(WarehouseAreasItem::getMatnrCode, orderItem.getMatnrCode()) | 
|---|
|  |  |  | .eq(!Cools.isEmpty(orderItem.getFieldsIndex()), WarehouseAreasItem::getFieldsIndex, orderItem.getFieldsIndex()) | 
|---|
|  |  |  | .eq(WarehouseAreasItem::getAsnCode, orderItem.getOrderCode()) | 
|---|
|  |  |  | .eq(StringUtils.isNotBlank(orderItem.getSplrBatch()), WarehouseAreasItem::getSplrBatch, orderItem.getSplrBatch()); | 
|---|
|  |  |  | if (Objects.isNull(orderItem.getIsptResult())) { | 
|---|
|  |  |  | queryWrapper.isNull(WarehouseAreasItem::getIsptResult); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | queryWrapper.eq(WarehouseAreasItem::getIsptResult, orderItem.getIsptResult()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WarehouseAreasItem serviceOne = warehouseAreasItemService.getOne(queryWrapper); | 
|---|
|  |  |  | if (!Objects.isNull(serviceOne)) { | 
|---|
|  |  |  | item.setId(serviceOne.getId()); | 
|---|
|  |  |  | item.setAnfme(item.getAnfme() + serviceOne.getAnfme()); | 
|---|
|  |  |  | Double anfme = Math.round((item.getAnfme() + serviceOne.getAnfme()) * 10000) / 10000.0; | 
|---|
|  |  |  | item.setAnfme(anfme); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //未质检 | 
|---|
|  |  |  | if (!warehouseAreasItemService.saveOrUpdate(item)) { | 
|---|
|  |  |  | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //获取未生成ASN单据 | 
|---|
|  |  |  | List<Purchase> purchases = purchaseService.list(new LambdaQueryWrapper<Purchase>().eq(Purchase::getStatus, 0)); | 
|---|
|  |  |  | List<Purchase> purchases = purchaseService.list(new LambdaQueryWrapper<Purchase>().eq(Purchase::getExceStatus, 0)); | 
|---|
|  |  |  | //PO单为空,直接跳出当前任务 | 
|---|
|  |  |  | if (purchases.isEmpty()) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | 
|---|
|  |  |  | if (items.isEmpty()) { | 
|---|
|  |  |  | throw new CoolException("子列表数据为空,请查询PO单是否正确录入!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | AsnOrder order = new AsnOrder(); | 
|---|
|  |  |  | WkOrder order = new WkOrder(); | 
|---|
|  |  |  | //根据编码规则生成ASN单号 | 
|---|
|  |  |  | String code = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_ASN_ORDER, purchase); | 
|---|
|  |  |  | order.setAnfme(purchase.getAnfme()) | 
|---|
|  |  |  | 
|---|
|  |  |  | if (!asnOrderService.save(order)) { | 
|---|
|  |  |  | throw new CoolException("ASN单据保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<AsnOrderItem> orderItems = new ArrayList<>(); | 
|---|
|  |  |  | List<WkOrderItem> orderItems = new ArrayList<>(); | 
|---|
|  |  |  | items.forEach(item -> { | 
|---|
|  |  |  | AsnOrderItem orderItem = new AsnOrderItem(); | 
|---|
|  |  |  | WkOrderItem orderItem = new WkOrderItem(); | 
|---|
|  |  |  | Matnr matnr = matnrService.getOne(new LambdaQueryWrapper<Matnr>().eq(Matnr::getCode, item.getMatnrCode())); | 
|---|
|  |  |  | if (Objects.isNull(matnr)) { | 
|---|
|  |  |  | throw new CoolException("数据错误:当前物料不存在!!"); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //                String barcode = code + matnr.getCode(); | 
|---|
|  |  |  | orderItem.setAnfme(item.getAnfme()) | 
|---|
|  |  |  | .setAsnId(order.getId()) | 
|---|
|  |  |  | .setOrderId(order.getId()) | 
|---|
|  |  |  | .setQty(item.getQty()) | 
|---|
|  |  |  | .setSplrName(item.getSplrName()) | 
|---|
|  |  |  | .setAsnCode(code) | 
|---|
|  |  |  | .setOrderCode(code) | 
|---|
|  |  |  | .setSplrCode(item.getSplrCode()) | 
|---|
|  |  |  | .setPoDetlId(item.getId()) | 
|---|
|  |  |  | .setPlatItemId(item.getPlatItemId()) | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //任务执行完成,修改已完成数量和PO单执行状态 | 
|---|
|  |  |  | purchase.setQty(purchase.getAnfme()).setStatus(1); | 
|---|
|  |  |  | purchase.setQty(purchase.getAnfme()) | 
|---|
|  |  |  | .setExceStatus(POExceStatus.PO_EXCE_STATUS_EXCE_ING.val); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!purchaseService.saveOrUpdate(purchase)) { | 
|---|
|  |  |  | throw new CoolException("PO单执行完成后,保存失败!!"); | 
|---|
|  |  |  | 
|---|
|  |  |  | @Scheduled(cron = "0 0/05 * * * ?  ") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void generateMatnrLabel() { | 
|---|
|  |  |  | List<AsnOrderItem> list = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>() | 
|---|
|  |  |  | .isNull(AsnOrderItem::getTrackCode) | 
|---|
|  |  |  | .select(AsnOrderItem::getId)); | 
|---|
|  |  |  | List<WkOrderItem> list = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>() | 
|---|
|  |  |  | .isNull(WkOrderItem::getTrackCode) | 
|---|
|  |  |  | .select(WkOrderItem::getId)); | 
|---|
|  |  |  | if (Objects.isNull(list) || list.isEmpty()) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<AsnOrderItem> items = new ArrayList<>(); | 
|---|
|  |  |  | List<WkOrderItem> items = new ArrayList<>(); | 
|---|
|  |  |  | list.forEach(item -> { | 
|---|
|  |  |  | String trackCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_LABEL_CODE, item); | 
|---|
|  |  |  | if (StringUtils.isBlank(trackCode)) { | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new CoolException("生成编码失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @param | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | * @author Ryan | 
|---|
|  |  |  | * @description 组拖历史档 | 
|---|
|  |  |  | * @time 2025/3/29 12:36 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Scheduled(cron = "0/25 * * * * ?") | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public void pakinLog() { | 
|---|
|  |  |  | List<WaitPakin> pakinIds = waitPakinService.list(new LambdaQueryWrapper<WaitPakin>() | 
|---|
|  |  |  | .eq(WaitPakin::getIoStatus, Short.valueOf(PakinIOStatus.PAKIN_IO_STATUS_TASK_DONE.val)) | 
|---|
|  |  |  | .select(WaitPakin::getId)); | 
|---|
|  |  |  | if (pakinIds.isEmpty()) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<Long> list = pakinIds.stream().map(WaitPakin::getId).collect(Collectors.toList()); | 
|---|
|  |  |  | List<WaitPakin> pakins = waitPakinService.list(new LambdaQueryWrapper<WaitPakin>().in(WaitPakin::getId, list)); | 
|---|
|  |  |  | if (pakins.isEmpty()) { | 
|---|
|  |  |  | throw new CoolException("组拖单为空!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<WaitPakinLog> pakinLogs = new ArrayList<>(); | 
|---|
|  |  |  | pakins.forEach(pakin -> { | 
|---|
|  |  |  | WaitPakinLog log = new WaitPakinLog(); | 
|---|
|  |  |  | BeanUtils.copyProperties(pakin, log); | 
|---|
|  |  |  | log.setPakinId(pakin.getId()).setIoStatus(Short.parseShort("2")); | 
|---|
|  |  |  | pakinLogs.add(log); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | if (!waitPakinLogService.saveBatch(pakinLogs)) { | 
|---|
|  |  |  | throw new CoolException("历史档保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<WaitPakinItemLog> itemLogs = new ArrayList<>(); | 
|---|
|  |  |  | List<WaitPakinItem> pakinItems = waitPakinItemService.list(new LambdaQueryWrapper<WaitPakinItem>().in(WaitPakinItem::getPakinId, list)); | 
|---|
|  |  |  | if (pakinItems.isEmpty()) { | 
|---|
|  |  |  | throw new CoolException("组拖明细为空!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | pakinItems.forEach(item -> { | 
|---|
|  |  |  | WaitPakinItemLog itemLog = new WaitPakinItemLog(); | 
|---|
|  |  |  | BeanUtils.copyProperties(item, itemLog); | 
|---|
|  |  |  | itemLog.setPakinItemId(item.getId()) | 
|---|
|  |  |  | .setPakinId(item.getPakinId()); | 
|---|
|  |  |  | itemLogs.add(itemLog); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!waitPakinItemLogService.saveBatch(itemLogs)) { | 
|---|
|  |  |  | throw new CoolException("历史明细档保存失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!waitPakinService.removeByIds(list)) { | 
|---|
|  |  |  | throw new CoolException("原单据删除失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!waitPakinItemService.remove(new LambdaQueryWrapper<WaitPakinItem>().in(WaitPakinItem::getPakinId, list))) { | 
|---|
|  |  |  | throw new CoolException("原单据明细删除失败!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|