From e66935b3506169bb169f51823f792b7d68ee499e Mon Sep 17 00:00:00 2001 From: value <z1292839451@163.com> Date: 星期二, 04 六月 2024 01:25:33 +0800 Subject: [PATCH] 部分功能小调整 --- inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderServiceImpl.java | 82 ++++++++++++++++++++++++++++++++--------- 1 files changed, 64 insertions(+), 18 deletions(-) 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 9391af6..cd585b3 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 @@ -9,10 +9,7 @@ import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.yuanchu.mom.common.GetLook; import com.yuanchu.mom.common.PrintChina; -import com.yuanchu.mom.dto.CostStatisticsDto; -import com.yuanchu.mom.dto.SampleOrderDto; -import com.yuanchu.mom.dto.SampleProductDto; -import com.yuanchu.mom.dto.SampleProductDto2; +import com.yuanchu.mom.dto.*; import com.yuanchu.mom.exception.ErrorException; import com.yuanchu.mom.mapper.*; import com.yuanchu.mom.pojo.*; @@ -59,6 +56,12 @@ PowerMapper powerMapper; + private InsBushingMapper insBushingMapper; + + private InsFibersMapper insFibersMapper; + + private InsFiberMapper insFiberMapper; + CustomMapper customMapper; @@ -77,7 +80,11 @@ sampleOrderDto.setCreateUser(map1.get("userId")); }else { //缁勭粐 - sampleOrderDto.setCompany(customMapper.selectById(user.getCompany()).getCompany()); + try { + sampleOrderDto.setCompany(customMapper.selectById(user.getCompany()).getCompany()); + }catch (NullPointerException e){ + throw new ErrorException("鎵句笉鍒版墍灞炲崟浣�"); + } } } Map<String, Object> map = new HashMap<>(); @@ -96,7 +103,7 @@ insOrderMapper.updateById(insOrder); List<InsSample> insSamples = insSampleMapper.selectList(Wrappers.<InsSample>lambdaQuery().eq(InsSample::getInsOrderId, orderId).select(InsSample::getId)); List<Integer> ids = insSamples.stream().map(a -> a.getId()).collect(Collectors.toList()); - List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery().in(InsProduct::getInsSampleId, ids).eq(InsProduct::getState, 1).select(InsProduct::getSonLaboratory).groupBy(InsProduct::getSonLaboratory)); + List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery().in(InsProduct::getInsSampleId, ids).eq(InsProduct::getState, 1).isNull(InsProduct::getInsFibersId).isNull(InsProduct::getInsFiberId).select(InsProduct::getSonLaboratory).groupBy(InsProduct::getSonLaboratory)); for (InsProduct insProduct : insProducts) { InsOrderState insOrderState = new InsOrderState(); insOrderState.setInsOrderId(orderId); @@ -122,7 +129,7 @@ @Transactional(rollbackFor = Exception.class) public int addInsOrder(List<SampleProductDto> list, InsOrder insOrder) { insOrder.setState(0); - String code = insOrderMapper.getLaboratoryCode(insOrder.getLaboratory()); + String code = customMapper.selectById(insOrder.getCompanyId()).getCode2(); insOrder.setEntrustCode(giveCode.giveCode("JCZX-" + code + "-", "ins_order", "-", "yyyyMMdd")); insOrderMapper.insert(insOrder); list.forEach(a -> { @@ -133,28 +140,67 @@ } insSampleMapper.insert(a); if (ObjectUtil.isNotEmpty(a.getInsProduct())) { - for (InsProduct product : a.getInsProduct()) { - product.setId(null); - product.setCreateTime(null); - product.setUpdateTime(null); - product.setUpdateTime(null); - product.setUpdateUser(null); - product.setInsSampleId(a.getId()); - if (product.getInspectionItemSubclass() == null) { - product.setInspectionItemSubclass(""); + addInsProductMethod(a.getId(), a.getInsProduct(), null, 0); + } + 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(), fiberDto.getProductList(), fiberDto.getId(), 2); + } + }else{ + for (FibersDto fibersDto : bushingDto.getFibers()) { + fibersDto.setInsBushingId(bushingDto.getId()); + fibersDto.setCode(giveCode.giveCode("", "ins_fibers", "", "yyMMdd")); + insFibersMapper.insert(fibersDto); + for (FiberDto fiberDto : fibersDto.getFiber()) { + fiberDto.setInsFibersId(fibersDto.getId()); + insFiberMapper.insert(fiberDto); + addInsProductMethod(a.getId(), fiberDto.getProductList(), fiberDto.getId(), 2); + } + addInsProductMethod(a.getId(), fibersDto.getProductList(), fibersDto.getId(), 1); + } } - insProductMapper.insert(product); } } }); return insOrder.getId(); } + private void addInsProductMethod(Integer sampleId, List<InsProduct> productList, Integer id, Integer type) { + for (InsProduct product : productList) { + if(product.getState()==1){ + 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); + } + } + } + @Override public Map<String, Object> getInsOrder(Integer id) { Map<String, Object> map = new HashMap<>(); InsOrder insOrder = insOrderMapper.selectById(id); - List<SampleProductDto> list = insSampleMapper.selectSampleProductListByOrderId(id); + List<SampleProductDto> list = insSampleMapper.selectSampleProductListByOrderId2(id); map.put("insOrder", insOrder); map.put("sampleProduct", list); return map; -- Gitblit v1.9.3