From a488088a18a9b8808bc57124681cee8c4ada7299 Mon Sep 17 00:00:00 2001
From: chen.lin <1442464845@qq.com>
Date: 星期二, 10 三月 2026 17:23:03 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/devlop-phyz' into devlop-phyz

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java |  365 ++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 328 insertions(+), 37 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 9b829a1..60635d3 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
@@ -6,10 +6,12 @@
 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.api.controller.erp.params.SyncOrderParams;
 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.dto.OrderOutItemPdaDto;
 import com.vincent.rsf.server.manager.controller.params.*;
 import com.vincent.rsf.server.manager.enums.*;
 import com.vincent.rsf.server.manager.entity.*;
@@ -155,9 +157,7 @@
         if (!this.remove(new LambdaQueryWrapper<WkOrder>().eq(WkOrder::getId, id))) {
             throw new CoolException("涓诲崟鍒犻櫎澶辫触锛侊紒");
         }
-        if (!outStockItemService.remove(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, id))) {
-            throw new CoolException("鍗曟嵁鏄庣粏鍒犻櫎澶辫触锛侊紒");
-        }
+        outStockItemService.remove(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, id));
         return R.ok("鎿嶄綔鎴愬姛");
     }
 
@@ -265,6 +265,107 @@
             }
         });
         return R.ok();
