From 2938aa734a2cf0baf93fdced92ea21e37f187365 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期二, 10 六月 2025 11:05:39 +0800
Subject: [PATCH] 出库单下发执行生成任务明细

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java |  340 +++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 251 insertions(+), 89 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 464ab07..990e9ac 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
@@ -1,29 +1,40 @@
 package com.vincent.rsf.server.manager.service.impl;
 
 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.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 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.entity.enums.OrderType;
+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.*;
-import com.vincent.rsf.server.manager.enums.AsnExceStatus;
-import com.vincent.rsf.server.manager.enums.WaveExceStatus;
 import com.vincent.rsf.server.manager.mapper.AsnOrderMapper;
 import com.vincent.rsf.server.manager.service.*;
 import com.vincent.rsf.server.manager.utils.OptimalAlgorithmUtil;
 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;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.math.BigDecimal;
 import java.util.*;
 import java.util.stream.Collectors;
+
+import com.vincent.rsf.server.manager.enums.WaveRuleType;
 
 /**
  * @author Ryan
@@ -34,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;
@@ -51,6 +65,18 @@
     private WaveService waveService;
     @Autowired
     private WaveItemService waveItemService;
+    @Autowired
+    private OutStockItemService outStockItemService;
+    @Autowired
+    private OutStockService outStockService;
+    @Autowired
+    private WaveRuleService waveRuleService;
+    @Autowired
+    private LocItemService locItemService;
+    @Autowired
+    private DeviceSiteService deviceSiteService;
+    @Autowired
+    private LocService locService;
 
 
     /**
@@ -61,7 +87,7 @@
      * @time 2025/4/7 13:28
      */
     @Transactional(rollbackFor = Exception.class)
