Commit 4ceb93c1 authored by neo's avatar neo

[bugfix] fixed nullpoint for bb formular

parent 30bfbfc1
package pwc.taxtech.atms.dto.vatdto;
import com.fasterxml.jackson.annotation.JsonProperty;
import lombok.Getter;
import lombok.Setter;
import java.util.HashMap;
import java.util.Map;
@Getter
@Setter
public class CellTemplateConfigGroupDto {
Integer columnIndex;
Integer rowIndex;
String columnName;
String rowName;
Integer dataType;
Boolean isReadOnly;
@JsonProperty("cellTemplateID")
Long cellTemplateId;
@JsonProperty("reportTemplateID")
Long reportTemplateId;
String comment;
public CellTemplateConfigGroupDto(Integer columnIndex, Integer rowIndex
, String columnName, String rowName, Integer dataType, Boolean isReadOnly
, Long cellTemplateId, Long reportTemplateId, String comment) {
this.columnIndex = columnIndex;
this.rowIndex = rowIndex;
this.columnName = columnName;
this.rowName = rowName;
this.dataType = dataType;
this.isReadOnly = isReadOnly;
this.cellTemplateId = cellTemplateId;
this.reportTemplateId = reportTemplateId;
this.comment = comment;
}
public Map<String, Map<String, Object>> toStr() {
StringBuilder sb = new StringBuilder();
sb.append(this.getColumnIndex());
sb.append(this.getRowIndex());
sb.append(this.getColumnName());
sb.append(this.getRowName());
sb.append(this.getDataType());
sb.append(this.getIsReadOnly());
sb.append(this.getCellTemplateId());
sb.append(this.getReportTemplateId());
sb.append(this.getComment());
Map<String, Map<String, Object>> result = new HashMap<>();
Map<String, Object> map = new HashMap<>();
map.put("columnIndex", this.getColumnIndex());
map.put("rowIndex", this.getRowIndex());
map.put("columnName", this.getColumnName());
map.put("rowName", this.getRowName());
map.put("dataType", this.getDataType());
map.put("isReadOnly", this.getIsReadOnly());
map.put("cellTemplateId", this.getCellTemplateId());
map.put("reportTemplateId", this.getReportTemplateId());
map.put("comment", this.getComment());
result.put(sb.toString(), map);
return result;
}
}
......@@ -136,8 +136,6 @@ public class RuleEngineeConfigServiceImpl extends AbstractService {
if ("Add".equals(tprrdo.getAction())) {
taxPayerReportRule.setId(distributedIdService.nextId());
taxPayerReportRuleMapper.insert(taxPayerReportRule);
// operationService.addDataAddLog(taxPayerReportRule, OperationModule.RuleEngineConfig, authUserHelper.getCurrentUserId(),
// "AddRuleEngineConfiguration", "纳税类型", "纳税类型添加特殊机构", OperateLogType.OperationLogRuleEngine);
} else if ("Update".equals(tprrdo.getAction())) {
TaxPayerReportRule old = taxPayerReportRuleMapper.selectByPrimaryKey(Long.parseLong(reportDto.getId()));
TaxPayerReportRule original = new TaxPayerReportRule();
......
......@@ -20,7 +20,6 @@ import pwc.taxtech.atms.constant.enums.CellDataSourceType;
import pwc.taxtech.atms.constant.enums.FormulaDataSourceType;
import pwc.taxtech.atms.dao.ProjectMapper;
import pwc.taxtech.atms.dto.vatdto.CellCalcInfoDto;
import pwc.taxtech.atms.dto.vatdto.CellTemplateConfigGroupDto;
import pwc.taxtech.atms.entity.Project;
import pwc.taxtech.atms.service.impl.DistributedIdService;
import pwc.taxtech.atms.service.impl.HttpFileService;
......@@ -526,32 +525,33 @@ public class ReportGeneratorImpl {
fixedPCTParsedFormula(periodCellTemplateConfigExtendDtos, projectId, period);
List<CellCalcInfoDto> cellCalcInfoDtos = new ArrayList<>();
periodCellTemplateConfigExtendDtos.stream().collect(Collectors.groupingBy(a ->
new CellTemplateConfigGroupDto(a.getColumnIndex(), a.getRowIndex()
, a.getColumnName(), a.getRowName(), a.getDataType(), a.getReadOnly()
, a.getCellTemplateId(), a.getReportTemplateId(), a.getComment()).toStr())).forEach((x, y) -> {
Optional<Map<String, Object>> result = x.values().stream().findFirst();
if (result.isPresent()) {
CellCalcInfoDto cellCalcInfoDto = new CellCalcInfoDto();
cellCalcInfoDto.setColumnIndex(Integer.parseInt(result.get().get("columnIndex").toString()));
cellCalcInfoDto.setColumnName(result.get().get("columnName").toString());
cellCalcInfoDto.setRowIndex(Integer.parseInt(result.get().get("rowIndex").toString()));
cellCalcInfoDto.setRowName(result.get().get("rowName").toString());
cellCalcInfoDto.setFormula(convertListToString(y.stream()
.map(PeriodCellTemplateConfig::getFormula).collect(Collectors.toList())));
cellCalcInfoDto.setParsedFormula(convertListToString(y.stream()
.map(PeriodCellTemplateConfig::getParsedFormula).collect(Collectors.toList())));
//todo: add validation at here later
cellCalcInfoDto.setCellTemplateId(result.get().get("cellTemplateId").toString());
cellCalcInfoDto.setReportTemplateId(Long.parseLong(result.get().get("reportTemplateId").toString()));
cellCalcInfoDto.setDataType(Integer.parseInt(result.get().get("dataType").toString()));
cellCalcInfoDto.setIsReadOnly(Boolean.valueOf(result.get().get("isReadOnly").toString()));
cellCalcInfoDto.setComment(result.get().get("comment").toString());
cellCalcInfoDto.setConfigList(y.stream()
.map(PeriodCellTemplateConfigExtendDto::getPeriodCellTemplateConfig)
.collect(Collectors.toList()));
cellCalcInfoDtos.add(cellCalcInfoDto);
}
Map<String, List<PeriodCellTemplateConfigExtendDto>> myStream = new HashMap<>();
for (PeriodCellTemplateConfigExtendDto pctce : periodCellTemplateConfigExtendDtos) {
String key = pctce.getRowIndex() + "_" + pctce.getColumnIndex() + "_" + pctce.getReportTemplateID();
if (!myStream.containsKey(key)) myStream.put(key, new ArrayList<>());
myStream.get(key).add(pctce);
}
myStream.keySet().forEach(m -> {
PeriodCellTemplateConfigExtendDto first = myStream.get(m).get(0);
CellCalcInfoDto cellCalcInfoDto = new CellCalcInfoDto();
cellCalcInfoDto.setColumnIndex(first.getColumnIndex());
cellCalcInfoDto.setColumnName(first.getColumnName());
cellCalcInfoDto.setRowIndex(first.getRowIndex());
cellCalcInfoDto.setRowName(first.getRowName());
cellCalcInfoDto.setFormula(convertListToString(myStream.get(m).stream()
.map(PeriodCellTemplateConfig::getFormula).collect(Collectors.toList())));
cellCalcInfoDto.setParsedFormula(convertListToString(myStream.get(m).stream()
.map(PeriodCellTemplateConfig::getParsedFormula).collect(Collectors.toList())));
//todo: add validation at here later
cellCalcInfoDto.setCellTemplateId(first.getCellTemplateID() + "");
cellCalcInfoDto.setReportTemplateId(first.getReportTemplateId());
cellCalcInfoDto.setDataType(first.getDataType());
cellCalcInfoDto.setIsReadOnly(first.getReadOnly());
cellCalcInfoDto.setComment(first.getComment());
cellCalcInfoDto.setConfigList(myStream.get(m).stream()
.map(PeriodCellTemplateConfigExtendDto::getPeriodCellTemplateConfig).collect(Collectors.toList()));
cellCalcInfoDtos.add(cellCalcInfoDto);
});
return cellCalcInfoDtos;
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment