From 3ae364164cb9d85acce0b53a1ba5c70a80991308 Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期三, 03 七月 2024 22:21:49 +0800
Subject: [PATCH] 温度循环+报告英文换行+检验只有一项的设备查询+光纤配置报告换页+温度湿度

---
 inspect-server/src/main/resources/mapper/InsSampleMapper.xml                                  |   32 ++
 inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java        |  529 +++++++++++++++++++++++++++-------------
 inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderServiceImpl.java            |  106 +++++--
 performance-server/src/main/resources/mapper/AuxiliaryOutputWorkingHoursMapper.xml            |    2 
 cnas-server/src/main/java/com/yuanchu/mom/service/impl/DeviceServiceImpl.java                 |   18 +
 inspect-server/src/main/java/com/yuanchu/mom/vo/ProductVo.java                                |   22 +
 inspect-server/src/main/java/com/yuanchu/mom/service/impl/StandardProductListServiceImpl.java |    4 
 performance-server/src/main/resources/mapper/AuxiliaryCorrectionHoursMapper.xml               |    4 
 inspect-server/src/main/java/com/yuanchu/mom/mapper/InsSampleMapper.java                      |    3 
 performance-server/src/main/resources/mapper/AuxiliaryWorkingHoursDayMapper.xml               |    4 
 inspect-server/src/main/resources/static/report-template.docx                                 |    0 
 inspect-server/src/main/java/com/yuanchu/mom/vo/SampleVo.java                                 |   13 +
 inspect-server/src/main/java/com/yuanchu/mom/controller/InsOrderPlanController.java           |    7 
 inspect-server/src/main/java/com/yuanchu/mom/service/InsOrderPlanService.java                 |    1 
 14 files changed, 532 insertions(+), 213 deletions(-)

diff --git a/cnas-server/src/main/java/com/yuanchu/mom/service/impl/DeviceServiceImpl.java b/cnas-server/src/main/java/com/yuanchu/mom/service/impl/DeviceServiceImpl.java
index 786bd65..1a4aa31 100644
--- a/cnas-server/src/main/java/com/yuanchu/mom/service/impl/DeviceServiceImpl.java
+++ b/cnas-server/src/main/java/com/yuanchu/mom/service/impl/DeviceServiceImpl.java
@@ -1,6 +1,7 @@
 package com.yuanchu.mom.service.impl;
 
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -85,16 +86,27 @@
     public List<Device> selectDeviceByCategory(String inspectionItem, String inspectionItemSubclass) {
         Integer id;
         try {
-            id = structureItemParameterMapper.selectOne(Wrappers.<StructureItemParameter>lambdaQuery().eq(StructureItemParameter::getInspectionItem, inspectionItem).eq(StructureItemParameter::getInspectionItemSubclass, inspectionItemSubclass).last("limit 1").select(StructureItemParameter::getId)).getId();
+            if (ObjectUtils.isEmpty(inspectionItemSubclass)) {
+                id = structureItemParameterMapper.selectOne(Wrappers.<StructureItemParameter>lambdaQuery()
+                        .eq(StructureItemParameter::getInspectionItem, inspectionItem)
+                        .last("limit 1").select(StructureItemParameter::getId)).getId();
+            }else {
+                id = structureItemParameterMapper.selectOne(Wrappers.<StructureItemParameter>lambdaQuery()
+                        .eq(StructureItemParameter::getInspectionItem, inspectionItem)
+                        .eq(StructureItemParameter::getInspectionItemSubclass, inspectionItemSubclass)
+                        .last("limit 1").select(StructureItemParameter::getId)).getId();
+            }
         } catch (Exception e) {
             return null;
         }
-        List<Device> devices = deviceMapper.selectList(Wrappers.<Device>lambdaQuery().eq(Device::getDeviceStatus, 0).isNotNull(Device::getInsProductIds));
+        List<Device> devices = deviceMapper.selectList(Wrappers.<Device>lambdaQuery()
+                .eq(Device::getDeviceStatus, 0)
+                .isNotNull(Device::getInsProductIds));
         List<Device> devices2 = new ArrayList<>();
         for (Device device : devices) {
             String[] ids = device.getInsProductIds().split(",");
             for (String i : ids) {
-                if (i.equals(id+"")) {
+                if (i.equals(id + "")) {
                     devices2.add(device);
                     break;
                 }
diff --git a/inspect-server/src/main/java/com/yuanchu/mom/controller/InsOrderPlanController.java b/inspect-server/src/main/java/com/yuanchu/mom/controller/InsOrderPlanController.java
index f357a50..406831b 100644
--- a/inspect-server/src/main/java/com/yuanchu/mom/controller/InsOrderPlanController.java
+++ b/inspect-server/src/main/java/com/yuanchu/mom/controller/InsOrderPlanController.java
@@ -167,4 +167,11 @@
     public Result<?> write(@RequestBody InsProductDto insProductDto) {
         return Result.success(insProductService.write(insProductDto));
     }
+
+    @ValueAuth
+    @ApiOperation(value = "娓╁害寰幆鏌ョ湅鍒楄〃鏁版嵁(鍖呮嫭閫氳繃鏍峰搧id,寰幆娆℃暟,娓╁害,寰幆娆℃暟杩涜绛涢��)")
+    @PostMapping("/temCycle")
+    public Result<?> temCycle(Integer sampleId, String inspectionItem, String inspectionItemSubclass) {
+        return Result.success(insOrderPlanService.temCycle(sampleId, inspectionItem, inspectionItemSubclass));
+    }
 }
diff --git a/inspect-server/src/main/java/com/yuanchu/mom/mapper/InsSampleMapper.java b/inspect-server/src/main/java/com/yuanchu/mom/mapper/InsSampleMapper.java
index 1c01c2d..69723bd 100644
--- a/inspect-server/src/main/java/com/yuanchu/mom/mapper/InsSampleMapper.java
+++ b/inspect-server/src/main/java/com/yuanchu/mom/mapper/InsSampleMapper.java
@@ -11,6 +11,7 @@
 import com.yuanchu.mom.pojo.InsSample;
 import com.yuanchu.mom.vo.InsOrderPlanTaskSwitchVo;
 import com.yuanchu.mom.vo.InsOrderPlanVO;
+import com.yuanchu.mom.vo.SampleVo;
 import org.apache.ibatis.annotations.Param;
 
 import java.util.List;
@@ -45,6 +46,8 @@
     List<InsProduct> getInsProduct3(Integer id);
 
     List<Map<String, Object>> getReportModel(@Param("orderId") Integer orderId, @Param("id") Integer id, @Param("laboratory") String laboratory);
+
+    SampleVo getDetailById(Integer sampleId);
 }
 
 
diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/InsOrderPlanService.java b/inspect-server/src/main/java/com/yuanchu/mom/service/InsOrderPlanService.java
index 8d2d2ef..cacd4cc 100644
--- a/inspect-server/src/main/java/com/yuanchu/mom/service/InsOrderPlanService.java
+++ b/inspect-server/src/main/java/com/yuanchu/mom/service/InsOrderPlanService.java
@@ -40,4 +40,5 @@
 
     Map<String,Object> getReportModel(Integer sampleId);
 
+    Map<String,Object> temCycle(Integer sampleId, String inspectionItem, String inspectionItemSubclass);
 }
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 1944a41..1e188a4 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
@@ -35,6 +35,8 @@
 import com.yuanchu.mom.utils.QueryWrappers;
 import com.yuanchu.mom.vo.InsOrderPlanTaskSwitchVo;
 import com.yuanchu.mom.vo.InsOrderPlanVO;
+import com.yuanchu.mom.vo.ProductVo;
+import com.yuanchu.mom.vo.SampleVo;
 import org.apache.commons.io.IOUtils;
 import org.apache.poi.xwpf.usermodel.*;
 import org.springframework.beans.factory.annotation.Value;
@@ -270,7 +272,6 @@
     @Override
     public Map<String, Object> getReportModel(Integer sampleId) {
         Map<String, Object> map = new HashMap<>();
-        //List<Integer> insSampleIds = insSampleMapper.selectList(Wrappers.<InsSample>lambdaQuery().eq(InsSample::getInsOrderId, orderId)).stream().map(InsSample::getId).collect(Collectors.toList());
         //鍏堟煡鍑哄绠�
         List<InsBushing> insBushings = insBushingMapper.selectList(Wrappers.<InsBushing>lambdaQuery().eq(InsBushing::getInsSampleId, sampleId));
         List<InsFibers> fibers = new ArrayList<>();
@@ -289,12 +290,76 @@
                 fiber.addAll(insFiberList);
             }
         }
-        map.put("鍏夌氦甯�",fibers);
-        map.put("鍏夌氦",fiber);
+        map.put("鍏夌氦甯�", fibers);
+        map.put("鍏夌氦", fiber);
         return map;
     }
 
-
+    //娓╁害寰幆鏌ョ湅鍒楄〃鏁版嵁(鍖呮嫭閫氳繃鏍峰搧id,寰幆娆℃暟,娓╁害,寰幆娆℃暟杩涜绛涢��)
+    @Override
+    public Map<String, Object> temCycle(Integer sampleId, String inspectionItem, String inspectionItemSubclass) {
+        Map<String, Object> map = new HashMap<>();
+        //鏍峰搧淇℃伅
+        SampleVo sampleVo = insSampleMapper.getDetailById(sampleId);
+        map.put("sampleVo", sampleVo);
+        List<ProductVo> productVos = new ArrayList<>();
+        //鍏堟煡鍑鸿繖涓牱鍝佷笅鏈夊摢浜涚鑹叉爣,鍏夌氦甯�,鍏夌氦鑹叉爣
+        //鍏堟煡鍑哄绠�
+        List<InsBushing> insBushings = insBushingMapper.selectList(Wrappers.<InsBushing>lambdaQuery().eq(InsBushing::getInsSampleId, sampleId));
+        for (InsBushing insBushing : insBushings) {
+            //鍐嶆煡璇㈠嚭鎵�鏈夌殑鍏夌氦甯�
+            List<InsFibers> insFibers = insFibersMapper.selectList(Wrappers.<InsFibers>lambdaQuery().eq(InsFibers::getInsBushingId, insBushing.getId()));
+            if (CollectionUtils.isNotEmpty(insFibers)) {
+                for (InsFibers insFiber : insFibers) {
+                    //鏌ュ嚭鍏夌氦甯︿笅鎵�鏈夌殑鍏夌氦
+                    List<InsFiber> fiberList = insFiberMapper.selectList(Wrappers.<InsFiber>lambdaQuery().eq(InsFiber::getInsFibersId, insFiber.getId()));
+                    for (InsFiber fiber : fiberList) {
+                        //鍐嶆牴鎹叧鑱旂殑鍏夌氦閰嶇疆鐨刬d鍜屽惊鐜鏁板拰娓╁害鍜屾牱鍝乮d杩涜鏌ヨ妫�楠岄」鐩�
+                        List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery()
+                                .eq(InsProduct::getInsSampleId, sampleId)
+                                .eq(InsProduct::getInspectionItem, inspectionItem)
+                                .eq(InsProduct::getInspectionItemSubclass, inspectionItemSubclass)
+                                .eq(InsProduct::getInsFiberId, fiber.getId()));
+                        for (InsProduct insProduct : insProducts) {
+                            InsProductResult insProductResult = insProductResultMapper.selectOne(Wrappers.<InsProductResult>lambdaQuery().eq(InsProductResult::getInsProductId, insProduct.getId()));
+                            ProductVo productVo = new ProductVo();
+                            productVo.setCode(insFiber.getCode());
+                            productVo.setColor(fiber.getColor());
+                            productVo.setBushColor(fiber.getBushColor());
+                            if (ObjectUtils.isNotEmpty(insProductResult)) {
+                                insProduct.setInsProductResult(insProductResult);
+                            }
+                            productVo.setInsProduct(insProduct);
+                            productVos.add(productVo);
+                        }
+                    }
+                }
+            } else {
+                //濡傛灉濂楃涓嬫病鏈夊厜绾ゅ甫灏卞彧鏈夊厜绾や簡
+                List<InsFiber> insFiberList = insFiberMapper.selectList(Wrappers.<InsFiber>lambdaQuery().eq(InsFiber::getInsBushingId, insBushing.getId()));
+                for (InsFiber fiber : insFiberList) {
+                    //鍐嶆牴鎹叧鑱旂殑鍏夌氦閰嶇疆鐨刬d鍜屽惊鐜鏁板拰娓╁害鍜屾牱鍝乮d杩涜鏌ヨ妫�楠岄」鐩�
+                    List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery()
+                            .eq(InsProduct::getInsSampleId, sampleId)
+                            .eq(InsProduct::getInspectionItem, inspectionItem)
+                            .eq(InsProduct::getInspectionItemSubclass, inspectionItemSubclass)
+                            .eq(InsProduct::getInsFiberId, fiber.getId()));
+                    for (InsProduct insProduct : insProducts) {
+                        InsProductResult insProductResult = insProductResultMapper.selectOne(Wrappers.<InsProductResult>lambdaQuery().eq(InsProductResult::getInsProductId, insProduct.getId()));
+                        ProductVo productVo = new ProductVo();
+                        productVo.setCode("/");
+                        productVo.setColor(fiber.getColor());
+                        productVo.setBushColor(fiber.getBushColor());
+                        insProduct.setInsProductResult(insProductResult);
+                        productVo.setInsProduct(insProduct);
+                        productVos.add(productVo);
+                    }
+                }
+            }
+        }
+        map.put("productVos", productVos);
+        return map;
+    }
 
 
     @Override
@@ -556,6 +621,30 @@
                     Set<String> delSet = new HashSet<>();
                     List<ExcelDto> excelDtos = JSON.parseArray(tem, ExcelDto.class);
                     List<ExcelDto> mcList = new ArrayList<>();
+                   /* int aaaa = excelDtos.get(excelDtos.size() - 1).getR();//杩欓噷鏄ā鐗堥噷闈㈢殑鎵�鏈夋娴嬮」鐨勯暱搴�,鍏堜互15涓」鐩垎椤�
+                    int bbbb = 17;
+                    int cccc = 0;
+                    for (int p = 0; p < aaaa; p++) {
+                        if (p % bbbb == 0) {
+                            for (int y = 0; y < excelDtos.size(); y++) {
+                                if (y == 0 || y == 1) {
+                                    if (excelDtos.get(y).getV().getMc() != null && excelDtos.get(y).getV().getMc().getCs() != null && excelDtos.get(y).getV().getMc().getRs() != null) {
+                                        mcList.add(excelDtos.get(y));
+                                    }
+                                } else {
+                                    try {
+                                        excelDtos.get(y + cccc - 2);
+                                    } catch (Exception e) {
+                                        continue;
+                                    }
+                                    if (excelDtos.get(y + cccc - 2).getV().getMc() != null && excelDtos.get(y + cccc - 2).getV().getMc().getCs() != null && excelDtos.get(y + cccc - 2).getV().getMc().getRs() != null) {
+                                        mcList.add(excelDtos.get(y + cccc - 2));
+                                    }
+                                }
+                            }
+                            cccc += 17;
+                        }
+                    }*/
                     excelDtos.forEach(b -> {
                         if (b.getV().getMc() != null && b.getV().getMc().getCs() != null && b.getV().getMc().getRs() != null) {
                             mcList.add(b);
@@ -689,12 +778,12 @@
                             } else if (value.equals("璇曢獙鏂规硶")) {
                                 textRenderData.setText(p.getMethodS());
                             } else if (value.equals("妫�楠岄」")) {
-                                textRenderData.setText(p.getInspectionItem() + "\r\n" + p.getInspectionItemEn());
+                                textRenderData.setText(p.getInspectionItem() + "&" + p.getInspectionItemEn());
                             } else if (value.equals("妫�楠屽瓙椤�")) {
                                 if (ObjectUtils.isEmpty(p.getInspectionItemSubclassEn())) {
                                     textRenderData.setText(p.getInspectionItemSubclass());
                                 } else {
-                                    textRenderData.setText(p.getInspectionItemSubclass() + "\r\n" + p.getInspectionItemSubclassEn());
+                                    textRenderData.setText(p.getInspectionItemSubclass() + "&" + p.getInspectionItemSubclassEn());
                                 }
                             } else {
                                 textRenderData.setText(v.get("v") == null ? "" : v.get("v") + "");
@@ -853,174 +942,211 @@
                     List<InsProduct> insProducts1 = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery()
                             .eq(InsProduct::getState, 1)
                             .eq(InsProduct::getInsSampleId, sample.getId())
-                            .isNotNull(InsProduct::getInsFiberId));
-                    long size = insProducts1.size();
+                            .isNotNull(InsProduct::getInsFiberId)
+                            .isNull(InsProduct::getInspectionItemClass));
+                    List<InsProduct> filteredProducts = insProducts1.stream()
+                            .collect(Collectors.groupingBy(product -> product.getInspectionItem() + product.getInspectionItemSubclass()))
+                            .values().stream()
+                            .map(group -> group.get(0))
+                            .sorted(Comparator.comparing(InsProduct::getInspectionItem))
+                            .collect(Collectors.toList());
+                    long size = insProducts1.stream().map(insProduct -> {
+                        return (insProduct.getInspectionItem() + insProduct.getInspectionItemSubclass());
+                    }).distinct().collect(Collectors.toList()).size();
                     long size2 = insProducts1.stream().map(InsProduct::getInsFiberId).distinct().count();
-                    List<RowRenderData> rows = new ArrayList<>();
-                    //鍒ゆ柇妫�楠岄」鐩槸鍚︽湁鐖跺瓙鍏崇郴
-                    Boolean state = true;
-                    for (InsProduct insProduct : insProducts1) {
-                        if (!insProduct.getInspectionItemSubclass().equals("") && insProduct.getInspectionItemSubclass() != null) {
-                            state = false;
-                        }
-                    }
-                    int a = 1;
-                    if (!state) {
-                        a = 2;
-                    }
-                    //琛ㄦ牸鐨勮鏁�
-                    for (long i = 0; i < size2 + a; i++) {
-                        RowRenderData rowRenderData = new RowRenderData();
-
-                        RowStyle rowStyle = new RowStyle();
-                        rowStyle.setHeight(40);
-                        rowRenderData.setRowStyle(rowStyle);
-                        List<CellRenderData> cells = new ArrayList<>();
-                        //琛ㄦ牸鐨勫垪鏁�
-                        for (long j = 0; j < size + 2; j++) {
-                            CellRenderData cellRenderData = new CellRenderData();
-                            CellStyle cellStyle = new CellStyle();
-                            cellStyle.setVertAlign(XWPFTableCell.XWPFVertAlign.CENTER);
-                            cellRenderData.setCellStyle(cellStyle);
-                            List<ParagraphRenderData> paragraphRenderDataList = new ArrayList<>();
-                            ParagraphRenderData paragraphRenderData = new ParagraphRenderData();
-                            ParagraphStyle paragraphStyle = new ParagraphStyle();
-                            paragraphStyle.setAlign(ParagraphAlignment.CENTER);
-                            paragraphRenderData.setParagraphStyle(paragraphStyle);
-                            List<RenderData> renderData = new ArrayList<>();
-                            TextRenderData textRenderData = new TextRenderData();
-                            Style style = new Style();
-                            style.setFontFamily("瀹嬩綋");
-                            style.setColor("000000");
-                            textRenderData.setStyle(style);
-                            if (i == 0) {
-                                //绗竴琛�
-                                if (j == 0) {
-                                    //绗竴鍒�
-                                    textRenderData.setText("绠¤壊鏍嘰r\nPipe鈭�100");
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
-                                } else if (j == 1) {
-                                    //绗簩鍒�
-                                    textRenderData.setText("鍏夌氦鑹叉爣\r\nScanning Number鈭�101");
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
-                                } else {
-                                    //椤圭洰淇℃伅
-                                    textRenderData.setText(insProducts1.get((int) (j - 2)).getInspectionItem() + "\r\n" + insProducts1.get((int) (j - 2)).getInspectionItemEn() + "鈭�" + (j + 101));
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
-                                }
-                            } else if (a == 2 && i == 1) {
-                                //鏈夌埗瀛愰」鐩叧绯荤殑绗笁琛�
-                                if (j == 0) {
-                                    //绗竴鍒�
-                                    textRenderData.setText("绠¤壊鏍嘰r\nPipe鈭�100");
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
-                                } else if (j == 1) {
-                                    //绗簩鍒�
-                                    textRenderData.setText("鍏夌氦鑹叉爣\r\nScanning Number鈭�101");
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
-                                } else {
-                                    //椤圭洰淇℃伅
-                                    //鍒ゆ柇鏄惁鏈夐」鐩瓙绫�
-                                    if (insProducts1.get((int) (j - 2)).getInspectionItemSubclass().equals("") || insProducts1.get((int) (j - 2)).getInspectionItemSubclass() == null) {
-                                        textRenderData.setText(insProducts1.get((int) (j - 2)).getInspectionItem() + "\r\n" + insProducts1.get((int) (j - 2)).getInspectionItemEn() + "鈭�" + (j + 101));
-                                    } else {
-                                        textRenderData.setText(insProducts1.get((int) (j - 2)).getInspectionItemSubclass() + "\r\n" + insProducts1.get((int) (j - 2)).getInspectionItemSubclassEn());
-                                    }
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
-                                }
-                            } else {
-                                int aa = 0;
-                                if (a == 2) {
-                                    aa = (int) i - 2;
-                                } else aa = (int) i - 1;
-                                InsFiber insFiber = insFiberMapper.selectById(insProducts1.get(aa).getInsFiberId());
-                                //濉��
-                                if (j == 0) {
-                                    //绗竴鍒�
-                                    textRenderData.setText(insFiber.getBushColor());
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
-                                } else if (j == 1) {
-                                    //绗簩鍒�
-                                    textRenderData.setText(insFiber.getColor());
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
-                                } else {
-                                    //椤圭洰淇℃伅
-                                    textRenderData.setText(insProducts1.get((int) (j - 2)).getLastValue());
-                                    renderData.add(textRenderData);
-                                    paragraphRenderData.setContents(renderData);
-                                    paragraphRenderDataList.add(paragraphRenderData);
-                                    cellRenderData.setParagraphs(paragraphRenderDataList);
-                                    cells.add(cellRenderData);
+                    long number = 7;
+                    long k = 0;
+                    for (long c = 0; c < size; c++) {
+                        if (c % number == 0) {
+                            List<RowRenderData> rows = new ArrayList<>();
+                            //鍒ゆ柇妫�楠岄」鐩槸鍚︽湁鐖跺瓙鍏崇郴
+                            Boolean state = true;
+                            for (InsProduct insProduct : filteredProducts) {
+                                if (!insProduct.getInspectionItemSubclass().equals("") && insProduct.getInspectionItemSubclass() != null) {
+                                    state = false;
                                 }
                             }
-                        }
-                        rowRenderData.setCells(cells);
-                        if (rowRenderData.getCells().size() != 0) {
-                            rows.add(rowRenderData);
+                            int a = 1;
+                            if (!state) {
+                                a = 2;
+                            }
+                            //琛ㄦ牸鐨勮鏁�
+                            for (long i = 0; i < size2 + a; i++) {
+                                RowRenderData rowRenderData = new RowRenderData();
+
+                                RowStyle rowStyle = new RowStyle();
+                                rowStyle.setHeight(40);
+                                rowRenderData.setRowStyle(rowStyle);
+                                List<CellRenderData> cells = new ArrayList<>();
+                                //琛ㄦ牸鐨勫垪鏁�
+                                for (long j = 0; j < 9; j++) {
+                                    CellRenderData cellRenderData = new CellRenderData();
+                                    CellStyle cellStyle = new CellStyle();
+                                    cellStyle.setVertAlign(XWPFTableCell.XWPFVertAlign.CENTER);
+                                    cellRenderData.setCellStyle(cellStyle);
+                                    List<ParagraphRenderData> paragraphRenderDataList = new ArrayList<>();
+                                    ParagraphRenderData paragraphRenderData = new ParagraphRenderData();
+                                    ParagraphStyle paragraphStyle = new ParagraphStyle();
+                                    paragraphStyle.setAlign(ParagraphAlignment.CENTER);
+                                    paragraphRenderData.setParagraphStyle(paragraphStyle);
+                                    List<RenderData> renderData = new ArrayList<>();
+                                    TextRenderData textRenderData = new TextRenderData();
+                                    Style style = new Style();
+                                    style.setFontFamily("瀹嬩綋");
+                                    style.setColor("000000");
+                                    textRenderData.setStyle(style);
+                                    if (i == 0) {
+                                        //绗竴琛�
+                                        if (j == 0) {
+                                            //绗竴鍒�
+                                            textRenderData.setText("绠¤壊鏍�&Pipe鈭�100");
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        } else if (j == 1) {
+                                            //绗簩鍒�
+                                            textRenderData.setText("鍏夌氦鑹叉爣&Scanning Number鈭�101");
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        } else {
+                                            //椤圭洰淇℃伅
+                                            try {
+                                                filteredProducts.get((int) (j - 2 + k));
+                                            } catch (Exception e) {
+                                                continue;
+                                            }
+                                            textRenderData.setText(filteredProducts.get((int) (j - 2 + k)).getInspectionItem() + "&" + insProducts1.get((int) (j - 2 + k)).getInspectionItemEn() + "鈭�" + (j + 101 + k));
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        }
+                                    } else if (a == 2 && i == 1) {
+                                        //鏈夌埗瀛愰」鐩叧绯荤殑绗笁琛�
+                                        if (j == 0) {
+                                            //绗竴鍒�
+                                            textRenderData.setText("绠¤壊鏍�&Pipe鈭�100");
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        } else if (j == 1) {
+                                            //绗簩鍒�
+                                            textRenderData.setText("鍏夌氦鑹叉爣&Scanning Number鈭�101");
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        } else {
+                                            //椤圭洰淇℃伅
+                                            try {
+                                                filteredProducts.get((int) (j - 2 + k));
+                                            } catch (Exception e) {
+                                                continue;
+                                            }
+                                            //鍒ゆ柇鏄惁鏈夐」鐩瓙绫�
+                                            if (filteredProducts.get((int) (j - 2 + k)).getInspectionItemSubclass().equals("") || filteredProducts.get((int) (j - 2 + k)).getInspectionItemSubclass() == null) {
+                                                textRenderData.setText(filteredProducts.get((int) (j - 2 + k)).getInspectionItem() + "&" + filteredProducts.get((int) (j - 2 + k)).getInspectionItemEn() + "鈭�" + (j + 101 + k));
+                                            } else {
+                                                textRenderData.setText(filteredProducts.get((int) (j - 2 + k)).getInspectionItemSubclass() + "&" + filteredProducts.get((int) (j - 2 + k)).getInspectionItemSubclassEn());
+                                            }
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        }
+                                    } else {
+                                        int aa;
+                                        if (a == 2) {
+                                            aa = (int) i - 2;
+                                        } else aa = (int) i - 1;
+                                        List<Integer> list = insProducts1.stream().map(InsProduct::getInsFiberId).distinct().collect(Collectors.toList());
+                                        try {
+                                            insFiberMapper.selectById(list.get(aa));
+                                        } catch (Exception e) {
+                                            continue;
+                                        }
+                                        InsFiber insFiber = insFiberMapper.selectById(list.get(aa));
+                                        //濉��
+                                        if (j == 0) {
+                                            //绗竴鍒�
+                                            textRenderData.setText(insFiber.getBushColor());
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        } else if (j == 1) {
+                                            //绗簩鍒�
+                                            textRenderData.setText(insFiber.getColor());
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        } else {
+                                            //椤圭洰淇℃伅
+                                            try {
+                                                filteredProducts.get((int) (j - 2 + k));
+                                            } catch (Exception e) {
+                                                continue;
+                                            }
+                                            textRenderData.setText(filteredProducts.get((int) (j - 2 + k)).getLastValue());
+                                            renderData.add(textRenderData);
+                                            paragraphRenderData.setContents(renderData);
+                                            paragraphRenderDataList.add(paragraphRenderData);
+                                            cellRenderData.setParagraphs(paragraphRenderDataList);
+                                            cells.add(cellRenderData);
+                                        }
+                                    }
+                                }
+                                rowRenderData.setCells(cells);
+                                if (rowRenderData.getCells().size() != 0) {
+                                    rows.add(rowRenderData);
+                                }
+                            }
+                            TableRenderData tableRenderData = new TableRenderData();
+                            tableRenderData.setRows(rows);
+                            int countSize = tableRenderData.getRows().get(0).getCells().size();
+                            for (RowRenderData row : tableRenderData.getRows()) {
+                                for (CellRenderData cell : row.getCells()) {
+                                    System.out.print(cell.getParagraphs().get(0).getContents());
+                                }
+                                System.out.println("");
+                                if (row.getCells().size() != countSize) {
+                                    throw new ErrorException("姣忚鍗曞厓鏍间笉鐩哥瓑");
+                                }
+                            }
+                            TableStyle tableStyle = new TableStyle();
+                            tableStyle.setWidth(XWPFTable.DEFAULT_PERCENTAGE_WIDTH);
+                            tableStyle.setAlign(TableRowAlign.CENTER);
+                            BorderStyle borderStyle = new BorderStyle();
+                            borderStyle.setColor("000000");
+                            borderStyle.setType(XWPFTable.XWPFBorderType.THICK);
+                            borderStyle.setSize(14);
+                            tableStyle.setLeftBorder(borderStyle);
+                            tableStyle.setTopBorder(borderStyle);
+                            tableStyle.setRightBorder(borderStyle);
+                            tableStyle.setBottomBorder(borderStyle);
+                            tableRenderData.setTableStyle(tableStyle);
+                            Map<String, Object> table = new HashMap<>();
+                            table.put("table2", tableRenderData);
+                            table.put("report", insReport);
+                            table.put("sample_number", sample.getSampleCode());
+                            table.put("type", sample.getModel());
+                            tables2.add(table);
+                            k += 7;
                         }
                     }
-                    TableRenderData tableRenderData = new TableRenderData();
-                    tableRenderData.setRows(rows);
-                    int countSize = tableRenderData.getRows().get(0).getCells().size();
-                    for (RowRenderData row : tableRenderData.getRows()) {
-                        /*for (CellRenderData cell : row.getCells()) {
-                            System.out.print(cell.getParagraphs().get(0).getContents());
-                        }
-                        System.out.println("");*/
-                        if (row.getCells().size() != countSize) {
-                            throw new ErrorException("姣忚鍗曞厓鏍间笉鐩哥瓑");
-                        }
-                    }
-                    TableStyle tableStyle = new TableStyle();
-                    tableStyle.setWidth(XWPFTable.DEFAULT_PERCENTAGE_WIDTH);
-                    tableStyle.setAlign(TableRowAlign.CENTER);
-                    BorderStyle borderStyle = new BorderStyle();
-                    borderStyle.setColor("000000");
-                    borderStyle.setType(XWPFTable.XWPFBorderType.THICK);
-                    borderStyle.setSize(14);
-                    tableStyle.setLeftBorder(borderStyle);
-                    tableStyle.setTopBorder(borderStyle);
-                    tableStyle.setRightBorder(borderStyle);
-                    tableStyle.setBottomBorder(borderStyle);
-                    tableRenderData.setTableStyle(tableStyle);
-                    Map<String, Object> table = new HashMap<>();
-                    table.put("table2", tableRenderData);
-                    table.put("report", insReport);
-                    table.put("sample_number", sample.getSampleCode());
-                    table.put("type", sample.getModel());
-                    tables2.add(table);
                 });
             }
 
@@ -1043,12 +1169,16 @@
             if (ObjectUtils.isEmpty(insOrder.getPhone())) {
                 insOrder.setPhone("/");
             }
-
+            //妫�楠岄」鐩殑鐜
+            InsProduct insProduct = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).eq(InsProduct::getInsSampleId, samples.get(0).getId())).get(0);
+            String environment = "";
+            environment = (ObjectUtils.isNotEmpty(insProduct.getTemperature()) ? insProduct.getTemperature() + "鈩� " : "") + (ObjectUtils.isNotEmpty(insProduct.getHumidity()) ? insProduct.getHumidity() + "%" : "");
+            String finalEnvironment = environment;
             XWPFTemplate template = XWPFTemplate.compile(url, builder.build()).render(
                     new HashMap<String, Object>() {{
                         put("order", insOrder);
                         put("report", insReport);
-                        //put("user", user);
+                        put("environment", finalEnvironment);
                         put("custom", custom);
                         put("sampleSize", samples.size());
                         put("tables", tables);
@@ -1089,6 +1219,7 @@
             } catch (IOException e) {
                 throw new RuntimeException(e);
             }
+            //澶勭悊鍚堝苟鍗曞厓鏍肩殑闂
             String path = wordUrl + "/" + insReport.getCode().replace("/", "") + ".docx";
             try {
                 FileInputStream stream = new FileInputStream(path);
@@ -1148,11 +1279,45 @@
             } catch (IOException e) {
                 throw new RuntimeException(e);
             }
+            try {
+                FileInputStream stream1 = new FileInputStream(path);
+                XWPFDocument document1 = new XWPFDocument(stream1);
+                List<XWPFTable> xwpfTables1 = document1.getTables();
+                //澶勭悊涓嫳鏂囨崲琛岀殑闂
+                for (int i = 1; i < xwpfTables1.size() - (deviceList == null ? 1 : 2); i++) {
+                    for (int j = 0; j < xwpfTables1.get(i).getRows().size(); j++) {
+                        for (int k = 0; k < xwpfTables1.get(i).getRows().get(j).getTableCells().size(); k++) {
+                            if (xwpfTables1.get(i).getRows().get(j).getTableCells().get(k).getText().contains("&")) {
+                                String text = xwpfTables1.get(i).getRows().get(j).getTableCells().get(k).getText();
+                                String[] split = text.split("&");
+                                xwpfTables1.get(i).getRows().get(j).getTableCells().get(k).removeParagraph(0);
+                                XWPFParagraph xwpfParagraph = xwpfTables1.get(i).getRows().get(j).getTableCells().get(k).addParagraph();
+                                XWPFRun run = xwpfParagraph.createRun();
+                                run.setText(split[0]);
+                                if (ObjectUtils.isNotNull(split[1])) {
+                                    run.addBreak();
+                                    run.setText(split[1]);
+                                }
+                                xwpfParagraph.setAlignment(ParagraphAlignment.CENTER);
+                            }
+                        }
+                    }
+                }
+                //澶勭悊妫�楠岀粨鏋滆法椤电殑闂
+                FileOutputStream fileOutputStream1 = new FileOutputStream(path);
+                document1.write(fileOutputStream1);
+                fileOutputStream1.close();
+            } catch (FileNotFoundException e) {
+                throw new RuntimeException(e);
+            } catch (IOException e) {
+                throw new RuntimeException(e);
+            }
         }
         return 1;
     }
 