-    private void svaeOrUpdateOrderItem(AsnOrderAndItemsParams params, Long loginUserId) throws Exception {
+    public void svaeOrUpdateOrderItem(AsnOrderAndItemsParams params, Long loginUserId) throws Exception {
         AsnOrder orders = params.getOrders();
         params.getItems().forEach(item -> {
             item.put("asnId", orders.getId());
@@ -69,13 +95,13 @@
             item.put("poCode", orders.getPoCode());
             item.put("createBy", loginUserId);
             item.put("updateBy", loginUserId);
-            if (!asnOrderItemService.fieldsSave(item)) {
+            if (!asnOrderItemService.fieldsSave(item, loginUserId)) {
                 throw new CoolException("鏄庣粏淇濆瓨澶辫触锛侊紒");
             }
         });
         List<AsnOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>()
                 .eq(AsnOrderItem::getAsnId, params.getOrders().getId()));
-        double sum = orderItems.stream().mapToDouble(AsnOrderItem::getAnfme).sum();
+        Double sum = orderItems.stream().mapToDouble(AsnOrderItem::getAnfme).sum();
         orders.setAnfme(sum);
         if (!this.updateById(orders)) {
             throw new CoolException("璁″垝鏀惰揣鏁伴噺淇敼澶辫触锛侊紒");
@@ -87,73 +113,12 @@
      * @param
      * @return
      * @author Ryan
-     * @description 鍒犻櫎鍘熶富鍗曞強鏄庣粏锛屽姞鍏ュ巻鍙叉。
-     * @time 2025/3/19 19:53
-     */
-    @Transactional(rollbackFor = Exception.class)
-    private void operateOrderLogs(AsnOrder asrder) throws Exception {
-        if (Objects.isNull(asrder) || Objects.isNull(asrder.getId())) {
-            throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒");
-        }
-        asrder.setExceStatus(AsnExceStatus.ASN_EXCE_STATUS_TASK_CLOSE.val);
-
-        if (!this.updateById(asrder)) {
-            throw new CoolException("鍗曟嵁鍏抽棴澶辫触锛侊紒");
-        }
-        List<AsnOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getAsnId, asrder.getId()));
-        if (orderItems.isEmpty()) {
-            throw new CoolException("鏀惰揣鏄庣粏涓虹┖锛侊紒");
-        }
-//        if (Objects.isNull(asrder.getAnfme()) || asrder.getAnfme().compareTo(0.00) == 0) {
-//            throw new CoolException("鏀惰揣鏁伴噺涓嶈兘涓洪浂锛侊紒");
-//        }
-        AsnOrder order = this.getById(asrder.getId());
-        AsnOrderLog orderLog = new AsnOrderLog();
-        order.setExceStatus(AsnExceStatus.ASN_EXCE_STATUS_TASK_DONE.val);
-        BeanUtils.copyProperties(order, orderLog);
-        orderLog.setId(null);
-        orderLog.setAsnId(order.getId());
-
-        if (!this.saveOrUpdate(order)) {
-            throw new CoolException("鐘舵�佷慨鏀瑰け璐ワ紒锛�");
-        }
-        orderLog.setExceStatus(AsnExceStatus.ASN_EXCE_STATUS_TASK_CLOSE.val);
-        if (!asnOrderLogService.save(orderLog)) {
-            throw new CoolException("涓诲崟鍘嗗彶妗f坊鍔犲け璐ワ紒锛�");
-        }
-        List<AsnOrderItemLog> logs = new ArrayList<>();
-        List<AsnOrderItem> items = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getAsnId, order.getId()));
-        items.forEach(item -> {
-            AsnOrderItemLog itemLog = new AsnOrderItemLog();
-            BeanUtils.copyProperties(item, itemLog);
-            itemLog.setAsnItemId(itemLog.getId())
-                    .setLogId(orderLog.getId())
-                    .setAsnId(item.getAsnId());
-            logs.add(itemLog);
-        });
-
-        if (!asnOrderItemLogService.saveBatch(logs)) {
-            throw new CoolException("閫氱煡鍗曟槑缁嗗巻鍙叉。淇濆瓨澶辫触锛侊紒");
-        }
-        if (!asnOrderItemService.remove(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getAsnId, order.getId()))) {
-            throw new CoolException("鍘熷崟鎹槑缁嗗垹闄ゅけ璐ワ紒锛�");
-        }
-        if (!this.removeById(asrder.getId())) {
-            throw new CoolException("鍘熷崟鎹垹闄ゅけ璐ワ紒锛�");
-        }
-    }
-
-    /**
-     * @param
-     * @return
-     * @author Ryan
      * @description 鍙栨秷鍑哄簱鍗曟嵁
      * @time 2025/4/22 10:40
      */
     @Override
     @Transactional(rollbackFor = Exception.class)
     public R cancelOutOrder(String id) {
-        //TODO 鍑哄簱鍗曞彇娑堟祦绋嬶紝QMS锛堝崟鎹彇娑堬級->DO鍗�->鍑哄簱鍗�->娉㈡->鍒ゆ柇鏄惁鍏ㄥ崟鎹�->鍏ㄥ崟鎹笅鍙戝彇娑堜换鍔¤嚦WCS,闈炲叏鍗曟暟鎹彇娑堝垹闄ゆ祦绋嬫墍鏈夊叧鑱旀暟鎹�
         if (Cools.isEmpty(id)) {
             throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒");
         }
@@ -161,19 +126,45 @@
         if (Objects.isNull(order)) {
             throw new CoolException("鍗曟嵁涓嶅瓨鍦紒锛�");
         }
-        if (!order.getExceStatus().equals(AsnExceStatus.ASN_EXCE_STATUS_UN_EXCE.val)) {
+        if (!order.getExceStatus().equals(AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val)) {
             throw new CoolException("褰撳墠鍗曟嵁鐘舵�佷负" + AsnExceStatus.getExceStatus(order.getExceStatus()) + "锛� 涓嶅彲鎵ц鍙栨秷鎿嶄綔锛侊紒");
         }
-        order.setExceStatus(AsnExceStatus.ASN_EXCE_STATUS_TASK_CANCEL.val).setStatus(0);
 
-        if (!this.saveOrUpdate(order)) {
-            throw new CoolException("鍗曟嵁鍙栨秷澶辫触锛侊紒");
+        List<AsnOrderItem> orderItems = outStockItemService.list(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getAsnId, id));
+        if (!orderItems.isEmpty()) {
+            for (AsnOrderItem orderItem : orderItems) {
+                if (!Objects.isNull(orderItem.getPoDetlId())) {
+                    DeliveryItem deliveryItem = deliveryItemService.getById(orderItem.getPoDetlId());
+                    Double workQty = Math.round((deliveryItem.getWorkQty() - orderItem.getAnfme()) * 10000) / 10000.0;
+                    deliveryItem.setWorkQty(workQty.compareTo(0.0) >= 0 ? workQty : 0);
+                    if (!deliveryItemService.updateById(deliveryItem)) {
+                        throw new CoolException("DO鍗曟槑缁嗘洿鏂板け璐ワ紒锛�");
+                    }
+
+                    Delivery delivery = deliveryService.getOne(new LambdaQueryWrapper<Delivery>().eq(Delivery::getCode, orderItem.getPoCode()));
+                    if (!Objects.isNull(delivery)) {
+                        Double wkQty = Math.round((delivery.getWorkQty() - delivery.getAnfme()) * 10000) / 10000.0;
+                        delivery.setWorkQty(wkQty.compareTo(0.0) >= 0 ? wkQty : 0).setExceStatus(POExceStatus.PO_EXCE_STATUS_UN_EXCE.val);
+                        if (!deliveryService.updateById(delivery)) {
+                            throw new CoolException("DO鍗曟嵁淇敼澶辫触锛侊紒");
+                        }
+                    }
+                }
+            }
+        }
+
+        if (!this.remove(new LambdaQueryWrapper<AsnOrder>().eq(AsnOrder::getId, id))) {
+            throw new CoolException("涓诲崟鍒犻櫎澶辫触锛侊紒");
+        }
+        if (!outStockItemService.remove(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getAsnId, id))) {
+            throw new CoolException("鍗曟嵁鏄庣粏鍒犻櫎澶辫触锛侊紒");
         }
         return R.ok("鎿嶄綔鎴愬姛");
     }
 
     /**
      * @param
+     * @param loginUserId
      * @return
      * @author Ryan
      * @description 閫氳繃DO鍗曠敓鎴愬嚭搴撳崟
@@ -181,7 +172,7 @@
      */
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public R genOutStock(List<Long> ids) {
+    public R genOutStock(List<Long> ids, Long loginUserId) {
         if (Objects.isNull(ids) || ids.isEmpty()) {
             throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒");
         }
@@ -191,7 +182,6 @@
         }
         Map<Long, List<DeliveryItem>> listMap = items.stream().collect(Collectors.groupingBy(DeliveryItem::getDeliveryId));
         listMap.keySet().forEach(key -> {
-            //TODO 鍒ゆ柇鍗曟嵁鏄惁宸茬粡瀛樺湪锛屽瀛樺湪鍒欑疮鍔犱慨鏀瑰瓙琛紝涓嶅瓨鍦ㄦ墠鏂板缓
             Delivery delivery = deliveryService.getById(key);
             if (Objects.isNull(delivery)) {
                 throw new CoolException("鍗曟嵁涓嶅瓨鍦紒锛�");
@@ -203,9 +193,13 @@
                 throw new CoolException("缂栫爜瑙勫垯閿欒锛氳妫�鏌� 銆孲YS_OUT_STOCK_CODE銆嶇紪鐮佹槸鍚﹁缃垚鍔�");
             }
             order.setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val)
+                    .setType(delivery.getType())
+                    .setWkType(delivery.getWkType())
                     .setCode(ruleCode)
                     .setPoId(delivery.getId())
                     .setId(null)
+                    .setUpdateBy(loginUserId)
+                    .setCreateBy(loginUserId)
                     .setPoCode(delivery.getCode());
             if (!this.save(order)) {
                 throw new CoolException("涓诲崟淇濆瓨澶辫触锛侊紒");
@@ -213,28 +207,58 @@
             List<AsnOrderItem> orderItems = new ArrayList<>();
             listMap.get(key).forEach(item -> {
                 AsnOrderItem orderItem = new AsnOrderItem();
+                Double anfme = Math.round((item.getAnfme() - item.getWorkQty() - item.getQty()) * 10000) / 10000.0;
                 BeanUtils.copyProperties(item, orderItem);
                 orderItem.setId(null)
                         .setPoCode(order.getPoCode())
                         .setMaktx(item.getMaktx())
                         .setMatnrCode(item.getMatnrCode())
                         .setFieldsIndex(item.getFieldsIndex())
+                        .setAnfme(anfme)
+                        .setWorkQty(0.0)
                         .setAsnId(order.getId())
                         .setAsnCode(order.getCode())
+                        .setStockUnit(item.getUnit())
+                        .setPurUnit(item.getUnit())
+                        .setPlatWorkCode(item.getPlatWorkCode())
+                        .setPlatOrderCode(item.getPlatOrderCode())
+                        .setProjectCode(item.getProjectCode())
                         .setPlatItemId(item.getPlatItemId())
+                        .setUpdateBy(loginUserId)
+                        .setCreateBy(loginUserId)
                         .setPoDetlId(item.getId());
                 orderItems.add(orderItem);
+
+                if (!deliveryItemService.update(new LambdaUpdateWrapper<DeliveryItem>()
+                        .set(DeliveryItem::getWorkQty, item.getAnfme())
+                        .eq(DeliveryItem::getId, item.getId()))) {
+                    throw new CoolException("DO鍗曟槑缁嗕慨鏀瑰け璐ワ紒锛�");
+                }
             });
 
-            double sum = orderItems.stream().mapToDouble(AsnOrderItem::getAnfme).sum();
+            Double sum = orderItems.stream().mapToDouble(AsnOrderItem::getAnfme).sum();
             //淇敼璁″垝鏁伴噺
-            order.setAnfme(sum);
+            order.setAnfme(sum).setWorkQty(0.0);
             if (!this.saveOrUpdate(order)) {
                 throw new CoolException("涓诲崟鏁伴噺淇敼澶辫触锛侊紒");
             }
             if (!asnOrderItemService.saveBatch(orderItems)) {
                 throw new CoolException("鏄庣粏淇濆瓨澶辫触锛侊紒");
             }
+
+            Short exceStatus = POExceStatus.PO_EXCE_STATUS_SECTION_DONE.val;
+            if (delivery.getAnfme().compareTo(order.getAnfme()) <= 0) {
+                exceStatus = AsnExceStatus.ASN_EXCE_STATUS_TASK_DONE.val;
+            }
+
+            Double wkQty = Math.round((delivery.getWorkQty() + sum) * 10000) / 10000.0;
+            if (!deliveryService.update(new LambdaUpdateWrapper<Delivery>()
+                    .set(Delivery::getExceStatus, exceStatus)
+                    .set(Delivery::getWorkQty, wkQty)
+                    .eq(Delivery::getId, key))) {
+                throw new CoolException("涓诲崟淇敼澶辫触锛侊紒");
+            }
+
         });
         return R.ok();
     }
