From d7bb8c43b17253b46c6a466cff5545e8b4bcaad3 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期二, 10 六月 2025 11:10:46 +0800 Subject: [PATCH] Merge branch 'devlop' of http://47.97.1.152:5880/r/wms-master into devlop --- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java | 78 ++++++++++++++++++++++++++++++++++----- 1 files changed, 68 insertions(+), 10 deletions(-) diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java index a1fb137..b494ac5 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java @@ -8,9 +8,12 @@ import com.vincent.rsf.framework.common.R; import com.vincent.rsf.framework.exception.CoolException; import com.vincent.rsf.server.api.utils.LocUtils; +import com.vincent.rsf.server.common.constant.Constants; import com.vincent.rsf.server.manager.controller.dto.ExistDto; import com.vincent.rsf.server.manager.controller.dto.OrderOutItemDto; +import com.vincent.rsf.server.manager.controller.params.LocToTaskParams; import com.vincent.rsf.server.manager.controller.params.OrderOutTaskParam; +import com.vincent.rsf.server.manager.controller.params.OutStockToTaskParams; import com.vincent.rsf.server.manager.enums.*; import com.vincent.rsf.server.manager.controller.params.AsnOrderAndItemsParams; import com.vincent.rsf.server.manager.entity.*; @@ -20,6 +23,8 @@ import com.vincent.rsf.server.system.constant.SerialRuleCode; import com.vincent.rsf.server.system.utils.SerialRuleUtils; import org.apache.commons.lang3.StringUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -28,6 +33,7 @@ import java.math.BigDecimal; import java.util.*; import java.util.stream.Collectors; + import com.vincent.rsf.server.manager.enums.WaveRuleType; /** @@ -39,6 +45,9 @@ */ @Service("outStockServiceImpl") public class OutStockServiceImpl extends ServiceImpl<AsnOrderMapper, AsnOrder> implements OutStockService { + + public Logger logger = LoggerFactory.getLogger(this.getClass()); + @Autowired private AsnOrderItemService asnOrderItemService; @@ -368,6 +377,7 @@ } return R.ok(); } + /** * @param * @return @@ -400,14 +410,14 @@ @Override public R getOrderOutTaskItem(OrderOutTaskParam param) { - if (Cools.isEmpty(param.getWaveId())){ + if (Cools.isEmpty(param.getWaveId())) { throw new CoolException("绛栫暐鍙傛暟涓虹┖"); } - if (Cools.isEmpty(param.getOrderId())){ + if (Cools.isEmpty(param.getOrderId())) { throw new CoolException("鍗曟嵁id涓虹┖"); } WaveRule waveRule = waveRuleService.getOne(new LambdaQueryWrapper<WaveRule>().eq(WaveRule::getId, param.getWaveId())); - if (Cools.isEmpty(waveRule)){ + if (Cools.isEmpty(waveRule)) { throw new CoolException("鏈壘鍒板綋鍓嶇瓥鐣�"); } List<OrderOutItemDto> locItems = null; @@ -415,7 +425,54 @@ return R.ok(locItems); } - private List<LocItem> getEfficiencyFirstItemList(AsnOrderItem asnOrderItem){ + /** + * 鐢熸垚鍑哄簱浠诲姟 + * + * @param params + * @return + */ + @Override + @Transactional(rollbackFor = Exception.class) + public R genOutStockTask(List<OutStockToTaskParams> params, Long loginUserId) { + if (params.isEmpty()) { + throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒"); + } + + //浼樺厛鐢熸垚娴呭簱浣嶄换鍔� + List<OutStockToTaskParams> Items = params.stream().sorted(Comparator.comparing(OutStockToTaskParams::getLocCode).thenComparing(item -> { + return LocUtils.isShallowLoc(item.getLocCode()) ? 1 : 0; + }).reversed()).collect(Collectors.toList()); + + for (OutStockToTaskParams param : Items) { + if (Objects.isNull(param)) { + continue; + } + Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getBarcode, param.getBarcode())); + if (!Objects.isNull(loc)) { + List<LocItem> locItems = new ArrayList<>(); + LocItem locItem = locItemService.getById(param.getId()); + locItem.setOutQty(param.getOutQty()).setBatch(param.getBatch()); + locItems.add(locItem); + + LocToTaskParams taskParams = new LocToTaskParams(); + taskParams.setType(Constants.TASK_TYPE_OUT_STOCK) + .setOrgLoc(loc.getCode()) + .setItems(locItems) + .setSiteNo(param.getSiteNo()); + try { + locItemService.generateTask(taskParams, loginUserId); + } catch (Exception e) { + logger.error("UNK", e); + throw new CoolException(e.getMessage()); + } + } + } + + return R.ok(); + } + + + private List<LocItem> getEfficiencyFirstItemList(AsnOrderItem asnOrderItem) { LambdaQueryWrapper<LocItem> locItemQueryWrapper = new LambdaQueryWrapper<>(); locItemQueryWrapper.eq(LocItem::getMatnrCode, asnOrderItem.getMatnrCode()); locItemQueryWrapper.eq(LocItem::getBatch, asnOrderItem.getSplrBatch()); @@ -434,7 +491,7 @@ return locItems; } - private List<LocItem> getFirstInFirstOutItemList(AsnOrderItem asnOrderItem){ + private List<LocItem> getFirstInFirstOutItemList(AsnOrderItem asnOrderItem) { LambdaQueryWrapper<LocItem> locItemQueryWrapper = new LambdaQueryWrapper<>(); locItemQueryWrapper.eq(LocItem::getMatnrCode, asnOrderItem.getMatnrCode()); locItemQueryWrapper.eq(LocItem::getBatch, asnOrderItem.getSplrBatch()); @@ -451,7 +508,7 @@ return locItems; } - private List<OrderOutItemDto> getOutOrderList(Long orderId,WaveRule waveRule){ + private List<OrderOutItemDto> getOutOrderList(Long orderId, WaveRule waveRule) { List<AsnOrderItem> asnOrderItems = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>() .eq(AsnOrderItem::getAsnId, orderId) ); @@ -470,16 +527,17 @@ locItems = getEfficiencyFirstItemList(asnOrderItem); } else if (WaveRuleType.First_In_First_Out.type.equals(waveRule.getType())) { locItems = getFirstInFirstOutItemList(asnOrderItem); - }else { + } else { locItems = getFirstInFirstOutItemList(asnOrderItem); } for (LocItem locItem : locItems) { Loc loc = locService.getById(locItem.getLocId()); List<LocItem> itemList = locItemService.list(new LambdaQueryWrapper<LocItem>().eq(LocItem::getLocCode, locItem.getLocCode())); - if (issued.doubleValue() > 0){ + if (issued.doubleValue() > 0) { ExistDto existDto = new ExistDto().setBatch(locItem.getBatch()).setMatnr(locItem.getMatnrCode()).setLocNo(locItem.getLocCode()); - if (existDtos.add(existDto)){ - locItem.setWorkQty(issued.doubleValue() >= locItem.getAnfme() ? locItem.getAnfme() : issued.doubleValue()); + if (existDtos.add(existDto)) { + locItem.setOutQty(issued.doubleValue() >= locItem.getAnfme() ? locItem.getAnfme() : issued.doubleValue()); + locItem.setBarcode(loc.getBarcode()); OrderOutItemDto orderOutItemDto = new OrderOutItemDto(); orderOutItemDto.setLocItem(locItem); -- Gitblit v1.9.1