-    private void getTemplateThing(Set<Integer> set, Map<Integer, String> map2, List<InsProduct> insProducts) {
+    private void getTemplateThing
+            (Set<Integer> set, Map<Integer, String> map2, List<InsProduct> insProducts) {
         for (InsProduct product : insProducts) {
             if (product.getTemplateId() == null) {
                 product.setTemplate(new ArrayList<>());
@@ -1188,8 +1353,24 @@
             String str = "";
             int count = 0;
             for (InsProduct product : insProducts) {
-                count++;
-                str += "<br/>" + count + "锛�" + product.getInspectionItem() + " " + product.getInspectionItemSubclass() + "<br/>";
+                //濡傛灉鏄厜缂嗙殑娓╁害寰幆
+                if (product.getInspectionItem().equals("娓╁害寰幆") && insOrderMapper.selectById(orderId).getSampleType().equals("鍏夌紗")) {
+                    //鏌ヨ閭d簺寰幆娓╁害鐨勬楠岄」鐩殑缁撹鏄惁鍏ㄩ儴妫�楠�
+                    List<InsProduct> insProductList = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getInsSampleId, product.getInsSampleId())
+                            .isNotNull(InsProduct::getInsFiberId).like(InsProduct::getInspectionItemSubclass, "鈩�"));
+                    List<Integer> collect = insProductList.stream().filter(insProduct -> insProduct.getInsResult() != null).map(InsProduct::getInsResult).collect(Collectors.toList());
+                    List<Integer> tt = new ArrayList<>();
+                    tt.add(1);
+                    if (collect.contains(0)) {
+                        product.setInsResult(0);
+                    } else if (collect.size() == insProductList.size() && collect.stream().distinct().collect(Collectors.toList()).containsAll(tt)) {
+                        product.setInsResult(0);
+                    }
+                    insProductMapper.updateById(product);
+                } else {
+                    count++;
+                    str += "<br/>" + count + "锛�" + product.getInspectionItem() + " " + product.getInspectionItemSubclass() + "<br/>";
+                }
             }
             throw new ErrorException("<strong>瀛樺湪寰呮楠岀殑椤圭洰锛�</strong><br/>" + str);
         }
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 7ad21ac..8f7c742 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
@@ -21,6 +21,7 @@
 import com.yuanchu.mom.vo.SampleDefectsFatherVo;
 import lombok.AllArgsConstructor;
 import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
@@ -147,8 +148,35 @@
             }
             insSampleMapper.insert(a);
             if (ObjectUtil.isNotEmpty(a.getInsProduct())) {
-                //鏅�氭楠岄」鐩�(闄や簡鍏夌氦鎺ュご鎹熻��)鐨勬坊鍔�
-                addInsProductMethod(a.getId(), a.getInsProduct(), null, 0);
+                addInsProductMethod(a.getId(), a.getInsProduct(), null, 0,false);
+                if (ObjectUtil.isNotEmpty(a.getBushing())){
+                    for (BushingDto bushingDto : a.getBushing()) {
+                        bushingDto.setInsSampleId(a.getId());
+                        insBushingMapper.insert(bushingDto);
+                        if (bushingDto.getFiber().size() != 0) {
+                            for (FiberDto fiberDto : bushingDto.getFiber()) {
+                                fiberDto.setInsBushingId(bushingDto.getId());
+                                insFiberMapper.insert(fiberDto);
+                                addInsProductMethod(a.getId(), a.getInsProduct(), fiberDto.getId(), 2,true);
+                                addInsProductMethod(a.getId(), fiberDto.getProductList(), fiberDto.getId(), 2,false);
+                            }
+                        }else {
+                            for (FibersDto fibersDto : bushingDto.getFibers()) {
+                                fibersDto.setInsBushingId(bushingDto.getId());
+                                fibersDto.setCode(this.giveCode.giveCode("", "ins_fibers", "", "yyMMdd"));
+                                insFibersMapper.insert(fibersDto);
+                                for (FiberDto fiberDto : fibersDto.getFiber()) {
+                                    fiberDto.setInsFibersId(fibersDto.getId());
+                                    insFiberMapper.insert(fiberDto);
+                                    addInsProductMethod(a.getId(), a.getInsProduct(), fiberDto.getId(), 2,true);
+                                    addInsProductMethod(a.getId(), fiberDto.getProductList(), fiberDto.getId(), 2,false);
+                                }
+                                //addInsProductMethod(a.getId(), a.getInsProduct(), fibersDto.getId(), 1);
+                                addInsProductMethod(a.getId(), fibersDto.getProductList(), fibersDto.getId(), 1,false);
+                            }
+                        }
+                    }
+                }
             }
             if (ObjectUtil.isNotEmpty(a.getInsulating())) {
                 List<InsProduct> ip2 = new ArrayList<>();
@@ -158,13 +186,13 @@
                 for (InsProduct product : ip2) {
                     product.setStandardMethodListId(a.getInsulating().getStandardMethodListId());
                 }
-                addInsProductMethod(a.getId(), ip2, null, 0);
+                addInsProductMethod(a.getId(), ip2, null, 0,false);
             }
             if (ObjectUtil.isNotEmpty(a.getSheath())) {
                 for (InsProduct product : a.getSheath().getInsProduct()) {
                     product.setStandardMethodListId(a.getSheath().getStandardMethodListId());
                 }
-                addInsProductMethod(a.getId(), a.getSheath().getInsProduct(), null, 0);
+                addInsProductMethod(a.getId(), a.getSheath().getInsProduct(), null, 0,false);
             }
             if (ObjectUtil.isNotEmpty(a.getChildSampleList())) {
                 for (SampleProductDto b : a.getChildSampleList()) {
@@ -177,12 +205,12 @@
                         }
                         insSampleMapper.insert(b);
                         if (ObjectUtil.isNotEmpty(b.getInsProduct())) {
-                            addInsProductMethod(b.getId(), b.getInsProduct(), null, 0);
+                            addInsProductMethod(b.getId(), b.getInsProduct(), null, 0,false);
                         }
                     }
                 }
             }
