From f2833c7f3e01c997e94a66bd5dd9be738b5c6cc7 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期四, 26 六月 2025 13:31:08 +0800 Subject: [PATCH] 波次任务下发功能优化 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/WaveServiceImpl.java | 274 +++++++++++++++++++++++++++++++----------------------- 1 files changed, 157 insertions(+), 117 deletions(-) diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/WaveServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/WaveServiceImpl.java index cafe93e..96dcb4b 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/WaveServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/WaveServiceImpl.java @@ -1,19 +1,23 @@ package com.vincent.rsf.server.manager.service.impl; +import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; +import com.vincent.rsf.framework.common.Cools; import com.vincent.rsf.framework.common.R; import com.vincent.rsf.framework.exception.CoolException; -import com.vincent.rsf.server.manager.enums.TaskStsType; -import com.vincent.rsf.server.manager.enums.TaskType; +import com.vincent.rsf.server.common.constant.Constants; +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.WaveToLocParams; +import com.vincent.rsf.server.manager.enums.*; import com.vincent.rsf.server.manager.entity.*; -import com.vincent.rsf.server.manager.enums.AsnExceStatus; -import com.vincent.rsf.server.manager.enums.WaveExceStatus; import com.vincent.rsf.server.manager.mapper.WaveMapper; import com.vincent.rsf.server.manager.service.*; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.vincent.rsf.server.manager.utils.LocManageUtil; import com.vincent.rsf.server.manager.utils.OptimalAlgorithmUtil; import com.vincent.rsf.server.system.constant.SerialRuleCode; import com.vincent.rsf.server.system.utils.SerialRuleUtils; @@ -46,6 +50,12 @@ private LocItemService locItemService; @Autowired private LocService locService; + @Autowired + private OutStockService outStockService; + @Autowired + private WaveService waveService; + @Autowired + private WaveRuleServiceImpl waveRuleService; /** * @param @@ -58,37 +68,146 @@ @Override @Transactional(rollbackFor = Exception.class) public R publicTask(Map<String, Object> map, Long loginUserId) { - List<WaveItem> itemParams = (List<WaveItem>) map.get("waveItem"); + List<WaveItem> itemParams = JSONArray.parseArray(JSON.toJSONString(map.get("waveItem")), WaveItem.class); if (Objects.isNull(itemParams) || itemParams.isEmpty()) { throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒"); } - List<WaveItem> items = JSONArray.parseArray(JSONArray.toJSONString(itemParams), WaveItem.class); String waveId = map.get("wave").toString(); Wave waves = this.getById(Long.parseLong(waveId)); if (Objects.isNull(waves)) { throw new CoolException("娉㈡鏁版嵁涓嶅瓨鍦紒锛�"); } - List<WaveItem> waveItems = waveItemService.list(new LambdaQueryWrapper<WaveItem>().eq(WaveItem::getWaveId, waves.getId())); + List<WaveItem> waveItems = waveItemService.list(new LambdaQueryWrapper<WaveItem>() + .eq(WaveItem::getWaveId, waves.getId()) + .apply("anfme > work_qty")); if (waveItems.isEmpty()) { throw new CoolException("娉㈡鏄庣粏涓嶅瓨鍦紒锛�"); } /**鐢熸垚鍑哄簱浠诲姟*/ try { - generateOutTask(items, loginUserId, waves); + List<WaveToLocParams> params = new ArrayList<>(); + for (WaveItem item : waveItems) { + WaveToLocParams locParams = new WaveToLocParams(); + BeanUtils.copyProperties(item, locParams); + locParams.setBatch(item.getSplrBatch()) + .setItemId(item.getId()) + .setWaveId(item.getWaveId()); + params.add(locParams); + } + List<OrderOutItemDto> results = LocManageUtil.getOutOrderList(params, null); + generateOutTask(results, loginUserId, waves); } catch (Exception e) { log.error(e.getMessage()); throw new CoolException("鍑哄簱浠诲姟鐢熸垚澶辫触锛侊紒锛�"); } - //TODO 1. 鏍规嵁娉㈡鏄庣粏鐢熸垚鍑哄簱浠诲姟 - // 2. 鏍规嵁鐗╂枡SKU瀵绘壘绗﹀悎鐗╂枡搴撲綅 {1. 鏍规嵁鐗╂枡缂栫爜锛屾壒娆★紝鍔ㄦ�佸瓧娈� 鏌ヨ绗﹀悎鐨勫簱浣嶏紝鍐嶆牴鎹簱浣嶄腑鐗╂枡鐨勬暟閲忛�夋嫨鏈�閫傚悎鐨勫簱浣� 2. 鍒ゆ柇褰撳墠璁㈠崟鏄叏鎷栧嚭搴撹繕鏄嫞鏂欏叆搴搣 - // 3. 淇敼涓诲崟銆佹尝娆℃墽琛屾暟閲� - // 4. 鍒ゆ柇鍏ㄤ粨鍑哄簱鎴栨嫞鏂欏嚭搴� List<Long> orderIds = waveItems.stream().map(WaveItem::getOrderId).collect(Collectors.toList()); /**淇敼鍑哄簱鍗曠姸鎬�*/ if (!asnOrderService.update(new LambdaUpdateWrapper<AsnOrder>() .set(AsnOrder::getExceStatus, AsnExceStatus.OUT_STOCK_STATUS_TASK_WORKING.val) .in(AsnOrder::getId, orderIds))) { throw new CoolException("鍑哄簱鍗曟嵁鐘舵�佷慨鏀瑰け璐ワ紒锛�"); + } + return R.ok(); + } + + + /** + * 閫夋嫨娉㈡鏄庣粏涓嬪彂浠诲姟 + * + * @param map + * @param loginUserId + * @return + */ + @Override + @Transactional(rollbackFor = Exception.class) + public R waveToTask(Map<String, Object> map, Long loginUserId) { + if (Objects.isNull(map.get("waveItem"))) { + throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒"); + } + String waveId = map.get("wave").toString(); + Wave waves = this.getById(Long.parseLong(waveId)); + if (Objects.isNull(waves)) { + throw new CoolException("娉㈡鏁版嵁涓嶅瓨鍦紒锛�"); + } + List<Long> waveItems = JSONArray.parseArray(JSON.toJSONString(map.get("waveItem")), Long.class); + if (waveItems.isEmpty()) { + throw new CoolException("娉㈡鏄庣粏涓嶈兘涓虹┖锛侊紒"); + } + List<WaveItem> items = waveItemService.listByIds(waveItems); + if (items.isEmpty()) { + throw new CoolException("娉㈡鏄庣粏涓嶅瓨鍦紒锛�"); + } + + if (!waveItemService.update(new LambdaUpdateWrapper<WaveItem>() + .set(WaveItem::getExceStatus, WaveItemExceStatus.WAVE_EXCE_STATUS_ING.val) + .in(WaveItem::getId, waveItems))) { + throw new CoolException("鎵ц鐘舵�佷慨鏀瑰け璐ワ紒锛�"); + } + + WaveRule waveRule = waveRuleService.getOne(new LambdaQueryWrapper<WaveRule>() + .eq(WaveRule::getType, WaveRuleType.First_In_First_Out.type)); + if (Cools.isEmpty(waveRule)) { + throw new CoolException("鏈壘鍒板綋鍓嶇瓥鐣�"); + } + + List<WaveToLocParams> params = new ArrayList<>(); + for (WaveItem item : items) { + WaveToLocParams locParams = new WaveToLocParams(); + BeanUtils.copyProperties(item, locParams); + locParams.setBatch(item.getSplrBatch()) + .setItemId(item.getId()) + .setWaveId(item.getWaveId()); + params.add(locParams); + } + List<OrderOutItemDto> results = LocManageUtil.getOutOrderList(params, waveRule); + if (results.isEmpty()) { + waveService.update(new LambdaUpdateWrapper<Wave>() + .set(Wave::getExceStatus, WaveExceStatus.WAVE_EXCE_STATUS_EXCING.val) + .set(Wave::getUpdateBy, loginUserId) + .set(Wave::getUpdateTime, new Date()) + .eq(Wave::getId, waveId)); + return R.ok(); + } + /**鐢熸垚鍑哄簱浠诲姟*/ + try { + generateOutTask(results, loginUserId, waves); + } catch (Exception e) { + log.error("UNK", e); + throw new CoolException(e.getMessage()); + } + + List<TaskItem> taskItems = taskItemService.list(new LambdaQueryWrapper<TaskItem>() + .in(TaskItem::getSource, waveItems)); + if (Cools.isEmpty(taskItems)) { + throw new CoolException("鏆傛棤鍚堥�傚簱瀛樹俊鎭紒锛�"); + } + for (TaskItem item : taskItems) { + WaveItem waveItem = waveItemService.getById(item.getSource()); + + Double workQty = Math.round((waveItem.getWorkQty() + item.getAnfme()) * 10000) / 10000.0; + waveItem.setWorkQty(workQty); + if (workQty.compareTo(waveItem.getAnfme()) < 0) { + waveItem.setExceStatus(WaveItemExceStatus.WAVE_EXCE_STATUS_ING.val); + } else { + waveItem.setExceStatus(WaveItemExceStatus.WAVE_EXCE_STATUS_PUBD.val); + } + + if (!waveItemService.update(new LambdaUpdateWrapper<WaveItem>() + .set(WaveItem::getExceStatus, WaveItemExceStatus.WAVE_EXCE_STATUS_PUBD.val) + .setSql("work_qty = work_qty + " + item.getAnfme()) + .set(WaveItem::getUpdateBy, loginUserId) + .set(WaveItem::getUpdateTime, new Date()) + .eq(WaveItem::getId, item.getSource()))) { + throw new CoolException("涓嬪彂鎵ц寮傚父锛岃绋嶅�欓噸璇曪紒"); + } + } + if (!waveService.update(new LambdaUpdateWrapper<Wave>() + .set(Wave::getExceStatus, WaveExceStatus.WAVE_EXCE_STATUS_TASK.val) + .set(Wave::getWorkQty, taskItems.stream().mapToDouble(TaskItem::getAnfme).sum()) + .set(Wave::getUpdateBy, loginUserId) + .set(Wave::getUpdateTime, new Date()) + .eq(Wave::getId, waveId))) { + throw new CoolException("娉㈡鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } return R.ok(); } @@ -104,113 +223,20 @@ */ @Synchronized @Transactional(rollbackFor = Exception.class) - public void generateOutTask(List<WaveItem> itemParams, Long loginUserId, Wave wave) throws Exception { - List<LocItem> locItemList = new ArrayList<>(); - for (WaveItem param : itemParams) { - String locs = param.getStockLocs(); - List<LocItem> locItems = JSONArray.parseArray(locs, LocItem.class); - if (locItems.isEmpty()) { + public void generateOutTask(List<OrderOutItemDto> itemParams, Long loginUserId, Wave wave) throws Exception { + for (OrderOutItemDto itemDto : itemParams) { + LocToTaskParams taskParams = new LocToTaskParams(); + Loc loc = locService.getById(itemDto.getLocId()); + if (Objects.isNull(loc)) { continue; } - List<Long> list = locItems.stream().map(LocItem::getLocId).collect(Collectors.toList()); - /**鏍规嵁渚涘簲鍟嗘壒娆★紝鐗╂枡鐮侊紝 鍔ㄦ�佸瓧娈垫煡璇㈡寚瀹氱殑鐗╂枡搴撳瓨淇℃伅*/ - List<LocItem> items = locItemService.list(new LambdaQueryWrapper<LocItem>() - .eq(LocItem::getSplrBatch, param.getSplrBatch()) - .in(LocItem::getLocId, list) - .eq(StringUtils.isNotBlank(param.getFieldsIndex()), LocItem::getFieldsIndex, param.getFieldsIndex()) - .eq(LocItem::getMatnrCode, param.getMatnrCode())); - if (items.isEmpty()) { - throw new CoolException("搴撳瓨淇℃伅鏈夊彉锛岃鍙栨秷褰撳墠娉㈡锛岀敓鏂扮敓鎴愭柊鐨勬尝娆★紒锛�"); - } - /***灏嗘湁璐ф湁鐨勬槑缁嗕俊鎭瓨鏀惧埌搴撲綅淇℃伅涓�*/ - for (int i = 0; i < items.size(); i++) { - items.get(i) - .setSourceId(param.getWaveId()) - .setSourceCode(param.getWaveCode()) - .setSource(param.getId()); - } - locItemList.addAll(items); + taskParams.setItems(Arrays.asList(itemDto.getLocItem())) + .setSiteNo(itemDto.getSiteNo()) + .setType(Constants.TASK_TYPE_WAVE_OUT_STOCK) + .setSourceId(wave.getId()) + .setTarLoc(loc.getCode()); + locItemService.generateTask(TaskResouceType.TASK_RESOUCE_WAVE_TYPE.val, taskParams, loginUserId); } - if (locItemList.isEmpty()) { - throw new CoolException("娌℃湁鍚堥�傚簱浣嶏紒锛�"); - } - - /**鎷嗗垎娉㈡鏄庣粏搴撲綅闆嗭紝鍚堝苟鐩稿悓搴撲綅锛屽垎瑙d换鍔℃槑缁�*/ - Map<Long, List<LocItem>> listMap = locItemList.stream().collect(Collectors.groupingBy(LocItem::getLocId)); - /**鏍规嵁搴撲綅姹囨�讳俊鎭紝鐢熸垚浠诲姟鏄庣粏**/ - listMap.keySet().forEach(key -> { - List<LocItem> locItems = listMap.get(key); - LocItem item1 = locItems.stream().findFirst().get(); - WaveItem waveItem = waveItemService.getById(item1.getSource()); - if (null == waveItem || Objects.isNull(waveItem)) { - throw new CoolException("鏁版嵁閿欒锛氭尝娆℃槑缁嗕笉瀛樺湪锛侊紒"); - } - //TODO 褰撳墠浠诲姟瀹屾垚鍚庯紝閫氳繃瀹氭椂浜嬩欢鍒ゆ柇鏄叏鐩樺嚭搴擄紝杩樻槸鎷f枡鍐嶅叆搴� - Loc loc = locService.getById(key); - Task task = new Task(); - String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_TASK_CODE, null); - if (StringUtils.isBlank(ruleCode)) { - throw new CoolException("缂栫爜瑙勫垯閿欒锛氳妫�鏌ャ�孲YS_TASK_CODE銆嶆槸鍚﹁缃畬鎴愶紒锛�"); - } - if (Objects.isNull(loc)) { - throw new CoolException("搴撲綅涓嶅瓨鍦紒锛�"); - } - - List<TaskItem> items = taskItemService.list(new LambdaQueryWrapper<TaskItem>().in(TaskItem::getSourceId, wave.getId())); - if (items.isEmpty()) { - throw new CoolException("娉㈡浠诲姟宸茬敓鎴愶紝涓嶈兘閲嶅鐢熸垚锛侊紒"); - } - - task.setTaskCode(ruleCode) - .setTaskType(TaskType.TASK_TYPE_OUT.type) - .setTaskStatus(TaskStsType.GENERATE_OUT.id) - .setBarcode(loc.getBarcode()) - .setOrgLoc(loc.getCode()) - .setCreateBy(loginUserId) - .setUpdateBy(loginUserId) - .setTargSite(wave.getTargSite()); - - if (!taskService.save(task)) { - throw new CoolException("浠诲姟鐢熸垚澶辫触锛侊紒"); - } - List<TaskItem> taskItems = new ArrayList<>(); - /**鐢熸垚浠诲姟鏄庣粏淇℃伅*/ - for (LocItem item : locItems) { - TaskItem taskItem = new TaskItem(); - BeanUtils.copyProperties(item, taskItem); - taskItem.setTaskId(task.getId()) - .setAnfme(waveItem.getAnfme()) - .setId(null) - .setSourceCode(wave.getCode()) - .setSourceId(wave.getId()) - .setSource(item.getSource()); - taskItems.add(taskItem); - } - if (!taskItemService.saveBatch(taskItems)) { - throw new CoolException("浠诲姟鏄庣粏淇濆瓨澶辫触锛侊紒"); - } - - /**淇敼娉㈡鎵ц鏁伴噺*/ - taskItems.forEach(item -> { - boolean update = waveItemService.update(new LambdaUpdateWrapper<WaveItem>() - .eq(WaveItem::getId, item.getSource()) - .set(WaveItem::getWorkQty, item.getAnfme())); - if (!update) { - throw new CoolException("娉㈡鎵ц鏁伴噺淇敼澶辫触锛侊紒"); - } - }); - - List<WaveItem> waveItems = waveItemService.list(new LambdaQueryWrapper<WaveItem>().eq(WaveItem::getWaveId, wave.getId())); - double sum = waveItems.stream().mapToDouble(WaveItem::getWorkQty).sum(); - /**娉㈡涓诲崟淇℃伅淇敼*/ - if (!this.update(new LambdaUpdateWrapper<Wave>() - .eq(Wave::getId, wave.getId()) - .set(Wave::getWorkQty, sum) - .set(Wave::getExceStatus, WaveExceStatus.WAVE_EXCE_STATUS_TASK.val))) { - throw new CoolException("娉㈡涓诲崟淇℃伅淇敼澶辫触锛侊紒"); - } - - }); } /** @@ -242,6 +268,20 @@ /** * @param + * @return + * @author Ryan + * @description 鍙栨秷娉㈡ + * @time 2025/6/17 10:04 + */ + @Override + @Transactional(rollbackFor = Exception.class) + public R cancelWave(List<Long> ids) { + + return null; + } + + /** + * @param * @param waveItems * @return * @author Ryan @@ -249,7 +289,7 @@ * @time 2025/4/27 09:26 */ @Synchronized - private List<WaveItem> getLocs(List<WaveItem> waveItems) throws Exception { + private List<WaveItem> getLocs(List<WaveItem> waveItems) throws Exception { //TODO 鏍规嵁鐗╂枡缂栫爜锛屾壒娆★紝鍔ㄦ�佸瓧娈� 鏌ヨ绗﹀悎鐨勫簱浣嶏紝鍐嶆牴鎹簱浣嶄腑鐗╂枡鐨勬暟閲忛�夋嫨鏈�閫傚悎鐨勫簱浣� waveItems.forEach(waveItem -> { List<LocItem> locItems = locItemService.list(new QueryWrapper<LocItem>() -- Gitblit v1.9.1