From 013c9ed47408e0c584a05663afee2bb47a39d50d Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期四, 27 二月 2025 16:02:05 +0800
Subject: [PATCH] #优化 波次预览显示优化 大屏1280*720兼容

---
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/manage/OutManage.java |   58 ++++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 42 insertions(+), 16 deletions(-)

diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/manage/OutManage.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/manage/OutManage.java
index b60555e..b1d6fe3 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/manage/OutManage.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/manage/OutManage.java
@@ -3,6 +3,7 @@
 import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.conditions.Wrapper;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.fasterxml.jackson.datatype.jsr310.DecimalUtils;
 import com.mysql.cj.util.StringUtils;
 import com.zy.asrs.framework.exception.CoolException;
 import com.zy.asrs.wms.asrs.entity.dto.*;
@@ -22,6 +23,7 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
+import java.text.DecimalFormat;
 import java.text.SimpleDateFormat;
 import java.util.*;
 import java.util.stream.Collectors;
@@ -555,12 +557,17 @@
         List<MergePreviewResultDto> resultDtos = new ArrayList<>();
         //浼樺厛鏌ヨ骞冲簱鏁版嵁
         param.forEach(pars -> {
+            if (pars.getStatus() == 1) {
+                return;
+            }
             List<MergePreviewResultLocDto> locDtos = new ArrayList<>();
             MergePreviewResultDto resultDto = new MergePreviewResultDto();
             resultDto.sync(pars);
             resultDto.setOrderIds(pars.getOrderIds());
+            //鎬婚渶姹傛暟閲�
+            resultDto.setAnfme(pars.getAnfme());
             resultDto.setLocs(locDtos);
-
+            //鏌ヨ骞冲簱涓鍚堟潯浠剁殑搴撳瓨
             List<LocDetl> locs = locDetlService.queryFlatStock(pars.getMatnr(), pars.getBatch(), pars.getFieldParams());
             if (!locs.isEmpty()) {
                 double anfme = pars.getAnfme() - pars.getWorkQty();
@@ -578,44 +585,61 @@
                     locDto.setLocNo(detl.getLocNo());
                     locDto.setTypeId(LocAreaTypeSts.LOC_AREA_TYPE_FLAT.id);
                     locDto.setLocDetlId(detl.getId());
-
+                    locDto.setAnfme(detl.getAnfme());
+                    locDto.setWorkQty(detl.getWorkQty());
                     locDtos.add(locDto);
                     //搴撲綅瀹為檯鍙敤鏁伴噺
                     double surplusQty = detl.getAnfme() - detl.getWorkQty();
+                    if (surplusQty <= 0) {
+                        continue;
+                    }
                     //娉㈡鏁伴噺鍑忓幓搴撲綅鍙敤鏁伴噺鍚庯紝鐩堜綑鏁伴噺
                     anfme = anfme - surplusQty;
                     if (anfme > 0) {
-                        locDto.setAnfme(detl.getAnfme());
-                        locDto.setWorkQty(surplusQty);
+                        //褰撳墠鍙娇鐢ㄦ暟閲�
+                        resultDto.setFetchQty(surplusQty);
+                        //浣欎笅闇�姹傛暟閲�
+                        pars.setStatus(2);
+                        pars.setWorkQty(pars.getWorkQty() + surplusQty);
+                        pars.setAnfme(anfme);
                     } else {
-                        locDto.setAnfme(pars.getAnfme() - pars.getWorkQty());
-                        locDto.setWorkQty(pars.getAnfme() - pars.getWorkQty());
+                        //褰撳墠浣跨敤鏁伴噺
+                        resultDto.setFetchQty(pars.getAnfme());
+                        //浣欎笅闇�姹�
+                        pars.setWorkQty(pars.getWorkQty() + pars.getAnfme());
+                        pars.setStatus(1);
+                        pars.setAnfme(0.0);
                         break;
                     }
                 }
-                //淇濆瓨鍑哄簱鏁伴噺锛堝钩搴擄級
-                pars.setWorkQty(pars.getAnfme() - pars.getWorkQty() - anfme);
 
-                resultDto.setOtherLocs(new ArrayList<>());
+                if (!Objects.isNull(resultDto.getFetchQty()) && !(new BigDecimal(resultDto.getFetchQty()).compareTo(new BigDecimal("0.00")) == 0)) {
+                    resultDto.setOtherLocs(new ArrayList<>());
 
-                resultDto.setAnfme(pars.getAnfme());
+                    resultDto.setType(LocAreaTypeSts.LOC_AREA_TYPE_FLAT.desc);
 
-                resultDtos.add(resultDto);
-
+                    resultDtos.add(resultDto);
+                }
             }
         });
+
         //骞冲簱鏌ヨ瀹屾垚鍚庯紝鍐嶆煡璇CU
         for (MergePreviewDto dto : param) {
-            Double anfme = dto.getAnfme() - dto.getWorkQty();
-            //鍑忓幓骞冲簱鏁伴噺鍚庯紝灏忎簬绛変簬0锛岃烦鍑哄鐞�
-            if (anfme <= 0) {
+            //鍗曟嵁宸插畬鎴愶紝璺冲嚭
+            if (dto.getStatus() == 1) {
                 continue;
             }
+//            Double anfme = dto.getAnfme() - dto.getWorkQty();
+//            //鍑忓幓骞冲簱鏁伴噺鍚庯紝灏忎簬绛変簬0锛岃烦鍑哄鐞�
+//            if (anfme <= 0) {
+//                continue;
+//            }
             List<LocDetl> locDetls = locDetlService.queryStock(dto.getMatnr(), dto.getBatch(), dto.getFieldParams(), sortParams);
             if (locDetls.isEmpty()) {
                 MergePreviewResultDto resultDto = new MergePreviewResultDto();
                 resultDto.sync(dto);
                 resultDto.setLocs(new ArrayList<>());
+                resultDto.setType(LocAreaTypeSts.LOC_AREA_TYPE_UTC.desc);
                 resultDto.setOrderIds(dto.getOrderIds());
                 resultDto.setAnfme(dto.getAnfme());
                 resultDtos.add(resultDto);
@@ -627,7 +651,7 @@
             MergePreviewResultDto resultDto = new MergePreviewResultDto();
             resultDto.sync(dto);
             resultDto.setOrderIds(dto.getOrderIds());
-//            Double anfme = dto.getAnfme();
+            Double anfme = dto.getAnfme();
             resultDto.setLocs(locDtos);
             for (LocDetl locDetl : locDetls) {
                 Loc loc = locService.getById(locDetl.getLocId());
@@ -676,6 +700,8 @@
 
             resultDto.setAnfme(dto.getAnfme());
 
+            resultDto.setType(LocAreaTypeSts.LOC_AREA_TYPE_UTC.desc);
+
             resultDtos.add(resultDto);
         }
 

--
Gitblit v1.9.1