-            if (ObjectUtil.isNotEmpty(a.getBushing())) {
+            if (ObjectUtil.isEmpty(a.getInsProduct()) && ObjectUtil.isNotEmpty(a.getBushing())) {
                 for (BushingDto bushingDto : a.getBushing()) {
                     bushingDto.setInsSampleId(a.getId());
                     insBushingMapper.insert(bushingDto);
@@ -190,7 +218,7 @@
                         for (FiberDto fiberDto : bushingDto.getFiber()) {
                             fiberDto.setInsBushingId(bushingDto.getId());
                             insFiberMapper.insert(fiberDto);
-                            addInsProductMethod(a.getId(), fiberDto.getProductList(), fiberDto.getId(), 2);
+                            addInsProductMethod(a.getId(), fiberDto.getProductList(), fiberDto.getId(), 2,false);
                         }
                     } else {
                         for (FibersDto fibersDto : bushingDto.getFibers()) {
@@ -200,9 +228,9 @@
                             for (FiberDto fiberDto : fibersDto.getFiber()) {
                                 fiberDto.setInsFibersId(fibersDto.getId());
                                 insFiberMapper.insert(fiberDto);
-                                addInsProductMethod(a.getId(), fiberDto.getProductList(), fiberDto.getId(), 2);
+                                addInsProductMethod(a.getId(), fiberDto.getProductList(), fiberDto.getId(), 2,false);
                             }
-                            addInsProductMethod(a.getId(), fibersDto.getProductList(), fibersDto.getId(), 1);
+                            addInsProductMethod(a.getId(), fibersDto.getProductList(), fibersDto.getId(), 1,false);
                         }
                     }
                 }
@@ -226,7 +254,7 @@
         return insOrder.getId();
     }
 
