From f3049ded47e4ab3c981c36f84e36ef15600711f7 Mon Sep 17 00:00:00 2001 From: chenjianxing Date: Wed, 3 Aug 2022 13:38:16 +0800 Subject: [PATCH] =?UTF-8?q?fix(=E6=B5=8B=E8=AF=95=E8=B7=9F=E8=B8=AA):=20?= =?UTF-8?q?=E5=8A=9F=E8=83=BD=E7=94=A8=E4=BE=8B=E5=AF=BC=E5=87=BA=E6=A8=A1?= =?UTF-8?q?=E6=9D=BF=E6=B2=A1=E6=9C=89=E6=A0=87=E6=B3=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --bug=1015552 --user=陈建星 【测试跟踪】导入用例,下载模版,看不到字段的标注了 https://www.tapd.cn/55049933/s/1218272 --- .../FunctionCaseTemplateWriteHandler.java | 143 +++++------------- 1 file changed, 41 insertions(+), 102 deletions(-) diff --git a/backend/src/main/java/io/metersphere/excel/handler/FunctionCaseTemplateWriteHandler.java b/backend/src/main/java/io/metersphere/excel/handler/FunctionCaseTemplateWriteHandler.java index 4ef5112631..a0c78c74f3 100644 --- a/backend/src/main/java/io/metersphere/excel/handler/FunctionCaseTemplateWriteHandler.java +++ b/backend/src/main/java/io/metersphere/excel/handler/FunctionCaseTemplateWriteHandler.java @@ -1,5 +1,7 @@ package io.metersphere.excel.handler; +import com.alibaba.excel.util.BooleanUtils; +import com.alibaba.excel.write.handler.context.RowWriteHandlerContext; import com.alibaba.excel.write.metadata.holder.WriteSheetHolder; import com.alibaba.excel.write.metadata.holder.WriteTableHolder; import com.alibaba.excel.write.style.row.AbstractRowHeightStyleStrategy; @@ -24,37 +26,37 @@ import java.util.*; public class FunctionCaseTemplateWriteHandler extends AbstractRowHeightStyleStrategy { private boolean isNeedId; - List> headList = new ArrayList<>(); - Map rowDispseIndexMap; - Map> caseLevelAndStatusValueMap; - public FunctionCaseTemplateWriteHandler(boolean isNeedId,List> headList,Map> caseLevelAndStatusValueMap){ + Map rowDispseIndexMap; + Map> caseLevelAndStatusValueMap; + + public FunctionCaseTemplateWriteHandler(boolean isNeedId, List> headList, Map> caseLevelAndStatusValueMap) { this.isNeedId = isNeedId; rowDispseIndexMap = this.buildFiledMap(headList); this.caseLevelAndStatusValueMap = caseLevelAndStatusValueMap; } private Map buildFiledMap(List> headList) { - Map returnMap = new HashMap<>(); + Map returnMap = new HashMap<>(); int index = 0; - for (List list:headList) { + for (List list : headList) { for (String head : list) { - if(StringUtils.equalsAnyIgnoreCase(head,"id")){ - returnMap.put("ID",index); - }else if(StringUtils.equalsAnyIgnoreCase(head,"所属模块","所屬模塊","Module")){ - returnMap.put("Module",index); - }else if(StringUtils.equalsAnyIgnoreCase(head,"责任人(ID)","維護人(ID)","Maintainer(ID)")){ - returnMap.put("Maintainer",index); - }else if(StringUtils.equalsAnyIgnoreCase(head,"用例等级","用例等級","Priority")){ - returnMap.put("Priority",index); - }else if(StringUtils.equalsAnyIgnoreCase(head,"标签","標簽","Tag")){ - returnMap.put("Tag",index); - }else if(StringUtils.equalsAnyIgnoreCase(head,"用例状态","用例狀態","Case status")){ - returnMap.put("Status",index); + if (StringUtils.equalsAnyIgnoreCase(head, "id")) { + returnMap.put("ID", index); + } else if (StringUtils.equalsAnyIgnoreCase(head, "所属模块", "所屬模塊", "Module")) { + returnMap.put("Module", index); + } else if (StringUtils.equalsAnyIgnoreCase(head, "责任人(ID)", "維護人(ID)", "Maintainer(ID)")) { + returnMap.put("Maintainer", index); + } else if (StringUtils.equalsAnyIgnoreCase(head, "用例等级", "用例等級", "Priority")) { + returnMap.put("Priority", index); + } else if (StringUtils.equalsAnyIgnoreCase(head, "标签", "標簽", "Tag")) { + returnMap.put("Tag", index); + } else if (StringUtils.equalsAnyIgnoreCase(head, "用例状态", "用例狀態", "Case status")) { + returnMap.put("Status", index); } else if (StringUtils.equalsAnyIgnoreCase(head, "编辑模式", "編輯模式", "Edit Model")) { - returnMap.put("StepModel",index); + returnMap.put("StepModel", index); } - index ++; + index++; } } return returnMap; @@ -62,64 +64,62 @@ public class FunctionCaseTemplateWriteHandler extends AbstractRowHeightStyleStra @Override public void beforeRowCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Integer rowIndex, Integer relativeRowIndex, Boolean isHead) { - } @Override public void afterRowCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Row row, Integer relativeRowIndex, Boolean isHead) { - } @Override - public void afterRowDispose(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Row row, Integer relativeRowIndex, Boolean isHead) { - super.afterRowDispose(writeSheetHolder, writeTableHolder, row, relativeRowIndex, isHead); - if (isHead) { - Sheet sheet = writeSheetHolder.getSheet(); + public void afterRowDispose(RowWriteHandlerContext context) { + + if (BooleanUtils.isTrue(context.getHead())) { + Sheet sheet = context.getWriteSheetHolder().getSheet(); Drawing drawingPatriarch = sheet.createDrawingPatriarch(); - if(rowDispseIndexMap != null){ - if(isNeedId){ + if (rowDispseIndexMap != null) { + if (isNeedId) { Integer idIndex = rowDispseIndexMap.get("ID"); - if(idIndex != null){ + if (idIndex != null) { Comment comment1 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, idIndex, 0, (short) 3, 1)); - comment1.setString(new XSSFRichTextString(Translator.get("do_not_modify_header_order")+","+Translator.get("id_required"))); + comment1.setString(new XSSFRichTextString(Translator.get("do_not_modify_header_order") + "," + Translator.get("id_required"))); sheet.getRow(0).getCell(1).setCellComment(comment1); } } - for (Map.Entry entry:rowDispseIndexMap.entrySet()){ + for (Map.Entry entry : rowDispseIndexMap.entrySet()) { String coloum = entry.getKey(); Integer index = entry.getValue(); - if(StringUtils.equalsAnyIgnoreCase(coloum,"Module")){ + if (StringUtils.equalsAnyIgnoreCase(coloum, "Module")) { Comment comment = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, index, 0, (short) 3, 1)); comment.setString(new XSSFRichTextString(Translator.get("module_created_automatically"))); sheet.getRow(0).getCell(1).setCellComment(comment); - }else if(StringUtils.equalsAnyIgnoreCase(coloum,"Maintainer")){ + } else if (StringUtils.equalsAnyIgnoreCase(coloum, "Maintainer")) { Comment comment = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, index, 0, (short) 3, 1)); comment.setString(new XSSFRichTextString(Translator.get("please_input_project_member"))); sheet.getRow(0).getCell(1).setCellComment(comment); - }else if(StringUtils.equalsAnyIgnoreCase(coloum,"Priority")){ + } else if (StringUtils.equalsAnyIgnoreCase(coloum, "Priority")) { Comment comment = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, index, 0, (short) 3, 1)); List list = new ArrayList<>(); - if(caseLevelAndStatusValueMap != null && caseLevelAndStatusValueMap.containsKey("caseLevel")){ + if (caseLevelAndStatusValueMap != null && caseLevelAndStatusValueMap.containsKey("caseLevel")) { list = caseLevelAndStatusValueMap.get("caseLevel"); } - if(CollectionUtils.isEmpty(list)){ + if (CollectionUtils.isEmpty(list)) { comment.setString(new XSSFRichTextString(Translator.get("options") + "(P0、P1、P2、P3)")); - }else { + } else { comment.setString(new XSSFRichTextString(Translator.get("options") + JSONArray.toJSONString(list))); } sheet.getRow(0).getCell(1).setCellComment(comment); - }else if(StringUtils.equalsAnyIgnoreCase(coloum,"Tag")){ + } else if (StringUtils.equalsAnyIgnoreCase(coloum, "Tag")) { Comment comment = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, index, 0, (short) 3, 1)); comment.setString(new XSSFRichTextString(Translator.get("tag_tip_pattern"))); sheet.getRow(0).getCell(1).setCellComment(comment); - }else if(StringUtils.equalsAnyIgnoreCase(coloum,"Status")){ + } else if (StringUtils.equalsAnyIgnoreCase(coloum, "Status")) { List list = new ArrayList<>(); - if(caseLevelAndStatusValueMap != null && caseLevelAndStatusValueMap.containsKey("caseStatus")){ + if (caseLevelAndStatusValueMap != null && caseLevelAndStatusValueMap.containsKey("caseStatus")) { list = caseLevelAndStatusValueMap.get("caseStatus"); } - if(!CollectionUtils.isEmpty(list)){ + if (!CollectionUtils.isEmpty(list)) { Comment comment = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, index, 0, (short) 3, 1)); comment.setString(new XSSFRichTextString(Translator.get("options") + JSONArray.toJSONString(list))); sheet.getRow(0).getCell(1).setCellComment(comment); @@ -131,66 +131,6 @@ public class FunctionCaseTemplateWriteHandler extends AbstractRowHeightStyleStra } } } - - - -// if(isNeedId){ -// // 在第一行 第1列创建一个批注 -// Comment comment1 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 0, 0, (short) 3, 1)); -// // 输入批注信息 -// comment1.setString(new XSSFRichTextString(Translator.get("do_not_modify_header_order")+","+Translator.get("id_required"))); -// // 在第一行 第3列创建一个批注 -// Comment comment2 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 2, 0, (short) 3, 1)); -// // 输入批注信息 -// comment2.setString(new XSSFRichTextString(Translator.get("module_created_automatically"))); -// // 在第一行 第4列创建一个批注 -// Comment comment4 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 3, 0, (short) 3, 1)); -// // 输入批注信息 -// comment4.setString(new XSSFRichTextString(Translator.get("please_input_workspace_member"))); -// -// // 在第一行 第5列创建一个批注 -// Comment comment5 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 4, 0, (short) 3, 1)); -// // 输入批注信息 -// comment5.setString(new XSSFRichTextString(Translator.get("options") + "(P0、P1、P2、P3)")); -// -// // 在第一行 第6列创建一个批注 -// Comment comment6 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 5, 0, (short) 3, 1)); -// // 输入批注信息 -// comment6.setString(new XSSFRichTextString(Translator.get("tag_tip_pattern"))); -// // 将批注添加到单元格对象中 -// sheet.getRow(0).getCell(1).setCellComment(comment1); -// sheet.getRow(0).getCell(1).setCellComment(comment2); -// sheet.getRow(0).getCell(1).setCellComment(comment4); -// sheet.getRow(0).getCell(1).setCellComment(comment5); -// sheet.getRow(0).getCell(1).setCellComment(comment6); -// }else { -// // 在第一行 第2列创建一个批注 -// Comment comment2 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 1, 0, (short) 3, 1)); -// // 输入批注信息 -// comment2.setString(new XSSFRichTextString(Translator.get("do_not_modify_header_order") + ","+Translator.get("module_created_automatically"))); -// -// // 在第一行 第3列创建一个批注 -// Comment comment4 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 2, 0, (short) 3, 1)); -// // 输入批注信息 -// comment4.setString(new XSSFRichTextString(Translator.get("please_input_workspace_member"))); -// -// // 在第一行 第4列创建一个批注 -// Comment comment5 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 3, 0, (short) 3, 1)); -// // 输入批注信息 -// comment5.setString(new XSSFRichTextString(Translator.get("options") + "(P0、P1、P2、P3)")); -// -// // 在第一行 第5列创建一个批注 -// Comment comment6 = drawingPatriarch.createCellComment(new XSSFClientAnchor(0, 0, 0, 0, (short) 4, 0, (short) 3, 1)); -// // 输入批注信息 -// comment6.setString(new XSSFRichTextString(Translator.get("tag_tip_pattern"))); -// -// // 将批注添加到单元格对象中 -// sheet.getRow(0).getCell(1).setCellComment(comment2); -// sheet.getRow(0).getCell(1).setCellComment(comment4); -// sheet.getRow(0).getCell(1).setCellComment(comment5); -// sheet.getRow(0).getCell(1).setCellComment(comment6); -// } - } } @@ -200,6 +140,5 @@ public class FunctionCaseTemplateWriteHandler extends AbstractRowHeightStyleStra @Override protected void setContentColumnHeight(Row row, int relativeRowIndex) { - } }