From 69f3d9e338f29af69def24839e9b8cdd276a0472 Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期四, 08 八月 2024 11:41:03 +0800
Subject: [PATCH] 检验任务保存优化+模版样式修改

---
 inspect-server/src/main/resources/static/report-template.docx                          |    0 
 inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java |   35 +++++++++++------
 inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderServiceImpl.java     |   50 ++++++++++++------------
 3 files changed, 48 insertions(+), 37 deletions(-)

diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java
index 1d15f2b..cc30704 100644
--- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java
+++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java
@@ -336,7 +336,7 @@
                 for (InsFibers insFiber : insFibers) {
                     List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getInsFibersId, insFiber.getId()));
                     List<Integer> collect = insProducts.stream().map(InsProduct::getInsResult)
-                            .filter(sm -> ObjectUtils.isNotEmpty(sm) && sm!=2).collect(Collectors.toList());
+                            .filter(sm -> ObjectUtils.isNotEmpty(sm) && sm != 2).collect(Collectors.toList());
                     if (insProducts.size() == collect.size()) {
                         insFiber.setState(1);//宸叉楠�
                     } else {
@@ -349,7 +349,7 @@
                 for (InsFiber insFiber : fiberList) {
                     List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getInsFiberId, insFiber.getId()));
                     List<Integer> collect = insProducts.stream().map(InsProduct::getInsResult)
-                            .filter(sm -> ObjectUtils.isNotEmpty(sm) && sm!=2).collect(Collectors.toList());
+                            .filter(sm -> ObjectUtils.isNotEmpty(sm) && sm != 2).collect(Collectors.toList());
                     if (insProducts.size() == collect.size()) {
                         insFiber.setState(1);//宸叉楠�
                     } else {
@@ -363,7 +363,7 @@
                 for (InsFiber insFiber : insFiberList) {
                     List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getInsFiberId, insFiber.getId()));
                     List<Integer> collect = insProducts.stream().map(InsProduct::getInsResult)
-                            .filter(sm -> ObjectUtils.isNotEmpty(sm) && sm!=2).collect(Collectors.toList());
+                            .filter(sm -> ObjectUtils.isNotEmpty(sm) && sm != 2).collect(Collectors.toList());
                     if (insProducts.size() == collect.size()) {
                         insFiber.setState(1);//宸叉楠�
                     } else {
@@ -378,7 +378,7 @@
                         .eq(InsProduct::getInsBushId, insBushing.getId()));
                 List<Integer> collect = insProducts.stream()
                         .map(InsProduct::getInsResult)