@@ -301,7 +325,7 @@
         double sum2 = orderItems.stream().mapToDouble(AsnOrderItem::getWorkQty).sum();
         if (!this.update(new LambdaUpdateWrapper<AsnOrder>()
                 .set(AsnOrder::getWaveId, wave.getId())
-                        .set(AsnOrder::getWorkQty, sum2)
+                .set(AsnOrder::getWorkQty, sum2)
                 .set(AsnOrder::getExceStatus, AsnExceStatus.OUT_STOCK_STATUS_TASK_WAVE.val)
                 .in(AsnOrder::getId, ids))) {
             throw new CoolException("鎵ц鐘舵�佷慨鏀逛慨鏀瑰け璐ワ紒锛�");
@@ -310,10 +334,10 @@
     }
 
     /**
-     * @author Ryan
-     * @description 淇濆瓨鍑哄簱涓诲崟鍙婃槑缁�
      * @param
      * @return
+     * @author Ryan
+     * @description 淇濆瓨鍑哄簱涓诲崟鍙婃槑缁�
      * @time 2025/4/29 13:47
      */
     @Override
@@ -334,9 +358,9 @@
         if (Objects.isNull(ruleCode) || StringUtils.isBlank(ruleCode)) {
             throw new CoolException("缂栫爜瑙勫垯閿欒锛氳妫�鏌ャ�孲YS_OUT_STOCK_CODE銆嶆槸鍚﹁缃纭紒锛�");
         }
