202501010 更新
1.新增可导入检材信息功能
This commit is contained in:
@@ -1,38 +0,0 @@
|
|||||||
//package digital.laboratory.platform.entrustment.config;
|
|
||||||
//
|
|
||||||
//import digital.laboratory.platform.entrustment.enums.EntrustEvent;
|
|
||||||
//import digital.laboratory.platform.entrustment.enums.EntrustStatusConstants;
|
|
||||||
//import org.springframework.beans.factory.annotation.Value;
|
|
||||||
//import org.springframework.context.annotation.Configuration;
|
|
||||||
//import org.springframework.statemachine.config.EnumStateMachineConfigurerAdapter;
|
|
||||||
//import org.springframework.statemachine.config.builders.StateMachineStateConfigurer;
|
|
||||||
//
|
|
||||||
///**
|
|
||||||
// * @author ChenJiangBao
|
|
||||||
// * @version 1.0
|
|
||||||
// * @description: 委托状态机配置类
|
|
||||||
// * @date 2025/3/14 11:47
|
|
||||||
// */
|
|
||||||
//@Configuration
|
|
||||||
//public class EntrustStateMachineConfig extends EnumStateMachineConfigurerAdapter<EntrustStatusConstants, EntrustEvent> {
|
|
||||||
//
|
|
||||||
// @Value("${dlp.entrustment.isApprovalRequired}")
|
|
||||||
// private boolean isApprovalRequired; // 动态标志判断是否需要审批
|
|
||||||
//
|
|
||||||
// @Override
|
|
||||||
// public void configure(StateMachineStateConfigurer<EntrustStatusConstants, EntrustEvent> states) throws Exception {
|
|
||||||
// states.withStates()
|
|
||||||
// .initial(EntrustStatusConstants.ENTRUST_STATUS_CREATED)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_WAITING_CHECK_CLAIM)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_WAITING_CHECK)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_WAITING_CONFIRM)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_WAITING_DELIVER)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_WAITING_ACCEPT)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_TEST_FINISH)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_COMPLETED)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_TERMINATED)
|
|
||||||
// .state(EntrustStatusConstants.ENTRUST_STATUS_ABORTED)
|
|
||||||
// .end(EntrustStatusConstants.ENTRUST_STATUS_COMPLETED);
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
@@ -3,7 +3,7 @@ package digital.laboratory.platform.entrustment.constant;
|
|||||||
/**
|
/**
|
||||||
* 统计的各个中文名称常量接口
|
* 统计的各个中文名称常量接口
|
||||||
*/
|
*/
|
||||||
public interface EntrustMarkConstants {
|
public interface EntrustConstants {
|
||||||
|
|
||||||
String CASE_ACCEPT = "案件受理";
|
String CASE_ACCEPT = "案件受理";
|
||||||
|
|
||||||
@@ -19,6 +19,4 @@ public interface EntrustMarkConstants {
|
|||||||
Integer LOCAL_SYSTEM = 0; // 本系统数据
|
Integer LOCAL_SYSTEM = 0; // 本系统数据
|
||||||
|
|
||||||
Integer THIRD_PARTY_SYSTEM = 1; // 大数据平台同步过来的数据
|
Integer THIRD_PARTY_SYSTEM = 1; // 大数据平台同步过来的数据
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -25,6 +25,17 @@ public class ExcelOperationController {
|
|||||||
@Resource
|
@Resource
|
||||||
private ExcelOperationService excelOperationService;
|
private ExcelOperationService excelOperationService;
|
||||||
|
|
||||||
|
@ApiOperation("检材信息导入接口")
|
||||||
|
@PostMapping("/importMaterialInfo")
|
||||||
|
public R importMaterialInfo(@RequestPart("file") MultipartFile file, @RequestParam("entrustId") String entrustId) {
|
||||||
|
try {
|
||||||
|
return excelOperationService.importMaterialInfo(file, entrustId) ? R.ok("检材信息导入成功!") : R.failed("检材信息导入失败!");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
return R.failed(e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ApiOperation("上传两社人员名单excel文件")
|
@ApiOperation("上传两社人员名单excel文件")
|
||||||
@PostMapping("/uploadHairInspect")
|
@PostMapping("/uploadHairInspect")
|
||||||
public R<Boolean> uploadHairInspectExcel(@RequestPart("file") MultipartFile file, @RequestParam("entrustId") String entrustId) {
|
public R<Boolean> uploadHairInspectExcel(@RequestPart("file") MultipartFile file, @RequestParam("entrustId") String entrustId) {
|
||||||
|
|||||||
@@ -46,4 +46,14 @@ public enum AnalysisOptionEnums {
|
|||||||
}
|
}
|
||||||
throw new IllegalArgumentException("No enum constant with code: " + code);
|
throw new IllegalArgumentException("No enum constant with code: " + code);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 根据描述获取枚举值
|
||||||
|
public static AnalysisOptionEnums fromDesc(String desc) {
|
||||||
|
for (AnalysisOptionEnums analysisOption : values()) {
|
||||||
|
if (analysisOption.getChineseName().equals(desc)) {
|
||||||
|
return analysisOption;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
throw new IllegalArgumentException("No enum constant with description: " + desc);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,4 +29,11 @@ public interface ExcelOperationService {
|
|||||||
*/
|
*/
|
||||||
void exportByEntrustOrg(Integer year, HttpServletResponse response) throws IOException;
|
void exportByEntrustOrg(Integer year, HttpServletResponse response) throws IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导入检材信息
|
||||||
|
* @param file
|
||||||
|
* @param entrustId
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
Boolean importMaterialInfo(MultipartFile file, String entrustId) throws Exception;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ import digital.laboratory.platform.common.feign.RemoteWord2PDFService;
|
|||||||
import digital.laboratory.platform.common.mybatis.security.service.DLPUser;
|
import digital.laboratory.platform.common.mybatis.security.service.DLPUser;
|
||||||
import digital.laboratory.platform.common.oss.service.OssFile;
|
import digital.laboratory.platform.common.oss.service.OssFile;
|
||||||
import digital.laboratory.platform.common.security.util.SecurityUtils;
|
import digital.laboratory.platform.common.security.util.SecurityUtils;
|
||||||
import digital.laboratory.platform.entrustment.constant.EntrustMarkConstants;
|
import digital.laboratory.platform.entrustment.constant.EntrustConstants;
|
||||||
import digital.laboratory.platform.entrustment.convert.DrugLiteConvert;
|
import digital.laboratory.platform.entrustment.convert.DrugLiteConvert;
|
||||||
import digital.laboratory.platform.entrustment.dto.EntrustmentDTO;
|
import digital.laboratory.platform.entrustment.dto.EntrustmentDTO;
|
||||||
import digital.laboratory.platform.entrustment.entity.*;
|
import digital.laboratory.platform.entrustment.entity.*;
|
||||||
@@ -3309,34 +3309,34 @@ public class EntrustmentServiceImpl extends ServiceImpl<EntrustmentMapper, Entru
|
|||||||
log.error("通过查询接口调用获取污水系统统计数据失败!失败原因:{}", statisticsDiffStatusJobDTOR.getMsg());
|
log.error("通过查询接口调用获取污水系统统计数据失败!失败原因:{}", statisticsDiffStatusJobDTOR.getMsg());
|
||||||
}
|
}
|
||||||
|
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.CASE_ACCEPT,
|
markersVOS.add(new MarkersVO(EntrustConstants.CASE_ACCEPT,
|
||||||
entrustListMap.getOrDefault(
|
entrustListMap.getOrDefault(
|
||||||
StrUtil.join("_", EntrustMarkConstants.LOCAL_SYSTEM, EntrustStatusConstants.ENTRUST_STATUS_WAITING_ACCEPT.getStatus()),
|
StrUtil.join("_", EntrustConstants.LOCAL_SYSTEM, EntrustStatusConstants.ENTRUST_STATUS_WAITING_ACCEPT.getStatus()),
|
||||||
Collections.EMPTY_LIST
|
Collections.EMPTY_LIST
|
||||||
).size(),
|
).size(),
|
||||||
String.format("待受理(%s)", EntrustMarkConstants.PUBLIC_SECURITY_BUREAU)));
|
String.format("待受理(%s)", EntrustConstants.PUBLIC_SECURITY_BUREAU)));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.CASE_ACCEPT,
|
markersVOS.add(new MarkersVO(EntrustConstants.CASE_ACCEPT,
|
||||||
entrustListMap.getOrDefault(
|
entrustListMap.getOrDefault(
|
||||||
StrUtil.join("_", EntrustMarkConstants.THIRD_PARTY_SYSTEM, EntrustStatusConstants.ENTRUST_STATUS_WAITING_ACCEPT.getStatus()),
|
StrUtil.join("_", EntrustConstants.THIRD_PARTY_SYSTEM, EntrustStatusConstants.ENTRUST_STATUS_WAITING_ACCEPT.getStatus()),
|
||||||
Collections.EMPTY_LIST
|
Collections.EMPTY_LIST
|
||||||
).size(),
|
).size(),
|
||||||
"待受理 (大数据平台)"));
|
"待受理 (大数据平台)"));
|
||||||
List<Entrustment> entrustListMapOrDefault = entrustListMap.getOrDefault(
|
List<Entrustment> entrustListMapOrDefault = entrustListMap.getOrDefault(
|
||||||
StrUtil.join("_", EntrustMarkConstants.LOCAL_SYSTEM, EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED.getStatus()), Collections.EMPTY_LIST
|
StrUtil.join("_", EntrustConstants.LOCAL_SYSTEM, EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED.getStatus()), Collections.EMPTY_LIST
|
||||||
);
|
);
|
||||||
// o.getAcceptTime().isAfter(LocalDateTime.of(LocalDate.now().withDayOfYear(1), LocalTime.MIN)) 筛选出当年的数据
|
// o.getAcceptTime().isAfter(LocalDateTime.of(LocalDate.now().withDayOfYear(1), LocalTime.MIN)) 筛选出当年的数据
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.CASE_ACCEPT,
|
markersVOS.add(new MarkersVO(EntrustConstants.CASE_ACCEPT,
|
||||||
entrustListMapOrDefault.stream().filter(o ->
|
entrustListMapOrDefault.stream().filter(o ->
|
||||||
o.getAcceptTime().isAfter(LocalDateTime.of(LocalDate.now().withDayOfYear(1), LocalTime.MIN))
|
o.getAcceptTime().isAfter(LocalDateTime.of(LocalDate.now().withDayOfYear(1), LocalTime.MIN))
|
||||||
&& EntrustStatusConstants.geAcceptedStatus(o.getStatus())
|
&& EntrustStatusConstants.geAcceptedStatus(o.getStatus())
|
||||||
).collect(Collectors.toList()).size(),
|
).collect(Collectors.toList()).size(),
|
||||||
String.format("已受理 (%s)", EntrustMarkConstants.PUBLIC_SECURITY_BUREAU)));
|
String.format("已受理 (%s)", EntrustConstants.PUBLIC_SECURITY_BUREAU)));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.CASE_ACCEPT,
|
markersVOS.add(new MarkersVO(EntrustConstants.CASE_ACCEPT,
|
||||||
entrustListMap.getOrDefault(
|
entrustListMap.getOrDefault(
|
||||||
StrUtil.join("_", EntrustMarkConstants.THIRD_PARTY_SYSTEM, EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED.getStatus()), Collections.EMPTY_LIST
|
StrUtil.join("_", EntrustConstants.THIRD_PARTY_SYSTEM, EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED.getStatus()), Collections.EMPTY_LIST
|
||||||
).size(),
|
).size(),
|
||||||
"已受理 (大数据平台)"));
|
"已受理 (大数据平台)"));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.CASE_ACCEPT,
|
markersVOS.add(new MarkersVO(EntrustConstants.CASE_ACCEPT,
|
||||||
this.list(Wrappers.<Entrustment>lambdaQuery()
|
this.list(Wrappers.<Entrustment>lambdaQuery()
|
||||||
.ge(Entrustment::getStatus, EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED.getStatus())
|
.ge(Entrustment::getStatus, EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED.getStatus())
|
||||||
.inSql(Entrustment::getId, "SELECT entrust_id FROM b_entrust_material_checkout_result"))
|
.inSql(Entrustment::getId, "SELECT entrust_id FROM b_entrust_material_checkout_result"))
|
||||||
@@ -3349,34 +3349,34 @@ public class EntrustmentServiceImpl extends ServiceImpl<EntrustmentMapper, Entru
|
|||||||
.size(),
|
.size(),
|
||||||
"检测结果")
|
"检测结果")
|
||||||
);
|
);
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.REVIEW_OR_APPROVAL,
|
markersVOS.add(new MarkersVO(EntrustConstants.REVIEW_OR_APPROVAL,
|
||||||
REVIEW_STATUS_GROUP1.stream()
|
REVIEW_STATUS_GROUP1.stream()
|
||||||
.mapToInt(status -> entrustListMap.getOrDefault(EntrustMarkConstants.LOCAL_SYSTEM + "_" + status, Collections.emptyList()).size())
|
.mapToInt(status -> entrustListMap.getOrDefault(EntrustConstants.LOCAL_SYSTEM + "_" + status, Collections.emptyList()).size())
|
||||||
.sum(),
|
.sum(),
|
||||||
String.format("委托审核(%s)", EntrustMarkConstants.PUBLIC_SECURITY_BUREAU)));
|
String.format("委托审核(%s)", EntrustConstants.PUBLIC_SECURITY_BUREAU)));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.REVIEW_OR_APPROVAL,
|
markersVOS.add(new MarkersVO(EntrustConstants.REVIEW_OR_APPROVAL,
|
||||||
REVIEW_STATUS_GROUP2.stream()
|
REVIEW_STATUS_GROUP2.stream()
|
||||||
.mapToInt(status -> entrustListMap.getOrDefault(EntrustMarkConstants.LOCAL_SYSTEM + "_" + status, Collections.emptyList()).size())
|
.mapToInt(status -> entrustListMap.getOrDefault(EntrustConstants.LOCAL_SYSTEM + "_" + status, Collections.emptyList()).size())
|
||||||
.sum(),
|
.sum(),
|
||||||
String.format("委托审批(%s)", EntrustMarkConstants.PUBLIC_SECURITY_BUREAU)));
|
String.format("委托审批(%s)", EntrustConstants.PUBLIC_SECURITY_BUREAU)));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.REVIEW_OR_APPROVAL,
|
markersVOS.add(new MarkersVO(EntrustConstants.REVIEW_OR_APPROVAL,
|
||||||
REVIEW_STATUS_GROUP1.stream()
|
REVIEW_STATUS_GROUP1.stream()
|
||||||
.mapToInt(status -> entrustListMap.getOrDefault(EntrustMarkConstants.THIRD_PARTY_SYSTEM + "_" + status, Collections.emptyList()).size())
|
.mapToInt(status -> entrustListMap.getOrDefault(EntrustConstants.THIRD_PARTY_SYSTEM + "_" + status, Collections.emptyList()).size())
|
||||||
.sum(),
|
.sum(),
|
||||||
"委托审核(大数据平台)"));
|
"委托审核(大数据平台)"));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.REVIEW_OR_APPROVAL,
|
markersVOS.add(new MarkersVO(EntrustConstants.REVIEW_OR_APPROVAL,
|
||||||
REVIEW_STATUS_GROUP2.stream()
|
REVIEW_STATUS_GROUP2.stream()
|
||||||
.mapToInt(status -> entrustListMap.getOrDefault(EntrustMarkConstants.LOCAL_SYSTEM + "_" + status, Collections.emptyList()).size())
|
.mapToInt(status -> entrustListMap.getOrDefault(EntrustConstants.LOCAL_SYSTEM + "_" + status, Collections.emptyList()).size())
|
||||||
.sum(),
|
.sum(),
|
||||||
"委托审批(大数据平台)"));
|
"委托审批(大数据平台)"));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.REVIEW_OR_APPROVAL,
|
markersVOS.add(new MarkersVO(EntrustConstants.REVIEW_OR_APPROVAL,
|
||||||
(int) entrustAlterApplyService.count(Wrappers.<EntrustAlterApply>lambdaQuery()
|
(int) entrustAlterApplyService.count(Wrappers.<EntrustAlterApply>lambdaQuery()
|
||||||
.eq(EntrustAlterApply::getStatus, EntrustAlterApplyStatus.SUBMITTED_WAIT_APPROVE.getStatus())),
|
.eq(EntrustAlterApply::getStatus, EntrustAlterApplyStatus.SUBMITTED_WAIT_APPROVE.getStatus())),
|
||||||
"委托修改审核"));
|
"委托修改审核"));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.SEWAGE_JOB_ACCEPT, statisticsDiffStatusSewageJobDTO.getJobStatusCreatedNum(), "污水任务待发布"));
|
markersVOS.add(new MarkersVO(EntrustConstants.SEWAGE_JOB_ACCEPT, statisticsDiffStatusSewageJobDTO.getJobStatusCreatedNum(), "污水任务待发布"));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.SEWAGE_JOB_ACCEPT, statisticsDiffStatusSewageJobDTO.getJobStatusClaimNum(), "污水任务已发布"));
|
markersVOS.add(new MarkersVO(EntrustConstants.SEWAGE_JOB_ACCEPT, statisticsDiffStatusSewageJobDTO.getJobStatusClaimNum(), "污水任务已发布"));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.SEWAGE_JOB_ACCEPT, statisticsDiffStatusSewageJobDTO.getJobStatusClaimNum(), "污水受理"));
|
markersVOS.add(new MarkersVO(EntrustConstants.SEWAGE_JOB_ACCEPT, statisticsDiffStatusSewageJobDTO.getJobStatusClaimNum(), "污水受理"));
|
||||||
markersVOS.add(new MarkersVO(EntrustMarkConstants.SEWAGE_JOB_ACCEPT, statisticsDiffStatusSewageJobDTO.getSewageTreatmentPlantNum(), "污水厂管理"));
|
markersVOS.add(new MarkersVO(EntrustConstants.SEWAGE_JOB_ACCEPT, statisticsDiffStatusSewageJobDTO.getSewageTreatmentPlantNum(), "污水厂管理"));
|
||||||
|
|
||||||
return markersVOS;
|
return markersVOS;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package digital.laboratory.platform.entrustment.service.impl;
|
package digital.laboratory.platform.entrustment.service.impl;
|
||||||
|
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
|
import cn.hutool.core.util.StrUtil;
|
||||||
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
||||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
import digital.laboratory.platform.common.core.constant.CommonConstants;
|
import digital.laboratory.platform.common.core.constant.CommonConstants;
|
||||||
@@ -25,6 +26,7 @@ import org.apache.poi.ss.usermodel.*;
|
|||||||
import org.apache.poi.ss.util.CellRangeAddress;
|
import org.apache.poi.ss.util.CellRangeAddress;
|
||||||
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
@@ -40,6 +42,7 @@ import java.time.temporal.ChronoUnit;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@@ -86,142 +89,71 @@ public class ExcelOperationServiceImpl implements ExcelOperationService {
|
|||||||
* @throws Exception 发生异常时抛出
|
* @throws Exception 发生异常时抛出
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
public Boolean uploadHairInspectExcel(MultipartFile file, String entrustId) throws Exception {
|
public Boolean uploadHairInspectExcel(MultipartFile file, String entrustId) throws Exception {
|
||||||
|
// ---------- 1. 校验委托合法性 ----------
|
||||||
// 1. 校验委托合法性
|
|
||||||
Entrustment entrustment = entrustmentService.getById(entrustId);
|
Entrustment entrustment = entrustmentService.getById(entrustId);
|
||||||
if (entrustment == null) {
|
if (entrustment == null) {
|
||||||
throw new CheckedException(String.format("委托id为 %s 的委托信息不存在!", entrustId));
|
throw new CheckedException(String.format("委托ID为 %s 的委托信息不存在!", entrustId));
|
||||||
}
|
|
||||||
if (!entrustment.getOldIdentificationResult().equals(EntrustIdentificationSituationType.TWO_AGENCY.getDesc())) {
|
|
||||||
throw new CheckedException("当前不支持两社人员之外的委托信息进行导入!");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. 获取案件与毒品信息
|
if (!EntrustIdentificationSituationType.TWO_AGENCY.getDesc().equals(entrustment.getOldIdentificationResult())) {
|
||||||
// 2.1 校验案件信息
|
throw new CheckedException("当前仅支持‘两社人员’类型的委托信息进行导入!");
|
||||||
CaseEvent cj = caseEventService.validateCaseInfo(entrustment.getCaseId());
|
|
||||||
|
|
||||||
// 2.2 获取默认毒品(海洛因)
|
|
||||||
|
|
||||||
|
|
||||||
// 2.3 获取所有毒品名称映射(便于匹配检测结果)
|
|
||||||
R<List<DrugLite>> innerGetAllR = remoteCommDrugService.innerGetAll();
|
|
||||||
List<DrugLite> drugLiteList = innerGetAllR.getData();
|
|
||||||
Map<String, DrugLite> drugLiteMap = drugLiteList.stream()
|
|
||||||
.collect(Collectors.toMap(DrugLite::getName, Function.identity()));
|
|
||||||
|
|
||||||
// 3. 读取Excel内容(从第一行数据开始读取)
|
|
||||||
int headIndex = 0;
|
|
||||||
List<Map<String, String>> data = ExcelUtils.readExcel(file, headIndex);
|
|
||||||
|
|
||||||
// 3.1 获取当前委托下已有检材数,作为orderNo起始编号
|
|
||||||
int orderNo = entrustmentIdentificationMaterialService.lambdaQuery()
|
|
||||||
.eq(EntrustmentIdentificationMaterial::getEntrustmentId, entrustId)
|
|
||||||
.list().size() + 1;
|
|
||||||
|
|
||||||
// 3.2 初始化结果对象集合
|
|
||||||
List<EntrustMaterialCheckoutResult> results = new ArrayList<>();
|
|
||||||
|
|
||||||
ArrayList<Suspect> suspects = new ArrayList<>();
|
|
||||||
for (Map<String, String> datum : data) {
|
|
||||||
Suspect suspect = new Suspect();
|
|
||||||
suspect.setName(datum.get("姓名"));
|
|
||||||
suspect.setIdNumber(datum.get("身份证号"));
|
|
||||||
suspects.add(suspect);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ---------- 2. 校验案件信息 ----------
|
||||||
|
CaseEvent caseEvent = caseEventService.validateCaseInfo(entrustment.getCaseId());
|
||||||
|
|
||||||
|
// ---------- 3. 获取毒品名称映射 ----------
|
||||||
|
Map<String, DrugLite> drugMap = getDrugLiteMap();
|
||||||
|
|
||||||
|
// ---------- 4. 读取 Excel 数据 ----------
|
||||||
|
final int headerRowIndex = 0;
|
||||||
|
List<Map<String, String>> excelData = ExcelUtils.readExcel(file, headerRowIndex);
|
||||||
|
if (CollUtil.isEmpty(excelData)) {
|
||||||
|
throw new CheckedException("Excel 文件内容为空!");
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---------- 5. 处理嫌疑人信息 ----------
|
||||||
|
List<Suspect> suspects = excelData.stream()
|
||||||
|
.map(row -> {
|
||||||
|
Suspect s = new Suspect();
|
||||||
|
s.setName(row.get("姓名"));
|
||||||
|
s.setIdNumber(row.get("身份证号"));
|
||||||
|
return s;
|
||||||
|
})
|
||||||
|
.filter(s -> StrUtil.isNotBlank(s.getName()))
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
|
||||||
if (CollUtil.isNotEmpty(suspects)) {
|
if (CollUtil.isNotEmpty(suspects)) {
|
||||||
|
// 删除旧嫌疑人信息
|
||||||
suspectService.remove(Wrappers.<Suspect>lambdaQuery()
|
suspectService.remove(Wrappers.<Suspect>lambdaQuery()
|
||||||
.eq(Suspect::getEntrustId, entrustId));
|
.eq(Suspect::getEntrustId, entrustId));
|
||||||
|
// 保存新嫌疑人信息
|
||||||
suspectService.addSuspectList(suspects, entrustId);
|
suspectService.addSuspectList(suspects, entrustId);
|
||||||
}
|
}
|
||||||
List<EntrustmentIdentificationMaterial> entrustmentIdentificationMaterialList = new ArrayList<>();
|
|
||||||
|
|
||||||
// 4. 遍历Excel数据行,构建检材与检测结果
|
// ---------- 6. 构建检材与检测结果 ----------
|
||||||
processExcelDataToMaterialEntity(data, entrustment, drugLiteMap, orderNo, cj, entrustmentIdentificationMaterialList);
|
Long existingMaterialCount = entrustmentIdentificationMaterialService.lambdaQuery()
|
||||||
// entrustMaterialCheckoutResultService.saveBatch(results);
|
.eq(EntrustmentIdentificationMaterial::getEntrustmentId, entrustId)
|
||||||
boolean isSave = entrustmentIdentificationMaterialService.saveBatch(entrustmentIdentificationMaterialList);
|
.count();
|
||||||
String entrustReq = entrustmentService.buildEntrustReq(entrustmentIdentificationMaterialList);
|
int startOrderNo = Math.toIntExact(existingMaterialCount + 1);
|
||||||
entrustment.setEntrustRequirement(entrustReq);
|
|
||||||
|
List<EntrustmentIdentificationMaterial> materialList = processHairExcelDataToMaterialEntity(excelData, entrustment, drugMap, startOrderNo, caseEvent);
|
||||||
|
|
||||||
|
// ---------- 7. 保存检材信息 ----------
|
||||||
|
boolean saveSuccess = entrustmentIdentificationMaterialService.saveBatch(materialList);
|
||||||
|
if (!saveSuccess) {
|
||||||
|
throw new CheckedException("批量保存检材信息失败!");
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---------- 8. 更新委托要求 ----------
|
||||||
|
String entrustRequirement = entrustmentService.buildEntrustReq(materialList);
|
||||||
|
entrustment.setEntrustRequirement(entrustRequirement);
|
||||||
entrustmentService.updateById(entrustment);
|
entrustmentService.updateById(entrustment);
|
||||||
// 5. 批量保存检材信息和检测结果
|
|
||||||
return isSave;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
// ---------- 9. 返回执行结果 ----------
|
||||||
* 处理Excel数据,构建检材对象并设置相关属性
|
return true;
|
||||||
* @param data Excel数据列表
|
|
||||||
* @param entrustment 委托信息对象
|
|
||||||
* @param drugLiteMap 毒品名称映射表
|
|
||||||
* @param orderNo 检材序号起始值
|
|
||||||
* @param cj 案件信息对象
|
|
||||||
* @param entrustmentIdentificationMaterialList 检材列表对象集合
|
|
||||||
*/
|
|
||||||
private void processExcelDataToMaterialEntity(List<Map<String, String>> data, Entrustment entrustment, Map<String, DrugLite> drugLiteMap, int orderNo, CaseEvent cj, List<EntrustmentIdentificationMaterial> entrustmentIdentificationMaterialList) {
|
|
||||||
for (Map<String, String> datum : data) {
|
|
||||||
// 构建检材对象
|
|
||||||
EntrustmentIdentificationMaterial material = new EntrustmentIdentificationMaterial();
|
|
||||||
material.setEntrustmentId(entrustment.getId());
|
|
||||||
material.setCaseId(entrustment.getCaseId());
|
|
||||||
material.setName(datum.get("姓名") + "毛发");
|
|
||||||
material.setRemark(datum.get("身份证号"));
|
|
||||||
|
|
||||||
// 解析身份证号
|
|
||||||
String idNum = datum.get("身份证号");
|
|
||||||
if (idNum != null && idNum.length() == 18) {
|
|
||||||
material.setBiologyGender(this.getSexByIdNum(idNum));
|
|
||||||
material.setMaterialAge(Integer.valueOf(this.getAgeByIdNum(idNum)));
|
|
||||||
}
|
|
||||||
|
|
||||||
material.setDrawPlace(datum.get("采样单位"));
|
|
||||||
material.setId(IdWorker.get32UUID().toUpperCase());
|
|
||||||
|
|
||||||
// 检测结果解析
|
|
||||||
ArrayList<DrugLite> matchedDrugs = new ArrayList<>();
|
|
||||||
String[] drugs = datum.get("检测结果").split("、");
|
|
||||||
if (drugs.length == 0 || (drugs.length == 1 && drugs[0].trim().isEmpty())) {
|
|
||||||
matchedDrugs.add(drugLiteMap.get("海洛因"));
|
|
||||||
} else {
|
|
||||||
for (String drugName : drugs) {
|
|
||||||
if (drugLiteMap.containsKey(drugName)) {
|
|
||||||
matchedDrugs.add(drugLiteMap.get(drugName));
|
|
||||||
} else {
|
|
||||||
// 未匹配到任何已知毒品,则调用接口保存
|
|
||||||
DrugLite newDrug = new DrugLite();
|
|
||||||
newDrug.setId(IdWorker.get32UUID().toUpperCase());
|
|
||||||
newDrug.setName(drugName);
|
|
||||||
R<Boolean> booleanR = remoteCommDrugService.innerSaveDrug(newDrug);
|
|
||||||
if (booleanR.getCode() == CommonConstants.FAIL) {
|
|
||||||
throw new CheckedException("新增未知毒品失败!");
|
|
||||||
}
|
|
||||||
// 更新缓存 Map,避免重复插入
|
|
||||||
drugLiteMap.put(drugName, newDrug);
|
|
||||||
matchedDrugs.add(newDrug);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
material.setCandidateDrugs(matchedDrugs);
|
|
||||||
|
|
||||||
// 设置检材默认属性
|
|
||||||
material.setBiologyType(EntrustBiologyType.HAIR.getDesc());
|
|
||||||
material.setType("1");
|
|
||||||
material.setTypeName("生物样本");
|
|
||||||
material.setQuantity(new BigDecimal(50));
|
|
||||||
material.setUnit("mg");
|
|
||||||
material.setForm("黑色头发");
|
|
||||||
material.setFormName("黑色头发");
|
|
||||||
material.setOrderNo(orderNo);
|
|
||||||
material.setImEntrustNumber(String.valueOf(orderNo));
|
|
||||||
orderNo++;
|
|
||||||
material.setPackComplete(true);
|
|
||||||
material.setRtSampleQuantity(0);
|
|
||||||
material.setDrawTime(LocalDateTime.now());
|
|
||||||
material.setAnalysisOption(AnalysisOptionEnums.QUALITATIVE.getCode());
|
|
||||||
|
|
||||||
entrustmentIdentificationMaterialService.setMaterialIdentificationNo(material, cj);
|
|
||||||
material.setSample1No(sampleService.getNewSampleNo(material.getImNo(), 1));
|
|
||||||
|
|
||||||
entrustmentIdentificationMaterialList.add(material);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -238,7 +170,7 @@ public class ExcelOperationServiceImpl implements ExcelOperationService {
|
|||||||
Wrappers.<Entrustment>query()
|
Wrappers.<Entrustment>query()
|
||||||
.eq("e.client_org_id", user.getOrgId())
|
.eq("e.client_org_id", user.getOrgId())
|
||||||
.eq("e.status", EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED.getStatus())
|
.eq("e.status", EntrustStatusConstants.ENTRUST_STATUS_ACCEPTED.getStatus())
|
||||||
.likeRight(year != null , "e.accept_time", year)
|
.likeRight(year != null, "e.accept_time", year)
|
||||||
.orderByDesc("e.accept_time")
|
.orderByDesc("e.accept_time")
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -258,7 +190,6 @@ public class ExcelOperationServiceImpl implements ExcelOperationService {
|
|||||||
Map<String, List<EntrustmentIdentificationMaterial>> materialGroupMap = identificationMaterials.stream().collect(Collectors.groupingBy(EntrustmentIdentificationMaterial::getEntrustmentId));
|
Map<String, List<EntrustmentIdentificationMaterial>> materialGroupMap = identificationMaterials.stream().collect(Collectors.groupingBy(EntrustmentIdentificationMaterial::getEntrustmentId));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// 获取嫌疑人信息并根据委托id分组
|
// 获取嫌疑人信息并根据委托id分组
|
||||||
Map<String, String> suspectGroupMap = buildSuspectInfoGroupByEntrustId(entrustmentVOList);
|
Map<String, String> suspectGroupMap = buildSuspectInfoGroupByEntrustId(entrustmentVOList);
|
||||||
|
|
||||||
@@ -350,8 +281,236 @@ public class ExcelOperationServiceImpl implements ExcelOperationService {
|
|||||||
workbook.close();
|
workbook.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导入检材信息
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* @param entrustId
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Boolean importMaterialInfo(MultipartFile file, String entrustId) throws Exception {
|
||||||
|
// ---------- 1. 校验委托合法性 ----------
|
||||||
|
Entrustment entrustment = entrustmentService.getById(entrustId);
|
||||||
|
if (entrustment == null) {
|
||||||
|
throw new CheckedException(String.format("委托ID为 %s 的委托信息不存在!", entrustId));
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---------- 2. 校验案件信息 ----------
|
||||||
|
CaseEvent caseEvent = caseEventService.validateCaseInfo(entrustment.getCaseId());
|
||||||
|
|
||||||
|
// ---------- 3. 获取毒品名称映射 ----------
|
||||||
|
Map<String, DrugLite> drugMap = getDrugLiteMap();
|
||||||
|
|
||||||
|
// ---------- 4. 读取 Excel 数据 ----------
|
||||||
|
final int headerRowIndex = 0;
|
||||||
|
List<Map<String, String>> excelData = ExcelUtils.readExcel(file, headerRowIndex);
|
||||||
|
if (CollUtil.isEmpty(excelData)) {
|
||||||
|
throw new CheckedException("Excel 文件内容为空!");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ---------- 6. 构建检材与检测结果 ----------
|
||||||
|
Long existingMaterialCount = entrustmentIdentificationMaterialService.lambdaQuery()
|
||||||
|
.eq(EntrustmentIdentificationMaterial::getEntrustmentId, entrustId)
|
||||||
|
.count();
|
||||||
|
int startOrderNo = Math.toIntExact(existingMaterialCount + 1);
|
||||||
|
|
||||||
|
List<EntrustmentIdentificationMaterial> materialList = processExcelDataToMaterialEntity(excelData, entrustment, drugMap, startOrderNo, caseEvent);
|
||||||
|
|
||||||
|
// ---------- 7. 保存检材信息 ----------
|
||||||
|
boolean saveSuccess = entrustmentIdentificationMaterialService.saveBatch(materialList);
|
||||||
|
if (!saveSuccess) {
|
||||||
|
throw new CheckedException("批量保存检材信息失败!");
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---------- 8. 更新委托要求 ----------
|
||||||
|
String entrustRequirement = entrustmentService.buildEntrustReq(materialList);
|
||||||
|
entrustment.setEntrustRequirement(entrustRequirement);
|
||||||
|
entrustmentService.updateById(entrustment);
|
||||||
|
|
||||||
|
// ---------- 9. 返回执行结果 ----------
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取毒品清单信息,并转成map
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
private Map<String, DrugLite> getDrugLiteMap() {
|
||||||
|
R<List<DrugLite>> drugResponse = remoteCommDrugService.innerGetAll();
|
||||||
|
List<DrugLite> drugList = Optional
|
||||||
|
.ofNullable(drugResponse.getData())
|
||||||
|
.orElseThrow(
|
||||||
|
() -> new CheckedException("获取毒品信息失败!")
|
||||||
|
);
|
||||||
|
Map<String, DrugLite> drugMap = drugList.stream()
|
||||||
|
.collect(Collectors.toMap(DrugLite::getName, Function.identity()));
|
||||||
|
return drugMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 处理毛发两社人员Excel数据,构建检材对象并设置相关属性
|
||||||
|
*
|
||||||
|
* @param data Excel数据列表
|
||||||
|
* @param entrustment 委托信息对象
|
||||||
|
* @param drugLiteMap 毒品名称映射表
|
||||||
|
* @param orderNo 检材序号起始值
|
||||||
|
* @param cj 案件信息对象
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
private List<EntrustmentIdentificationMaterial> processHairExcelDataToMaterialEntity(List<Map<String, String>> data, Entrustment entrustment, Map<String, DrugLite> drugLiteMap, int orderNo, CaseEvent cj) {
|
||||||
|
List<EntrustmentIdentificationMaterial> entrustmentIdentificationMaterialList = new ArrayList<>();
|
||||||
|
for (Map<String, String> datum : data) {
|
||||||
|
// 构建检材对象
|
||||||
|
EntrustmentIdentificationMaterial material = new EntrustmentIdentificationMaterial();
|
||||||
|
material.setEntrustmentId(entrustment.getId());
|
||||||
|
material.setCaseId(entrustment.getCaseId());
|
||||||
|
material.setName(datum.get("姓名") + "毛发");
|
||||||
|
material.setRemark(datum.get("身份证号"));
|
||||||
|
|
||||||
|
// 解析身份证号
|
||||||
|
String idNum = datum.get("身份证号");
|
||||||
|
if (idNum != null && idNum.length() == 18) {
|
||||||
|
material.setBiologyGender(this.getSexByIdNum(idNum));
|
||||||
|
material.setMaterialAge(Integer.valueOf(this.getAgeByIdNum(idNum)));
|
||||||
|
}
|
||||||
|
|
||||||
|
material.setDrawPlace(datum.get("采样单位"));
|
||||||
|
material.setId(IdWorker.get32UUID().toUpperCase());
|
||||||
|
|
||||||
|
// 检测结果解析
|
||||||
|
String[] drugs = datum.get("检测结果").split("、");
|
||||||
|
buildMatchedDrugs(drugLiteMap, material, drugs);
|
||||||
|
|
||||||
|
// 设置检材默认属性
|
||||||
|
material.setBiologyType(EntrustBiologyType.HAIR.getDesc());
|
||||||
|
material.setType("1");
|
||||||
|
material.setTypeName("生物样本");
|
||||||
|
material.setQuantity(new BigDecimal(50));
|
||||||
|
material.setUnit("mg");
|
||||||
|
material.setForm("黑色头发");
|
||||||
|
material.setFormName("黑色头发");
|
||||||
|
material.setOrderNo(orderNo);
|
||||||
|
material.setImEntrustNumber(String.valueOf(orderNo));
|
||||||
|
orderNo++;
|
||||||
|
material.setPackComplete(true);
|
||||||
|
material.setRtSampleQuantity(0);
|
||||||
|
material.setDrawTime(LocalDateTime.now());
|
||||||
|
material.setAnalysisOption(AnalysisOptionEnums.QUALITATIVE.getCode());
|
||||||
|
|
||||||
|
entrustmentIdentificationMaterialService.setMaterialIdentificationNo(material, cj);
|
||||||
|
material.setSample1No(sampleService.getNewSampleNo(material.getImNo(), 1));
|
||||||
|
|
||||||
|
entrustmentIdentificationMaterialList.add(material);
|
||||||
|
}
|
||||||
|
return entrustmentIdentificationMaterialList;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 处理委托检材Excel数据,构建检材对象并设置相关属性
|
||||||
|
*
|
||||||
|
* @param data Excel数据列表
|
||||||
|
* @param entrustment 委托信息对象
|
||||||
|
* @param drugLiteMap 毒品名称映射表
|
||||||
|
* @param orderNo 检材序号起始值
|
||||||
|
* @param cj 案件信息对象
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
private List<EntrustmentIdentificationMaterial> processExcelDataToMaterialEntity(List<Map<String, String>> data, Entrustment entrustment, Map<String, DrugLite> drugLiteMap, int orderNo, CaseEvent cj) {
|
||||||
|
List<EntrustmentIdentificationMaterial> entrustmentIdentificationMaterialList = new ArrayList<>();
|
||||||
|
for (Map<String, String> datum : data) {
|
||||||
|
// 构建检材对象
|
||||||
|
EntrustmentIdentificationMaterial material = new EntrustmentIdentificationMaterial();
|
||||||
|
material.setId(IdWorker.get32UUID().toUpperCase());
|
||||||
|
material.setEntrustmentId(entrustment.getId());
|
||||||
|
material.setCaseId(entrustment.getCaseId());
|
||||||
|
material.setName(datum.get("疑似物种类"));
|
||||||
|
material.setRtSampleQuantity(Integer.valueOf(datum.get("留存样个数")));
|
||||||
|
material.setQuantity(new BigDecimal(datum.get("重量/体积")));
|
||||||
|
material.setUnit(datum.get("单位"));
|
||||||
|
String formDesc = datum.get("性状描述");
|
||||||
|
material.setForm(formDesc);
|
||||||
|
material.setFormName(formDesc);
|
||||||
|
// 提取颜色
|
||||||
|
if (StrUtil.isNotBlank(formDesc) && formDesc.contains("色")) {
|
||||||
|
// 截取“色”之前的部分(包含“色”)
|
||||||
|
material.setColor(formDesc.substring(0, formDesc.indexOf("色") + 1));
|
||||||
|
}
|
||||||
|
material.setDrawTime(LocalDate.parse(datum.get("提取时间"), DateTimeFormatter.ofPattern("yyyy-MM-dd")).atStartOfDay());
|
||||||
|
material.setDrawPlace(datum.get("提取地点"));
|
||||||
|
|
||||||
|
// 检测结果解析
|
||||||
|
String[] drugs = datum.get("筛查目标物").split("、");
|
||||||
|
buildMatchedDrugs(drugLiteMap, material, drugs);
|
||||||
|
// 设置委托类型
|
||||||
|
material.setType(String.valueOf(entrustment.getEntrustmentType()));
|
||||||
|
if (entrustment.getEntrustmentType() == 0) {
|
||||||
|
material.setTypeName("常规毒品");
|
||||||
|
} else {
|
||||||
|
material.setTypeName("生物样本");
|
||||||
|
material.setBiologyType(EntrustBiologyType.isExist(formDesc).getDesc());
|
||||||
|
}
|
||||||
|
material.setOrderNo(orderNo);
|
||||||
|
material.setImEntrustNumber(String.valueOf(orderNo));
|
||||||
|
orderNo++;
|
||||||
|
String packageInfo = datum.get("包装信息");
|
||||||
|
if (packageInfo.equals("完整")) {
|
||||||
|
material.setPackComplete(true);
|
||||||
|
} else {
|
||||||
|
material.setPackComplete(false);
|
||||||
|
}
|
||||||
|
String age = datum.get("年龄");
|
||||||
|
if (StrUtil.isNotBlank(age)) {
|
||||||
|
material.setMaterialAge(Integer.valueOf(age));
|
||||||
|
}
|
||||||
|
material.setBiologyGender(datum.get("性别"));
|
||||||
|
material.setAnalysisOption(AnalysisOptionEnums.fromDesc(datum.get("检验项目")).getCode());
|
||||||
|
entrustmentIdentificationMaterialService.setMaterialIdentificationNo(material, cj);
|
||||||
|
material.setSample1No(sampleService.getNewSampleNo(material.getImNo(), 1));
|
||||||
|
|
||||||
|
entrustmentIdentificationMaterialList.add(material);
|
||||||
|
}
|
||||||
|
return entrustmentIdentificationMaterialList;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 构建匹配筛查目标物毒品列表
|
||||||
|
*
|
||||||
|
* @param drugLiteMap 毒品信息缓存Map
|
||||||
|
* @param material 委托鉴定检材对象
|
||||||
|
* @param drugs 待匹配毒品名称数组
|
||||||
|
* @throws CheckedException 抛出检查异常
|
||||||
|
*/
|
||||||
|
private void buildMatchedDrugs(Map<String, DrugLite> drugLiteMap, EntrustmentIdentificationMaterial material,String[] drugs) {
|
||||||
|
ArrayList<DrugLite> matchedDrugs = new ArrayList<>();
|
||||||
|
if (drugs.length == 0 || (drugs.length == 1 && drugs[0].trim().isEmpty())) {
|
||||||
|
matchedDrugs.add(drugLiteMap.get("海洛因"));
|
||||||
|
} else {
|
||||||
|
for (String drugName : drugs) {
|
||||||
|
if (drugLiteMap.containsKey(drugName)) {
|
||||||
|
matchedDrugs.add(drugLiteMap.get(drugName));
|
||||||
|
} else {
|
||||||
|
// 未匹配到任何已知毒品,则调用接口保存
|
||||||
|
DrugLite newDrug = new DrugLite();
|
||||||
|
newDrug.setId(IdWorker.get32UUID().toUpperCase());
|
||||||
|
newDrug.setName(drugName);
|
||||||
|
R<Boolean> booleanR = remoteCommDrugService.innerSaveDrug(newDrug);
|
||||||
|
if (booleanR.getCode() == CommonConstants.FAIL) {
|
||||||
|
throw new CheckedException("新增未知毒品失败!");
|
||||||
|
}
|
||||||
|
// 更新缓存 Map,避免重复插入
|
||||||
|
drugLiteMap.put(drugName, newDrug);
|
||||||
|
matchedDrugs.add(newDrug);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
material.setCandidateDrugs(matchedDrugs);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据委托id分组,拼接嫌疑人姓名和身份证
|
* 根据委托id分组,拼接嫌疑人姓名和身份证
|
||||||
|
*
|
||||||
* @param entrustmentVOList
|
* @param entrustmentVOList
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
|
|||||||
Reference in New Issue
Block a user