-                        .filter(sm -> ObjectUtils.isNotEmpty(sm) && sm!=2).collect(Collectors.toList());
+                        .filter(sm -> ObjectUtils.isNotEmpty(sm) && sm != 2).collect(Collectors.toList());
                 if (insProducts.size() == collect.size()) {
                     insBushing.setState(1);//宸叉楠�
                 } else {
@@ -516,6 +516,7 @@
                 insProduct.setId(Integer.parseInt(k));
                 List<InsProductResult> results = insProductResultMapper.selectList(Wrappers.<InsProductResult>lambdaQuery()
                         .eq(InsProductResult::getInsProductId, insProduct.getId()));
+                InsProduct product = insProductMapper.selectById(insProduct.getId());
                 InsProductResult result;
                 if (CollectionUtils.isEmpty(results)) {
                     result = new InsProductResult();
@@ -621,7 +622,7 @@
 
                 /*濡傛灉鏄涓�娆¢�夋嫨璁惧淇℃伅,涓旇繕鏈夊叾浣欐牱鍝佷篃鏈夊悓涓�涓粡楠岄」鐩�,閭d箞鎵�鏈夋牱鍝佺殑璇ラ」鐩兘鐢ㄨ繖涓澶囦俊鎭�*/
                 //鍏堟煡璇㈡槸鍚﹁繕鏈夊叾浣欐牱鍝�
-                InsProduct product = insProductMapper.selectById(insProduct.getId());
+
                 Integer insSampleId = product.getInsSampleId();
                 List<InsSample> insSamples = insSampleMapper.selectList(Wrappers.<InsSample>lambdaQuery().eq(InsSample::getInsOrderId, insSampleMapper.selectById(insSampleId).getInsOrderId()));
                 if (insSamples.size() > 1 && !product.getInspectionItemType().equals("1")) {
@@ -636,9 +637,9 @@
                                 .eq(InsProduct::getInspectionItemSubclassEn, product.getInspectionItemSubclassEn())
                                 .eq(InsProduct::getTemplateId, product.getTemplateId())
                                 .eq(InsProduct::getStandardMethodListId, product.getStandardMethodListId())
-                                .eq(InsProduct::getInsBushId,product.getInsBushId())
-                                .eq(InsProduct::getInsFibersId,product.getInsFibersId())
-                                .eq(InsProduct::getInsFiberId,product.getInsFiberId())
+                                .eq(InsProduct::getInsBushId, product.getInsBushId())
+                                .eq(InsProduct::getInsFibersId, product.getInsFibersId())
+                                .eq(InsProduct::getInsFiberId, product.getInsFiberId())
                         );
                         if (ObjectUtils.isNotEmpty(product1)) {
                             //濡傛灉瀛樺湪椤圭洰,鏌ヨ鏄惁鏈夎〃
@@ -698,20 +699,30 @@
                             isWithinRange = !now.isBefore(startTime) || !now.isAfter(endTime);
                         }
                         //鍔犵彮
-                        AuxiliaryOutputWorkingHours count1 = auxiliaryOutputWorkingHoursMapper.selectOne(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery()
+                        List<AuxiliaryOutputWorkingHours> count1s = auxiliaryOutputWorkingHoursMapper.selectList(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery()
                                 .eq(AuxiliaryOutputWorkingHours::getCheck, userId)
                                 .eq(AuxiliaryOutputWorkingHours::getInspectionItem, insProduct.getInspectionItem())
                                 .eq(AuxiliaryOutputWorkingHours::getInspectionItemSubclass, insProduct.getInspectionItemSubclass())
                                 .eq(AuxiliaryOutputWorkingHours::getOvertimeOrderNo, insOrder.getEntrustCode())
                                 .eq(AuxiliaryOutputWorkingHours::getSample, insSampleMapper.selectById(insProduct.getInsSampleId()).getSampleCode()));
+                        if (count1s.size() > 1) {
+                            for (int i = 1; i < count1s.size(); i++) {
+                                auxiliaryOutputWorkingHoursMapper.deleteById(count1s.get(i));
+                            }
+                        }
                         //闈炲姞鐝�
-                        AuxiliaryOutputWorkingHours count2 = auxiliaryOutputWorkingHoursMapper.selectOne(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery()
+                        List<AuxiliaryOutputWorkingHours> count2s = auxiliaryOutputWorkingHoursMapper.selectList(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery()
                                 .eq(AuxiliaryOutputWorkingHours::getCheck, userId)
                                 .eq(AuxiliaryOutputWorkingHours::getInspectionItem, insProduct.getInspectionItem())
                                 .eq(AuxiliaryOutputWorkingHours::getInspectionItemSubclass, insProduct.getInspectionItemSubclass())
                                 .eq(AuxiliaryOutputWorkingHours::getOrderNo, insOrder.getEntrustCode())
                                 .eq(AuxiliaryOutputWorkingHours::getSample, insSampleMapper.selectById(insProduct.getInsSampleId()).getSampleCode()));
-                        if (ObjectUtils.isNotEmpty(insProduct.getManHour()) && ObjectUtils.isEmpty(count2) && ObjectUtils.isEmpty(count1)) {
+                        if (count2s.size() > 1) {
+                            for (int i = 1; i < count2s.size(); i++) {
+                                auxiliaryOutputWorkingHoursMapper.deleteById(count2s.get(i));
+                            }
+                        }
+                        if (ObjectUtils.isNotEmpty(insProduct.getManHour()) && CollectionUtils.isEmpty(count2s) && CollectionUtils.isEmpty(count1s)) {
                             AuxiliaryOutputWorkingHours auxiliaryOutputWorkingHours = new AuxiliaryOutputWorkingHours();
                             if (isWithinRange) {
                                 //鍦ㄦ椂闂村唴灏辨槸姝e父涓婄彮
@@ -3474,7 +3485,7 @@
                         put("createTime", now.format(DateTimeFormatter.ofPattern("yyyy骞碝M鏈坉d鏃�")));
                         put("createTimeEn", monthNames[now.getMonthValue() - 1] + " " + now.getDayOfMonth() + ", " + now.getYear());
                         put("insTime", insOrder.getInsTime().format(DateTimeFormatter.ofPattern("yyyy骞碝M鏈坉d鏃�")));
-                        put("insTimeEn", monthNames[insOrder.getInsTime().getMonthValue() - 1] + " " + now.getDayOfMonth() + ", " + now.getYear());
+                        put("insTimeEn", monthNames[insOrder.getInsTime().getMonthValue() - 1] + " " + insOrder.getInsTime().getDayOfMonth() + ", " + insOrder.getInsTime().getYear());
                         put("writeUrl", null);
                         put("insUrl", Pictures.ofLocal(imgUrl + "/" + signatureUrl).create());
                         put("images", images);
diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderServiceImpl.java
index 72267d5..18d7db4 100644
--- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderServiceImpl.java
+++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderServiceImpl.java
@@ -235,28 +235,28 @@
                             }
                         }
                         //閮戒负绌� 鍙厤缃簡濂楃 杩欑鎯呭喌鍙檺浜庨」鐩槸鍚湁鏉惧绠$殑
-//                        else {
-//                            String collect = a.getInsProduct().stream().map(InsProduct::getInspectionItem).distinct().collect(Collectors.joining(","));
-//                            if (collect.contains("鏉惧绠�")){
-//                                //鑾峰彇妫�楠岄」鐩腑鍖呭惈鏉惧绠$殑妫�楠岄」鐩�
-//                                List<InsProduct> products = a.getInsProduct().stream().filter(insProduct -> insProduct.getInspectionItem().contains("鏉惧绠�")).collect(Collectors.toList());
-//                                for (InsProduct product : products) {
-//                                    product.setInsBushId(bushingDto.getId());
-//                                    product.setId(null);
-//                                    product.setCreateTime(null);
-//                                    product.setCreateUser(null);
-//                                    product.setUpdateTime(null);
-//                                    product.setUpdateUser(null);
-//                                    product.setInsSampleId(a.getId());
-//                                    if (product.getInspectionItemSubclass() == null) {
-//                                        product.setInspectionItemSubclass("");
-//                                    }
-//                                    insProductMapper.insert(product);
-//                                }
-//                            }else {
-//                                throw new ErrorException("鏍峰搧鐨勫厜绾ら厤缃俊鎭噷闈㈡病鏈夐厤缃厜绾ゅ甫淇℃伅涔熸病鏈夊厜绾や俊鎭�,璇烽噸鏂伴厤缃繚瀛樺啀鎻愪氦涓嬪崟!!!");
-//                            }
-//                        }
+                        else {
+                            String collect = a.getInsProduct().stream().map(InsProduct::getInspectionItem).distinct().collect(Collectors.joining(","));
+                            if (collect.contains("鏉惧绠�")){
+                                //鑾峰彇妫�楠岄」鐩腑鍖呭惈鏉惧绠$殑妫�楠岄」鐩�
+                                List<InsProduct> products = a.getInsProduct().stream().filter(insProduct -> insProduct.getInspectionItem().contains("鏉惧绠�")).collect(Collectors.toList());
+                                for (InsProduct product : products) {
+                                    product.setInsBushId(bushingDto.getId());
+                                    product.setId(null);
+                                    product.setCreateTime(null);
+                                    product.setCreateUser(null);
+                                    product.setUpdateTime(null);
+                                    product.setUpdateUser(null);
+                                    product.setInsSampleId(a.getId());
+                                    if (product.getInspectionItemSubclass() == null) {
+                                        product.setInspectionItemSubclass("");
+                                    }
+                                    insProductMapper.insert(product);
+                                }
+                            }else {
+                                throw new ErrorException("鏍峰搧鐨勫厜绾ら厤缃俊鎭噷闈㈡病鏈夐厤缃厜绾ゅ甫淇℃伅涔熸病鏈夊厜绾や俊鎭�,璇烽噸鏂伴厤缃繚瀛樺啀鎻愪氦涓嬪崟!!!");
+                            }
+                        }
                     }
                 }
             }
@@ -340,9 +340,9 @@
         InsOrder insOrder = insOrderMapper.selectById(insSampleMapper.selectById(sampleId).getInsOrderId());
         String name = insSampleMapper.selMethodById(sampleId);
         for (InsProduct product : productList) {
-//            if (product.getInspectionItem().contains("鏉惧绠�")){
-//                continue;
-//            }
+            if (product.getInspectionItem().contains("鏉惧绠�")){
+                continue;
+            }
             if (product.getState() == 1 && !product.getInspectionItem().equals("鍏夌氦鎺ュご鎹熻��")) {
                 //鍒ゆ柇鍏夌紗鐨勬俯搴﹀惊鐜」鐩坊鍔�
                 if (insOrder.getSampleType().equals("鍏夌紗") && product.getInspectionItem().equals("娓╁害寰幆") && type != 0) {
diff --git a/inspect-server/src/main/resources/static/report-template.docx b/inspect-server/src/main/resources/static/report-template.docx
index 4a6e506..2f54031 100644
--- a/inspect-server/src/main/resources/static/report-template.docx
+++ b/inspect-server/src/main/resources/static/report-template.docx
Binary files differ

--
Gitblit v1.9.3