+    }
+
+    /**
+     * @param
+     * @return
+     * @author Ryan
+     * @description 鐢熸垚娉㈡
+     * @time 2025/4/24 15:04
+     */
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public R generateWavesOrderAuto(GenWaveParams params,String stationId,String locCode) {
+        if (Objects.isNull(params.getIds()) || params.getIds().isEmpty()) {
+            throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒");
+        }
+        List<WkOrder> orders = this.list(new LambdaQueryWrapper<WkOrder>()
+                .eq(WkOrder::getExceStatus, AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val)
+                .in(WkOrder::getId, params.getIds()));
+        if (orders.isEmpty()) {
+            throw new CoolException("褰撳墠鍗曟嵁鐘舵�佷笉鑳芥墽琛屾尝娆$敓鎴愭搷浣滐紒锛�");
+        }
+        Double sum = orders.stream().mapToDouble(WkOrder::getAnfme).sum();
+        Double workQty = orders.stream().mapToDouble(WkOrder::getWorkQty).sum();
+        Double anfme = Math.round((sum - workQty) * 10000) / 10000.0;
+        Wave wave = new Wave();
+        String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_WAVE_TYPE, null);
+        if (StringUtils.isBlank(ruleCode)) {
+            throw new CoolException("缂栫爜瑙勫垯閿欒锛氳瑕佹煡鐪嬨�孲YS_WAVE_TYPE銆嶆槸鍚﹁缃垚鍔燂紒锛�");
+        }
+        wave.setOrderNum(params.getIds().size())
+                .setType(Short.parseShort("1"))
+                .setCode(ruleCode)
+                .setExceStatus(WaveExceStatus.WAVE_EXCE_STATUS_INIT.val)
+                .setAnfme(anfme);
+        if (!waveService.save(wave)) {
+            throw new CoolException("娉㈡淇濆瓨澶辫触锛侊紒");
+        }
+
+        List<Long> list = orders.stream().map(WkOrder::getId).collect(Collectors.toList());
+        List<WkOrderItem> orderItems = asnOrderItemService
+                .list(new LambdaQueryWrapper<WkOrderItem>()
+                        .in(WkOrderItem::getOrderId, list).apply("anfme > work_qty"));
+        if (orderItems.isEmpty()) {
+            throw new CoolException("鍗曟嵁涓嶅瓨鍦紒锛�");
+        }
+
+        //鍚堝苟鐗╂枡锛岀敓鎴愭尝娆℃槑缁�
+        List<WaveItem> waveItems = mergeWave(orderItems, wave);
+
+        if (!waveItemService.saveBatch(waveItems)) {
+            throw new CoolException("娉㈡鏄庣粏淇濆瓨澶辫触锛侊紒");
+        }
+        double sum1 = waveItems.stream().mapToDouble(WaveItem::getAnfme).sum();
+        wave.setAnfme(sum1).setGroupQty(waveItems.size());
+        wave.setStationId(stationId);
+        wave.setLocCode(locCode);
+        if (!waveService.saveOrUpdate(wave)) {
+            throw new CoolException("涓诲崟淇敼澶辫触锛侊紒");
+        }
+        for (int i = 0; i < orderItems.size(); i++) {
+            orderItems.get(i).setWorkQty(orderItems.get(i).getAnfme());
+        }
+
+        /**
+         *璁㈠崟淇℃伅瀛樺偍鑷抽�昏緫鍏宠仈琛�
+         */
+        for (WaveItem item : waveItems) {
+            List<WkOrderItem> items = orderItems.stream()
+                    .filter(orderItem -> item.getMatnrId()
+                            .equals(orderItem.getMatnrId()))
+                    .collect(Collectors.toList());
+
+            items.forEach(orderItem -> {
+                WaveOrderRela orderRela = new WaveOrderRela();
+                orderRela.setId(null)
+                        .setOrderId(orderItem.getOrderId())
+                        .setOrderItemId(orderItem.getId())
+                        .setWaveId(wave.getId())
+                        .setWaveItemId(item.getId());
+                if (!waveOrderRelaService.saveOrUpdate(orderRela)) {
+                    throw new CoolException("<UNK>");
+                }
+            });
+        }
+
+
+        if (!asnOrderItemService.saveOrUpdateBatch(orderItems)) {
+            throw new CoolException("鍑哄簱鍗曟墽琛屾暟閲忎慨鏀瑰け璐ワ紒锛�");
+        }
+        for (WkOrder order : orders) {
+            Double wkQty = Math.round((order.getWorkQty() + order.getAnfme()) * 10000) / 10000.0;
+            if (!this.update(new LambdaUpdateWrapper<WkOrder>()
+                    .set(WkOrder::getWaveId, wave.getId())
+                    .set(WkOrder::getWorkQty, wkQty)
+                    .set(WkOrder::getExceStatus, AsnExceStatus.OUT_STOCK_STATUS_TASK_WAVE.val)
+                    .eq(WkOrder::getId, order.getId()))) {
+                throw new CoolException("鎵ц鐘舵�佷慨鏀逛慨鏀瑰け璐ワ紒锛�");
+            }
+        }
+
+        return R.ok("鎿嶄綔瀹屾垚锛侊紒");
     }
 
     /**
@@ -384,11 +485,12 @@
             throw new CoolException("涓氬姟绫诲瀷涓嶈兘涓虹┖锛侊紒");
         }
 
-        String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_OUT_STOCK_CODE, orders);
-        if (StringUtils.isBlank(ruleCode)) {
-            throw new CoolException("缂栫爜瑙勫垯閿欒锛氳妫�鏌ャ�孲YS_OUT_STOCK_CODE銆嶆槸鍚﹁缃纭紒锛�");
-        }
-        orders.setCode(ruleCode)
+//        String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_OUT_STOCK_CODE, orders);
+//        if (StringUtils.isBlank(ruleCode)) {
+//            throw new CoolException("缂栫爜瑙勫垯閿欒锛氳妫�鏌ャ�孲YS_OUT_STOCK_CODE銆嶆槸鍚﹁缃纭紒锛�");
+//        }
+        orders.setCode(orders.getPoCode())
+                .setWkType(OrderWorkType.ORDER_WORK_TYPE_STOCK_UP.type)
                 .setType(OrderType.ORDER_OUT.type)
                 .setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val)
                 .setUpdateBy(loginUserId)
@@ -456,6 +558,59 @@
         return R.ok(locItems);
     }
 
+    @Override
+    public R getOrderOutTaskItem(OrderOutTaskParam param,Long orderItemId) {
+
+        OrderOutTaskParam orderOutTaskParam = new OrderOutTaskParam();
+        orderOutTaskParam.setWaveId(param.getWaveId());
+
+        if (Cools.isEmpty(param.getWaveId())) {
+            throw new CoolException("绛栫暐鍙傛暟涓虹┖");
+        }
+        if (Cools.isEmpty(param.getOrderId())) {
+            throw new CoolException("鍗曟嵁ID涓虹┖");
+        }
+        WkOrderItem byId = asnOrderItemService.getById(orderItemId);
+        param.setOrderId(byId.getOrderId());
+
+        WaveRule waveRule = waveRuleService.getOne(new LambdaQueryWrapper<WaveRule>()
+                .eq(WaveRule::getId, param.getWaveId()));
+        if (Cools.isEmpty(waveRule)) {
+            throw new CoolException("鏈壘鍒板綋鍓嶇瓥鐣�");
+        }
+        List<OrderOutItemDto> locItems = null;
+        List<Long> itemIds = new ArrayList<>();
+        itemIds.add(orderItemId);
+        locItems = getOutOrderList(param.getOrderId(), waveRule,itemIds);
+        List<OrderOutItemPdaDto> locItemList = new ArrayList<>();
+        for (OrderOutItemDto locItem : locItems) {
+            for (LocItem locItem1 : locItem.getLocItemList()) {
+                OrderOutItemPdaDto orderOutItemPdaDto = new OrderOutItemPdaDto();
+                orderOutItemPdaDto.setLocItem(locItem1);
+                locItemList.add(orderOutItemPdaDto);
+            }
+        }
+        return R.ok(locItemList);
+    }
+
+    @Override
+    public List<OrderOutItemDto>  getOrderOutTaskItemAuto(OrderOutTaskParam param) {
+        if (Cools.isEmpty(param.getWaveId())) {
+            throw new CoolException("绛栫暐鍙傛暟涓虹┖");
+        }
+        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)) {
+            throw new CoolException("鏈壘鍒板綋鍓嶇瓥鐣�");
+        }
+        List<OrderOutItemDto> locItems = null;
+        locItems = getOutOrderList(param.getOrderId(), waveRule);
+        return locItems;
+    }
+
     /**
      * 鐢熸垚鍑哄簱浠诲姟
      *
@@ -470,37 +625,77 @@
             throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒");
         }
         //浼樺厛鐢熸垚娴呭簱浣嶄换鍔�
-        List<OutStockToTaskParams> Items = params.stream()
+        List<OutStockToTaskParams> itemList = params.stream()
                 .sorted(Comparator.comparing(OutStockToTaskParams::getLocCode)
                         .thenComparing(item -> {
             return LocUtils.isShallowLoc(item.getLocCode()) ? 1 : 0;
         }).reversed()).collect(Collectors.toList());
 
-        for (OutStockToTaskParams param : Items) {
+        WkOrder wkOrder = outStockService.getById(outId);
+        if (Cools.isEmpty(wkOrder)) {
+            throw new CoolException("鍗曟嵁涓嶅瓨鍦紒锛�");
+        }
+        List<List<OutStockToTaskParams>> itemLists = new ArrayList<>();
+        List<String> locList = new ArrayList<>();
+        for (OutStockToTaskParams item : itemList) {
+            if (!locList.contains(item.getLocCode())) {
+                List<OutStockToTaskParams> items = new ArrayList<>();
+                locList.add(item.getLocCode());
+                items.add(item);
+                itemLists.add(items);
+            } else {
+                for (List<OutStockToTaskParams> items : itemLists){
+                    boolean sign = false;
+                    for (OutStockToTaskParams itemOld : items) {
+                        if (itemOld.getLocCode().equals(item.getLocCode())) {
+                            sign = true;
+                            items.add(item);
+                        }
+                        break;
+                    }
+                    if (sign) {
+                        break;
+                    }
+                }
+            }
+        }
+        for (List<OutStockToTaskParams> items : itemLists){
+            OutStockToTaskParams param = items.get(0);
             if (Objects.isNull(param) || StringUtils.isBlank(param.getLocCode())) {
                 continue;
             }
             Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, param.getLocCode()).eq(Loc::getBarcode, param.getBarcode()));
             if (!Objects.isNull(loc)) {
                 List<LocItem> locItems = new ArrayList<>();
-                LocItem locItem = locItemService.getById(param.getId());
+                for (OutStockToTaskParams itemOld : items) {
+                    LocItem locItem = locItemService.getById(itemOld.getId());
 
-                WkOrderItem orderItem = outStockItemService.getOne(new LambdaQueryWrapper<WkOrderItem>()
-                        .eq(WkOrderItem::getOrderId, outId)
-                        .eq(StringUtils.isNotBlank(locItem.getBatch()), WkOrderItem::getSplrBatch, locItem.getBatch())
+                    WkOrderItem orderItem = outStockItemService.getOne(new LambdaQueryWrapper<WkOrderItem>()
+                            .eq(WkOrderItem::getOrderId, outId)
+//                        .eq(StringUtils.isNotBlank(locItem.getBatch()), WkOrderItem::getSplrBatch, locItem.getBatch())
+                            .eq(WkOrderItem::getMatnrId, locItem.getMatnrId()));
 //                        .eq(StringUtils.isNotBlank(locItem.getFieldsIndex()), WkOrderItem::getFieldsIndex, locItem.getFieldsIndex())
-                        .eq(WkOrderItem::getMatnrId, locItem.getMatnrId()));
 
-                if (Objects.isNull(orderItem)) {
-                    throw new CoolException("鍗曟嵁鏄庣粏涓嶅瓨鍦紒锛�");
+                    if (Objects.isNull(orderItem)) {
+                        throw new CoolException("鍗曟嵁鏄庣粏涓嶅瓨鍦紒锛�");
+                    }
+
+                    locItem.setOutQty(itemOld.getOutQty())
+                            .setBatch(itemOld.getBatch())
+                            .setSourceId(outId)
+                            .setSourceCode(orderItem.getOrderCode())
+                            .setSource(orderItem.getId());
+                    locItems.add(locItem);
+
+
+                    Double workQty = Math.round((orderItem.getWorkQty() + locItem.getOutQty()) * 10000) / 10000.0;
+
+                    orderItem.setUpdateBy(loginUserId).setUpdateTime(new Date()).setWorkQty(workQty);
+
+                    if (!outStockItemService.updateById(orderItem)) {
+                        throw new CoolException("鍗曟嵁鏄庣粏淇敼澶辫触锛侊紒");
+                    }
                 }
-
-                locItem.setOutQty(param.getOutQty())
-                        .setBatch(param.getBatch())
-                        .setSourceId(outId)
-                        .setSourceCode(orderItem.getOrderCode())
-                        .setSource(orderItem.getId());
-                locItems.add(locItem);
 
                 LocToTaskParams taskParams = new LocToTaskParams();
                 taskParams.setType(Constants.TASK_TYPE_ORDER_OUT_STOCK)
@@ -508,26 +703,21 @@
                         .setItems(locItems)
                         .setSourceId(outId)
                         .setSiteNo(param.getSiteNo());
+                //澧炲姞澶囪揣鍑哄簱绫诲瀷鍒ゆ柇
+                Short type = wkOrder.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_STOCK_UP.type)
+                        ?TaskResouceType.TASK_RESOUCE_STOCK_UP.val
+                        :TaskResouceType.TASK_RESOUCE_ORDER_TYPE.val;
                 try {
                     //鐢熸垚鍑哄簱浠诲姟
-                    locItemService.generateTask(TaskResouceType.TASK_RESOUCE_ORDER_TYPE.val, taskParams, loginUserId);
+                    locItemService.generateTask(type, taskParams, loginUserId);
                 } catch (Exception e) {
                     logger.error("UNK", e);
                     throw new CoolException(e.getMessage());
                 }
-
-
-                Double workQty = Math.round((orderItem.getWorkQty() + locItem.getOutQty()) * 10000) / 10000.0;
-
-                orderItem.setUpdateBy(loginUserId).setUpdateTime(new Date()).setWorkQty(workQty);
-
-                if (!outStockItemService.updateById(orderItem)) {
-                    throw new CoolException("鍗曟嵁鏄庣粏淇敼澶辫触锛侊紒");
-                }
             }
         }
 
-        Double sum = Items.stream().mapToDouble(OutStockToTaskParams::getOutQty).sum();
+        Double sum = itemList.stream().mapToDouble(OutStockToTaskParams::getOutQty).sum();
         //鏇存柊鍑哄簱鍗曟槑缁嗗強涓诲崟
         WkOrder outOrder = outStockService.getById(outId);
         if (Objects.isNull(outOrder)) {
@@ -630,7 +820,8 @@
                         locItem.setOutQty(issued.doubleValue() >= locItem.getAnfme() ? locItem.getAnfme() : issued.doubleValue());
                         locItem.setBarcode(loc.getBarcode());
                         OrderOutItemDto orderOutItemDto = new OrderOutItemDto();
-                        orderOutItemDto.setLocItem(locItem);
+//                        orderOutItemDto.setLocItem(locItem);
+                        orderOutItemDto.getLocItemList().add(locItem);
 
                         List<DeviceSite> deviceSites = deviceSiteService.list(new LambdaQueryWrapper<DeviceSite>()
                                 .eq(DeviceSite::getChannel, loc.getChannel())
@@ -668,7 +859,86 @@
                         .setUnit(wkOrderItem.getStockUnit())
                         .setBatch(wkOrderItem.getSplrBatch());
                 OrderOutItemDto orderOutItemDto = new OrderOutItemDto();
-                orderOutItemDto.setLocItem(locItem);
+//                orderOutItemDto.setLocItem(locItem);
+                orderOutItemDto.getLocItemList().add(locItem);
+                list.add(orderOutItemDto);
+            }
+        }
+
+        return list;
+
+    }
+
+    private List<OrderOutItemDto> getOutOrderList(Long orderId, WaveRule waveRule,List<Long> orderItemIdList) {
+        List<WkOrderItem> wkOrderItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>()
+                        .in(WkOrderItem::getId, orderItemIdList).eq(WkOrderItem::getOrderId, orderId));
+        List<OrderOutItemDto> list = new ArrayList<>();
+        Set<ExistDto> existDtos = new HashSet<>();
+        for (WkOrderItem wkOrderItem : wkOrderItems) {
+            BigDecimal issued = new BigDecimal(wkOrderItem.getAnfme().toString())
+                    .subtract(new BigDecimal(wkOrderItem.getWorkQty().toString())
+                    );
+            if (issued.doubleValue() <= 0) {
+                continue;
+            }
+            List<LocItem> locItems = new ArrayList<>();
+            if (WaveRuleType.Efficiency_First.type.equals(waveRule.getType())) {
+                locItems = LocManageUtil.getEfficiencyFirstItemList(wkOrderItem.getMatnrCode(), wkOrderItem.getSplrBatch(), wkOrderItem.getAnfme());
+            } else if (WaveRuleType.First_In_First_Out.type.equals(waveRule.getType())) {
+                locItems = LocManageUtil.getFirstInFirstOutItemList(wkOrderItem.getMatnrCode(), wkOrderItem.getSplrBatch(), wkOrderItem.getAnfme());
+            } else {
+                locItems = LocManageUtil.getFirstInFirstOutItemList(wkOrderItem.getMatnrCode(), wkOrderItem.getSplrBatch(), wkOrderItem.getAnfme());
+            }
+            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) {
+                    ExistDto existDto = new ExistDto().setBatch(locItem.getBatch()).setMatnr(locItem.getMatnrCode()).setLocNo(locItem.getLocCode());
+                    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);
+                        orderOutItemDto.getLocItemList().add(locItem);
+
+                        List<DeviceSite> deviceSites = deviceSiteService.list(new LambdaQueryWrapper<DeviceSite>()
+                                .eq(DeviceSite::getChannel, loc.getChannel())
+                                .eq(DeviceSite::getType, issued.doubleValue() >= locItem.getAnfme() && itemList.size() == 1 ? TaskType.TASK_TYPE_OUT.type : TaskType.TASK_TYPE_PICK_AGAIN_OUT.type)
+                        );
+
+                        if (!deviceSites.isEmpty()) {
+                            List<OrderOutItemDto.staListDto> maps = new ArrayList<>();
+                            for (DeviceSite sta : deviceSites) {
+                                OrderOutItemDto.staListDto staListDto = new OrderOutItemDto.staListDto();
+                                staListDto.setStaNo(sta.getSite());
+                                staListDto.setStaName(sta.getSite());
+                                maps.add(staListDto);
+                            }
+                            orderOutItemDto.setStaNos(maps);
+                            //榛樿鑾峰彇绗竴绔欑偣
+                            DeviceSite deviceSite = deviceSites.stream().findFirst().get();
+                            orderOutItemDto.setSiteNo(deviceSite.getSite());
+                        }
+
+                        list.add(orderOutItemDto);
+
+                        issued = issued.subtract(new BigDecimal(locItem.getAnfme().toString()));
+                    }
+                }
+            }
+            if (issued.doubleValue() > 0) {
+                LocItem locItem = new LocItem()
+                        .setId(new Random().nextLong())
+                        .setMatnrCode(wkOrderItem.getMatnrCode())
+                        .setMaktx(wkOrderItem.getMaktx())
+                        .setAnfme(0.00)
+                        .setWorkQty(issued.doubleValue())
+                        .setOutQty(issued.doubleValue())
+                        .setUnit(wkOrderItem.getStockUnit())
+                        .setBatch(wkOrderItem.getSplrBatch());
+                OrderOutItemDto orderOutItemDto = new OrderOutItemDto();
+//                orderOutItemDto.setLocItem(locItem);
+                orderOutItemDto.getLocItemList().add(locItem);
                 list.add(orderOutItemDto);
             }
         }
@@ -730,4 +1000,25 @@
 
         return waveItems;
     }
+
+
+    /**
+     * @param id
+     * @return
+     * @author Ryan
+     * @description 瀹屾垚鍑哄簱鍗�
+     * @time 2025/4/25 10:07
+     */
+    @Override
+    public R completeOutOrderById(Long id) {
+        WkOrder order = this.getById(id);
+        if (Objects.isNull(order)) {
+            return R.error("鍑哄簱鍗曚笉瀛樺湪锛侊紒");
+        }
+        order.setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_DONE.val);
+        if (!this.updateById(order)) {
+            throw new CoolException("瀹屾垚鍑哄簱鍗曞け璐ワ紒锛�");
+        }
+         return R.ok("瀹屾垚鍑哄簱鍗曟垚鍔燂紒锛�");
+    }
 }

--
Gitblit v1.9.1