-
         orders.setCode(ruleCode)
                 .setType(OrderType.ORDER_OUT.type)
+                .setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val)
                 .setUpdateBy(loginUserId)
                 .setCreateBy(loginUserId);
         if (!this.save(orders)) {
@@ -347,20 +371,18 @@
         }
         params.setOrders(orders);
         try {
-            svaeOrUpdateOrderItem(params,loginUserId);
+            svaeOrUpdateOrderItem(params, loginUserId);
         } catch (Exception e) {
             throw new CoolException(e.getMessage());
         }
-
         return R.ok();
     }
 
-
     /**
-     * @author Ryan
-     * @description 淇敼涓诲崟鍙婃槑缁�
      * @param
      * @return
+     * @author Ryan
+     * @description 淇敼涓诲崟鍙婃槑缁�
      * @time 2025/4/29 13:47
      */
     @Override
@@ -376,16 +398,156 @@
             throw new CoolException("涓诲崟淇敼澶辫触锛侊紒");
         }
         if (Objects.isNull(params.getItems()) || params.getItems().isEmpty()) {
-            return R.ok("鏄庣粏鍙傛暟涓嶈兘涓虹┖锛侊紒");
+            throw new CoolException("鏄庣粏鍙傛暟涓嶈兘涓虹┖锛侊紒");
         }