-    private void addInsProductMethod(Integer sampleId, List<InsProduct> productList, Integer id, Integer type) {
+    private void addInsProductMethod(Integer sampleId, List<InsProduct> productList, Integer id, Integer type,Boolean is) {
         InsOrder insOrder = insOrderMapper.selectById(insSampleMapper.selectById(sampleId).getInsOrderId());
         for (InsProduct product : productList) {
             if (product.getState() == 1 && !product.getInspectionItem().equals("鍏夌氦鎺ュご鎹熻��")) {
@@ -247,11 +275,23 @@
                                     break;
                             }
                             String[] split = strings[i].split(",");
-                            insProduct.setInspectionItem("1娆�");//妫�楠岄」--寰幆娆℃暟
+                            insProduct.setInspectionItem("1");//妫�楠岄」--寰幆娆℃暟
                             insProduct.setInspectionItemSubclass(split[0]);//妫�楠岄」--娓╁害
                             insProduct.setInspectionItemClass(split[1]);//妫�楠岄」--鍏夌氦椤圭洰
                             insProduct.setAsk(split[2]);//妫�楠岃姹�
                             insProduct.setTell(strings[i]);//妫�楠屾弿杩�
+                            insProduct.setInsSampleId(sampleId);
+                            insProduct.setState(1);
+                            insProduct.setFactory(product.getFactory());
+                            insProduct.setLaboratory(product.getLaboratory());
+                            insProduct.setSampleType(product.getSampleType());
+                            insProduct.setSample(product.getSample());
+                            insProduct.setModel(product.getModel());
+                            insProduct.setSonLaboratory(product.getSonLaboratory());
+                            insProduct.setUnit(product.getUnit());
+                            insProduct.setManHourGroup(product.getManHourGroup());
+                            insProduct.setInspectionItemType("0");
+                            insProduct.setInspectionValueType("1");
                             insProducts.add(insProduct);
                             insProductes.add(insProduct);
                         } else {
@@ -262,8 +302,10 @@
                                 for (int j = 2; j <= count; j++) {
                                     for (InsProduct insProduct : insProducts) {
                                         if (!insProduct.getInspectionItemSubclass().equals("20鈩�")) {
-                                            insProduct.setInspectionItem(j + "娆�");
-                                            insProductes.add(insProduct);
+                                            InsProduct insProduct1 = new InsProduct();
+                                            BeanUtils.copyProperties(insProduct,insProduct1);
+                                            insProduct1.setInspectionItem(j + "");
+                                            insProductes.add(insProduct1);
                                         }
                                     }
                                 }
@@ -271,25 +313,27 @@
                         }
                     }
                     insProductService.saveBatch(insProductes);
-                } else {
-                    switch (type) {
-                        case 1:
-                            product.setInsFibersId(id);
-                            break;
-                        case 2:
-                            product.setInsFiberId(id);
-                            break;
+                } else  {
+                    if (!is) {
+                        switch (type) {
+                            case 1:
+                                product.setInsFibersId(id);
+                                break;
+                            case 2:
+                                product.setInsFiberId(id);
+                                break;
+                        }
+                        product.setId(null);
+                        product.setCreateTime(null);
+                        product.setUpdateTime(null);
+                        product.setUpdateTime(null);
+                        product.setUpdateUser(null);
+                        product.setInsSampleId(sampleId);
+                        if (product.getInspectionItemSubclass() == null) {
+                            product.setInspectionItemSubclass("");
+                        }
+                        insProductMapper.insert(product);
                     }
-                    product.setId(null);
-                    product.setCreateTime(null);
-                    product.setUpdateTime(null);
-                    product.setUpdateTime(null);
-                    product.setUpdateUser(null);
-                    product.setInsSampleId(sampleId);
-                    if (product.getInspectionItemSubclass() == null) {
-                        product.setInspectionItemSubclass("");
-                    }
-                    insProductMapper.insert(product);
                 }
             }
         }
diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/StandardProductListServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/StandardProductListServiceImpl.java
index c5e49a3..255da3d 100644
--- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/StandardProductListServiceImpl.java
+++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/StandardProductListServiceImpl.java
@@ -67,6 +67,10 @@
             String[] split = insSample.getFactory().split(" - ");
             String tree = split[0] + " - " + split[1] + " - " + split[2] + " - " + split[3] + " - null";
             list = standardProductListMapper.selectDetail2(insSample.getStandardMethodListId(), 1, tree);
+            if (list.size()==0){
+                String tree1 = split[0] + " - " + split[1] + " - " + split[2] + " - null - " + split[3] ;
+                list = standardProductListMapper.selectDetail2(insSample.getStandardMethodListId(), 1, tree1);
+            }
         }
         list = list.stream().filter(a -> {
             try {
diff --git a/inspect-server/src/main/java/com/yuanchu/mom/vo/ProductVo.java b/inspect-server/src/main/java/com/yuanchu/mom/vo/ProductVo.java
new file mode 100644
index 0000000..7c3c489
--- /dev/null
+++ b/inspect-server/src/main/java/com/yuanchu/mom/vo/ProductVo.java
@@ -0,0 +1,22 @@
+package com.yuanchu.mom.vo;
+
+import com.yuanchu.mom.pojo.InsProduct;
+import lombok.Data;
+
+@Data
+public class ProductVo  {
+
+    //绠¤壊鏍�
+    private String bushColor;
+
+    //鍏夌氦鑹叉爣
+    private String color;
+
+    //鍏夌氦甯︾紪鍙�
+    private String code;
+
+    //妫�楠岄」鐩�
+    private InsProduct insProduct;
+
+
+}
diff --git a/inspect-server/src/main/java/com/yuanchu/mom/vo/SampleVo.java b/inspect-server/src/main/java/com/yuanchu/mom/vo/SampleVo.java
new file mode 100644
index 0000000..860520a
--- /dev/null
+++ b/inspect-server/src/main/java/com/yuanchu/mom/vo/SampleVo.java
@@ -0,0 +1,13 @@
+package com.yuanchu.mom.vo;
+
+import com.yuanchu.mom.pojo.InsProduct;
+import com.yuanchu.mom.pojo.InsSample;
+import lombok.Data;
+
+import java.util.List;
+
+@Data
+public class SampleVo extends InsSample {
+    //璇曢獙鏂规硶
+    private  String methodName;
+}
diff --git a/inspect-server/src/main/resources/mapper/InsSampleMapper.xml b/inspect-server/src/main/resources/mapper/InsSampleMapper.xml
index c5e2571..457fc59 100644
--- a/inspect-server/src/main/resources/mapper/InsSampleMapper.xml
+++ b/inspect-server/src/main/resources/mapper/InsSampleMapper.xml
@@ -556,4 +556,36 @@
         <result property="equipValue" column="equip_value" jdbcType="VARCHAR"/>
         <result property="equipName" column="equip_name" jdbcType="VARBINARY"/>
     </resultMap>
+
+    <resultMap id="sampleVo" type="com.yuanchu.mom.vo.SampleVo">
+        <id property="id" column="id" jdbcType="INTEGER"/>
+        <result property="insResult" column="ins_result" jdbcType="INTEGER"/>
+        <result property="insOrderId" column="ins_order_id" jdbcType="INTEGER"/>
+        <result property="joinModel" column="join_model" jdbcType="VARCHAR"/>
+        <result property="joinName" column="join_name" jdbcType="VARCHAR"/>
+        <result property="sampleCode" column="sample_code" jdbcType="VARCHAR"/>
+        <result property="factory" column="factory" jdbcType="VARCHAR"/>
+        <result property="laboratory" column="laboratory" jdbcType="VARCHAR"/>
+        <result property="sampleType" column="sample_type" jdbcType="VARCHAR"/>
+        <result property="sample" column="sample" jdbcType="VARCHAR"/>
+        <result property="model" column="model" jdbcType="VARCHAR"/>
+        <result property="insState" column="ins_state" jdbcType="INTEGER"/>
+        <result property="joinNum" column="join_num" jdbcType="INTEGER"/>
+        <result property="remark" column="remark" jdbcType="VARCHAR"/>
+        <result property="createUser" column="create_user" jdbcType="INTEGER"/>
+        <result property="updateUser" column="update_user" jdbcType="INTEGER"/>
+        <result property="createTime" column="create_time" jdbcType="TIMESTAMP"/>
+        <result property="updateTime" column="update_time" jdbcType="TIMESTAMP"/>
+        <result property="standardMethodListId" column="standard_method_list_id"/>
+        <result property="methodName" column="methodName" jdbcType="VARCHAR"/>
+        <result property="unit" column="unit"/>
+    </resultMap>
+
+    <select id="getDetailById" resultMap="sampleVo">
+        select is2.*,
+               code methodName
+        from ins_sample is2
+                 inner join standard_method sm on standard_method_list_id = sm.id
+        where is2.id=#{sampleId}
+    </select>
 </mapper>
diff --git a/inspect-server/src/main/resources/static/report-template.docx b/inspect-server/src/main/resources/static/report-template.docx
index b022ae6..32f0a07 100644
--- a/inspect-server/src/main/resources/static/report-template.docx
+++ b/inspect-server/src/main/resources/static/report-template.docx
Binary files differ
diff --git a/performance-server/src/main/resources/mapper/AuxiliaryCorrectionHoursMapper.xml b/performance-server/src/main/resources/mapper/AuxiliaryCorrectionHoursMapper.xml
index fa2a6be..2fced33 100644
--- a/performance-server/src/main/resources/mapper/AuxiliaryCorrectionHoursMapper.xml
+++ b/performance-server/src/main/resources/mapper/AuxiliaryCorrectionHoursMapper.xml
@@ -44,7 +44,7 @@
         <result column="update_user" property="updateUser"/>
     </resultMap>
     <select id="selectAuxiliaryCorrectionHours" resultType="com.yuanchu.mom.dto.AuxiliaryCorrectionHoursDto">
-        select data.*
+        select A.*
         from (
         select ach.*,name
         FROM auxiliary_correction_hours ach
@@ -55,7 +55,7 @@
                 #{val}
             </foreach>
         </if>
-        ) data
+        ) A
         <if test="ew.customSqlSegment != null and ew.customSqlSegment != ''">
             ${ew.customSqlSegment}
         </if>
diff --git a/performance-server/src/main/resources/mapper/AuxiliaryOutputWorkingHoursMapper.xml b/performance-server/src/main/resources/mapper/AuxiliaryOutputWorkingHoursMapper.xml
index 97ff05d..8210a83 100644
--- a/performance-server/src/main/resources/mapper/AuxiliaryOutputWorkingHoursMapper.xml
+++ b/performance-server/src/main/resources/mapper/AuxiliaryOutputWorkingHoursMapper.xml
@@ -45,7 +45,7 @@
                 #{val}
             </foreach>
         </if>
-        ) data
+        ) A
         <if test="ew.customSqlSegment != null and ew.customSqlSegment != ''">
             ${ew.customSqlSegment}
         </if>
diff --git a/performance-server/src/main/resources/mapper/AuxiliaryWorkingHoursDayMapper.xml b/performance-server/src/main/resources/mapper/AuxiliaryWorkingHoursDayMapper.xml
index c4c2c6f..04cdf11 100644
--- a/performance-server/src/main/resources/mapper/AuxiliaryWorkingHoursDayMapper.xml
+++ b/performance-server/src/main/resources/mapper/AuxiliaryWorkingHoursDayMapper.xml
@@ -26,7 +26,7 @@
         <result column="state" property="state"/>
     </resultMap>
     <select id="selectAuxiliaryWorkingHoursDay" resultType="com.yuanchu.mom.dto.AuxiliaryWorkingHoursDayDto">
-        select data.*
+        select A.*
         from (
         select awhd.*,name
         FROM auxiliary_working_hours_day awhd
@@ -37,7 +37,7 @@
                 #{val}
             </foreach>
         </if>
-        ) data
+        ) A
         <if test="ew.customSqlSegment != null and ew.customSqlSegment != ''">
             ${ew.customSqlSegment}
         </if>

--
Gitblit v1.9.3