From 47ff9c863e736ff06c39ba44ddfd736c8329a9b7 Mon Sep 17 00:00:00 2001 From: zouyu <2723363702@qq.com> Date: 星期三, 12 三月 2025 19:34:26 +0800 Subject: [PATCH] 完成检验下单接口联调及自测 --- basic-server/src/main/java/com/ruoyi/basic/service/impl/StandardProductListServiceImpl.java | 351 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 351 insertions(+), 0 deletions(-) diff --git a/basic-server/src/main/java/com/ruoyi/basic/service/impl/StandardProductListServiceImpl.java b/basic-server/src/main/java/com/ruoyi/basic/service/impl/StandardProductListServiceImpl.java new file mode 100644 index 0000000..bb8b583 --- /dev/null +++ b/basic-server/src/main/java/com/ruoyi/basic/service/impl/StandardProductListServiceImpl.java @@ -0,0 +1,351 @@ +package com.ruoyi.basic.service.impl; + +import cn.hutool.core.util.NumberUtil; +import com.alibaba.fastjson.JSON; +import com.alibaba.fastjson.JSONArray; +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.core.toolkit.*; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.basic.dto.ProductDto; +import com.ruoyi.basic.mapper.StandardProductListMapper; +import com.ruoyi.basic.mapper.StandardTreeMapper; +import com.ruoyi.basic.pojo.InsSample1; +import com.ruoyi.basic.pojo.StandardProductList; +import com.ruoyi.basic.pojo.StandardTree; +import com.ruoyi.common.exception.base.BaseException; +import com.ruoyi.common.utils.SecurityUtils; +import com.ruoyi.basic.service.StandardProductListService; +import com.ruoyi.common.utils.StringUtils; +import lombok.AllArgsConstructor; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import java.math.BigDecimal; +import java.util.*; +import java.util.regex.Matcher; +import java.util.regex.Pattern; +import java.util.stream.Collectors; + +/** + * @author Administrator + * @description 閽堝琛ㄣ�恠tandard_product_list(鏍囧噯鏍戜笅鐨勬楠岄」鐩�)銆戠殑鏁版嵁搴撴搷浣淪ervice瀹炵幇 + * @createDate 2024-03-05 10:33:29 + */ +@Service +@AllArgsConstructor +public class StandardProductListServiceImpl extends ServiceImpl<StandardProductListMapper, StandardProductList> + implements StandardProductListService { + + private StandardProductListMapper standardProductListMapper; + + private StandardTreeMapper standardTreeMapper; + + + @Override + public int upStandardProductList(StandardProductList list) { + return standardProductListMapper.updateById(list); + } + + @Override + public int delStandardProduct(JSONArray list) { + return standardProductListMapper.deleteBatchIds(list); + } + + @Override + public List<StandardProductList> selectStandardProductList(InsSample1 insSample) { + String[] models = insSample.getModel().split("-(?=[^-]*$)");//鎷嗗垎鏈�鍚庝竴涓��-銆� + String[] splits = StringUtils.isNotEmpty(insSample.getFactory())?insSample.getFactory().split(" - "):new String[0]; + List<StandardProductList> list = new ArrayList<>(); + if(splits.length<4){ + list = standardProductListMapper.selectDetail(insSample.getStandardMethodListId(), 1, models[0],"",""); + }else { + list = standardProductListMapper.selectDetail(insSample.getStandardMethodListId(), 1, models[0],splits[2],splits[3]); + } + if (list.isEmpty()) { + if (Objects.equals(insSample.getFactory(), "") || insSample.getFactory() == null) { + return null; + } + 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.isEmpty()) { + String tree1 = split[0] + " - " + split[1] + " - " + split[2] + " - null - " + split[3]; + list = standardProductListMapper.selectDetail2(insSample.getStandardMethodListId(), 1, tree1); + if(list.isEmpty()) { + String tree2 = split[0] + " - " + split[1] + " - " + split[2] + " - " + split[3] + " - "; + list = standardProductListMapper.selectDetail2(insSample.getStandardMethodListId(), 1, tree2); + } + } + } + //鍒ゆ柇闀垮害 + if (splits.length > 4) { + if (ObjectUtils.isNotEmpty(splits[3])) { + list = list.stream().filter(list1 -> Objects.nonNull(list1.getSample())&&Objects.equals(list1.getSample(),splits[3])).collect(Collectors.toList()); + }else if (splits[3].isEmpty()) { + list = list.stream().filter(list1 -> Objects.nonNull(list1.getSampleType())&&Objects.equals(list1.getSampleType(),splits[2])).collect(Collectors.toList()); + } + } + list = list.stream().filter(a -> { + try { + if (a.getSection() != null && !Objects.equals(a.getSection(), "")) { + List<String> sections = JSON.parseArray(a.getSection(), String.class); + List<String> asks = JSON.parseArray(a.getAsk(), String.class); + List<String> tells = JSON.parseArray(a.getTell(), String.class); + List<String> manHours = JSON.parseArray(a.getManHour(), String.class); + List<String> prices = JSON.parseArray(a.getPrice(), String.class); + boolean isIf; + for (int i = 0; i < sections.size(); i++) { + if (Objects.equals(a.getBsm(), "1")) { + return true; + } else { + if (sections.get(i).contains("&")) { + String[] split = sections.get(i).split("&"); + isIf = getIsIf(split[0], models[1]) && getIsIf(split[1], models[1]); + } else { + isIf = getIsIf(sections.get(i), models[1]); + } + if (isIf) { + a.setSection(sections.get(i)); + a.setAsk(asks.get(i)); + a.setTell(tells.get(i)); + a.setPrice(prices.get(i)); + a.setManHour(manHours.get(i)); + return true; + } + } + } + return false; + } + } catch (Exception ignored) { + return false; + } + return true; + }).collect(Collectors.toList()); + return list; + } + + private boolean getIsIf(String str, String model) { + Matcher matcher = Pattern.compile("\\d+(\\.\\d+)?").matcher(model); + BigDecimal modelNumber = BigDecimal.ZERO; + String model2 = ""; + while (matcher.find()) { + model2 += matcher.group(); + modelNumber = BigDecimal.valueOf(Double.parseDouble(model2)); + break; + } + Double param = matchNumber(str); + if (str.contains("鈮�") || str.contains(">=")) { +// String param = str.replace("鈮�", "").replace(">=", ""); + return modelNumber.compareTo(new BigDecimal(param)) > -1; + } else if (str.contains("鈮�") || str.contains("<=")) { +// String param = str.replace("鈮�", "").replace("<=", ""); + return modelNumber.compareTo(new BigDecimal(param)) < 1; + } else if (str.contains(">") || str.contains("锛�")) { +// String param = str.replace(">", "").replace("锛�", ""); + return modelNumber.compareTo(new BigDecimal(param)) > 0; + } else if (str.contains("<") || str.contains("锛�")) { +// String param = str.replace("<", "").replace("锛�", ""); + return modelNumber.compareTo(new BigDecimal(param)) < 0; + } else if (str.contains("=")) { +// String param = str.replace("=", ""); + return modelNumber.compareTo(new BigDecimal(param)) == 0; + } + return false; + } + public Double matchNumber(String str) { + String regex = "[>锛溾墺鈮�=]?[>=<]?\\s*(-?\\d+(\\.\\d+)?)"; + // 缂栬瘧姝e垯琛ㄨ揪寮� + Matcher matcher = Pattern.compile(regex).matcher(str); + List<Double> numbers = new ArrayList<>(); + while(matcher.find()) { + if(matcher.group(1) != null) { + numbers.add(Double.parseDouble(matcher.group(1))); + } + } + if(numbers.size() > 0) { + return numbers.get(0); + } + return 0.00; + } + + @Override + @Transactional(rollbackFor = Exception.class) + public Map<String, Object> selectStandardProductListByMethodId(Integer id, String tree, Integer page) { + String[] trees = tree.split(" - "); +// try { +// String tree1 = trees[2]; +// } catch (Exception e) { +// throw new ErrorException("鎿嶄綔澶揩,绯荤粺浼犲弬閿欒!!!!"); +// } + //list涓烘牴鎹潯浠舵煡璇㈢殑鑳藉姏鑼冨洿鏁版嵁 + List<StandardProductList> list = new ArrayList<>(); + if (trees.length == 3) { + List<StandardTree> treeList = new ArrayList<>(); + StandardTree standardTree = new StandardTree(); + standardTree.setFactory(trees[0]); + standardTree.setLaboratory(trees[1]); + standardTree.setSampleType(trees[2]); + List<ProductDto> pList = standardTreeMapper.selectPList(trees[2]); + if (pList.isEmpty() || pList.get(0) == null) { + List<StandardTree> treeList1 = standardTreeMapper.selectList(Wrappers.<StandardTree>lambdaQuery().eq(StandardTree::getLaboratory, trees[1]).eq(StandardTree::getSampleType, trees[2])); + if (treeList1.isEmpty()) { + treeList.add(standardTree); + } else { + treeList.addAll(treeList1); + } + } else { + for (ProductDto p : pList) { + standardTree.setSample(p.getName()); + List<StandardTree> treeList1 = standardTreeMapper.selectList(Wrappers.<StandardTree>lambdaQuery().eq(StandardTree::getLaboratory, trees[1]).eq(StandardTree::getSampleType, trees[2]).eq(StandardTree::getSample, p.getName())); + if (treeList1.isEmpty()) { + treeList.add(JSON.parseObject(JSON.toJSONString(standardTree), StandardTree.class)); + } else { + treeList.addAll(treeList1); + } + } + } + for (StandardTree standardTree2 : treeList) { + String tree2 = trees[0] + " - " + trees[1] + " - " + trees[2] + " - " + standardTree2.getSample() + " - " + standardTree2.getModel(); + list.addAll(standardTreeMapper.selectStandardProductListByTree("\"" + trees[2] + "\"", standardTree2.getSample(), standardTree2.getModel(), tree2, trees[1])); + list.addAll(standardTreeMapper.selectStandardProductListByTree2("\"" + trees[2] + "\",\"" + standardTree2.getSample() + "\"", standardTree2.getSample(), standardTree2.getModel(), tree2, trees[1])); + } + } + else if (trees.length == 4) { + List<StandardTree> treeList = standardTreeMapper.selectList(Wrappers.<StandardTree>lambdaQuery().eq(StandardTree::getLaboratory, trees[1]).eq(StandardTree::getSampleType, trees[2]).eq(StandardTree::getSample, trees[3])); + if (treeList.isEmpty()) { + StandardTree standardTree = new StandardTree(); + standardTree.setFactory(trees[0]); + standardTree.setLaboratory(trees[1]); + standardTree.setSampleType(trees[2]); + standardTree.setSample(trees[3]); + treeList.add(standardTree); + } + for (StandardTree standardTree : treeList) { + String str = tree + " - " + standardTree.getModel(); + list.addAll(standardTreeMapper.selectStandardProductListByTree("\"" + trees[2] + "\"", standardTree.getSample(), standardTree.getModel(), str, trees[1])); + list.addAll(standardTreeMapper.selectStandardProductListByTree2("\"" + trees[2] + "\",\"" + trees[3] + "\"", standardTree.getSample(), standardTree.getModel(), str, trees[1])); + } + } + else { + list.addAll(standardTreeMapper.selectStandardProductListByTree("\"" + trees[2] + "\"", trees[3].equals("null") ? null : trees[3], trees[4], tree, trees[1])); + list.addAll(standardTreeMapper.selectStandardProductListByTree2("\"" + trees[2] + "\",\"" + trees[3] + "\"", trees[3].equals("null") ? null : trees[3], trees[4], tree, trees[1])); + } + //鏍囧噯搴撳搴旀楠岄」鏁版嵁 + List<StandardProductList> standardProductLists = standardProductListMapper.selectList(Wrappers.<StandardProductList>lambdaQuery() + .eq(StandardProductList::getStandardMethodListId, id)//鏍囧噯鏂规硶id + .eq(StandardProductList::getSampleType,trees[2])//鏍峰搧澶х被 + .eq(trees.length>3,StandardProductList::getSample,trees.length>3?trees[3]:"")//鏍峰搧 + .eq(trees.length>4,StandardProductList::getModel,trees.length>4?trees[4]:"")//鍨嬪彿 + ); + //澶勭悊鏁版嵁 + //涓嶈兘缂栬緫鐨勬暟鎹互鑳藉姏鑼冨洿涓轰富锛屽彲缂栬緫鐨勬暟鎹互鏍囧噯搴撲负涓� + for (StandardProductList sp : standardProductLists) { + for (StandardProductList pl : list) { + if(Objects.isNull(sp.getStructureItemParameterId())){ + break; + } + pl.setFactory(sp.getFactory()); + pl.setSampleType(sp.getSampleType()); + pl.setStandardMethodListId(id);//鏍囧噯鏂规硶id + if(NumberUtil.equals(sp.getStructureItemParameterId(),pl.getStructureItemParameterId()) && (trees.length <= 4 || Objects.equals(sp.getModel(), pl.getModel()))){ + pl.setId(sp.getId()); + pl.setAsk(sp.getAsk());//瑕佹眰鍊� + pl.setTell(sp.getTell());//瑕佹眰鎻忚堪 + pl.setManHour(sp.getManHour());//宸ユ椂绯绘暟 + pl.setManHourGroup(sp.getManHourGroup());//宸ユ椂鍒嗙粍 + pl.setPrice(sp.getPrice());//鍗曚环 + pl.setTemplateId(sp.getTemplateId());//妯℃澘id + pl.setSection(sp.getSection());//鍖洪棿 + pl.setState(sp.getState());//鍕鹃�夌姸鎬� + pl.setMethodS(sp.getMethodS());//璇曢獙鏂规硶 + pl.setMethodS(sp.getMethodS());//鏂规硶 + pl.setTree(sp.getTree());//鏍戝舰缁撴瀯瀛楃 + } + } + } + //鏌ヨ鏍囧噯搴撳搴旂殑鏁版嵁涓虹┖锛岃瘉鏄庢槸鏂板姞鐨勬爣鍑嗭紝浠ヨ兘鍔涜寖鍥翠负涓� + if(standardProductLists.isEmpty()){ + list.forEach(l->{ + l.setStandardMethodListId(id); + l.setFactory(org.apache.commons.lang3.StringUtils.isNotBlank(trees[0])?trees[0]:""); + l.setSampleType(org.apache.commons.lang3.StringUtils.isNotBlank(trees[2])?trees[2]:""); + }); + } + //娣诲姞鏂板姞鐨勯」鐩� + list.stream().filter(l->Objects.isNull(l.getId())).forEach(this::save); + Map<String, Object> map = new HashMap<>(); + list.sort((o1, o2) -> { + String field1 = o1.getManHourGroup(); + String field2 = o2.getManHourGroup(); + + boolean isEmpty1 = field1 == null || field1.isEmpty(); + boolean isEmpty2 = field2 == null || field2.isEmpty(); + + if (isEmpty1 && isEmpty2) { + return 0; + } else if (isEmpty1) { + return 1; + } else if (isEmpty2) { + return -1; + } else { + int num1 = extractNumber(field1); + int num2 = extractNumber(field2); + return Integer.compare(num1, num2); + } + }); + try { + map.put("productList", list.subList((page - 1) * 50, page * 50)); + } catch (IndexOutOfBoundsException e) { + map.put("productList", list.subList((page - 1) * 50, list.size())); + } + map.put("total", list.size()); + return map; + } + + private int extractNumber(String s) { + // 浠庡瓧绗︿覆涓彁鍙栨暟瀛楃殑閫昏緫锛岃繖閲屽亣璁惧瓧娈电殑鏍煎紡鏄� "text<number>" + String number = s; + if (!s.matches("\\d+")) { + number = s.replaceAll("\\D", ""); + } + return Integer.parseInt(number); + } + + @Override + public IPage<StandardProductList> selectStandardProductByMethodId(Integer id, String tree, Integer page, String laboratory, String item, String items) { + IPage<StandardProductList> iPage = new Page<>(); + iPage.setSize(100); + iPage.setCurrent(page); + return standardProductListMapper.standardProductListIPage(id, tree, iPage, laboratory, item, items); + } + + @Override + public Map<String, List<?>> selectStandardProductEnumByMethodId(Integer id, String tree, String item) { + HashMap<String, List<?>> map = new HashMap<>(); + map.put("item", standardProductListMapper.selectList(Wrappers.<StandardProductList>lambdaQuery() + .eq(StandardProductList::getStandardMethodListId, id) + .like(StandardProductList::getTree, tree) + .select(StandardProductList::getInspectionItem) + .groupBy(StandardProductList::getInspectionItem))); + if (ObjectUtils.isNotEmpty(item)) { + map.put("items", standardProductListMapper.selectList(Wrappers.<StandardProductList>lambdaQuery() + .eq(StandardProductList::getStandardMethodListId, id) + .eq(StandardProductList::getInspectionItem, item) + .like(StandardProductList::getTree, tree) + .select(StandardProductList::getInspectionItemSubclass) + .groupBy(StandardProductList::getInspectionItemSubclass))); + } else { + map.put("items", standardProductListMapper.selectList(Wrappers.<StandardProductList>lambdaQuery() + .eq(StandardProductList::getStandardMethodListId, id) + .like(StandardProductList::getTree, tree) + .select(StandardProductList::getInspectionItemSubclass) + .groupBy(StandardProductList::getInspectionItemSubclass))); + } + return map; + } +} + + + + -- Gitblit v1.9.3