-
         try {
-            svaeOrUpdateOrderItem(params,loginUserId);
+            svaeOrUpdateOrderItem(params, loginUserId);
         } catch (Exception e) {
             throw new CoolException(e.getMessage());
         }
+        return R.ok();
+    }
 
-        return null;
+    @Override
+    public R getOrderOutTaskItem(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;
+        if (WaveRuleType.Efficiency_First.type.equals(waveRule.getType())) {
+            locItems = efficiencyFirst(param.getOrderId());
+        } else if (WaveRuleType.First_In_First_Out.type.equals(waveRule.getType())) {
+
+        }
+        return R.ok(locItems);
+    }
+
+    /**
+     * 鐢熸垚鍑哄簱浠诲姟
+     * @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) {
+        QueryWrapper<LocItem> locItemQueryWrapper = new QueryWrapper<>();
+        locItemQueryWrapper.eq("matnr_code", asnOrderItem.getMatnrCode());
+        locItemQueryWrapper.eq("batch", asnOrderItem.getSplrBatch());
+        String applySql = String.format(
+                "EXISTS (SELECT 1 FROM man_loc ml " +
+                        "WHERE ml.use_status = '%s'" +
+                        "AND ml.id = man_loc_item.loc_id " +
+                        ")",
+                LocStsType.LOC_STS_TYPE_F.type
+        );
+        locItemQueryWrapper.apply(applySql);
+        List<LocItem> locItems = locItemService.list(locItemQueryWrapper);
+        locItems.sort((s1, s2) -> LocUtils.isShallowLoc(s1.getLocCode()) ? -1 : 0);
+        return locItems;
+    }
+
+    private List<OrderOutItemDto> efficiencyFirst(Long orderId) {
+        List<AsnOrderItem> asnOrderItems = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>()
+                .eq(AsnOrderItem::getAsnId, orderId)
+        );
+
+        List<OrderOutItemDto> list = new ArrayList<>();
+
+        Set<String> exist = new HashSet<>();
+        Set<ExistDto> existDtos = new HashSet<>();
+
+        for (AsnOrderItem asnOrderItem : asnOrderItems) {
+            BigDecimal issued = new BigDecimal(asnOrderItem.getAnfme().toString())
+                    .subtract(new BigDecimal(asnOrderItem.getWorkQty().toString())
+                    );
+            if (issued.doubleValue() <= 0) {
+                continue;
+            }
+            List<LocItem> locItems = null;
+            locItems = getEfficiencyFirstItemList(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) {
+                    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);
+                        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()) {
+                            DeviceSite deviceSite = deviceSites.stream().findFirst().get();
+                            orderOutItemDto.setSiteNo(deviceSite.getSite());
+                        }
+                        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);
+
+                        list.add(orderOutItemDto);
+
+                        issued = issued.subtract(new BigDecimal(locItem.getAnfme().toString()));
+                    }
+                }
+
+            }
+        }
+
+        return list;
+
     }
 
     /**
@@ -426,7 +588,7 @@
                         p1.getUnit(),
                         p1.getTrackCode(),
                         p1.getFieldsIndex(),
-                        p1.getAnfme() + p2.getAnfme(),
+                        Math.round((p1.getAnfme() + p2.getAnfme()) * 10000) / 10000.0,
                         p1.getWorkQty(),
                         p1.getTenantId(),
                         p1.getStatus(),

--
Gitblit v1.9.1