|
|
|
@ -69,25 +69,22 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
} |
|
|
|
|
return R.ok(entrustInfoList,"获取数据成功"); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 获取文书的数据 |
|
|
|
|
* |
|
|
|
|
* @param businessId |
|
|
|
|
* @return |
|
|
|
|
*/ |
|
|
|
|
@Override |
|
|
|
|
public R getIdentifyBookDataByBusinessId(String businessId) { |
|
|
|
|
public IdentificationBookDTO getIdentifyBookDataByBusinessId(String businessId) { |
|
|
|
|
//一个委托案件,只能属于一个实验,不允许一个委托中的检材分配到2个实验中做实验,这个是前提
|
|
|
|
|
if(ObjectUtils.isNotEmpty(businessId)){ |
|
|
|
|
IdentificationBookDTO identificationBookDTO = buildBookDataDetail(businessId); |
|
|
|
|
return R.ok(identificationBookDTO, "构建数据成功"); |
|
|
|
|
return identificationBookDTO; |
|
|
|
|
}else { |
|
|
|
|
log.info("参数业务id不能为空,请检查参数{}",businessId); |
|
|
|
|
return R.failed("参数业务id不能为空,请检查参数" + businessId); |
|
|
|
|
return null; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//构建文书数据
|
|
|
|
|
private IdentificationBookDTO buildBookDataDetail(String businessId){ |
|
|
|
|
IdentificationBookDTO bookData=new IdentificationBookDTO(); |
|
|
|
@ -100,11 +97,12 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
bookData.setSampleInfoList(sampleList); |
|
|
|
|
|
|
|
|
|
//设置检验结果
|
|
|
|
|
List<TestRecordSampleSolution> testRecordSampleSolutionList = getTestRecordSampleSolution(sampleList);//样本溶液
|
|
|
|
|
List<TestRecordSampleData> testRecordSampleDataList = getTestRecordSampleData(sampleList);//样本溶液对应的数据
|
|
|
|
|
List<TestResult> testResultsList = buildTestResult(testRecordSampleDataList, sampleList);//构建检验结果
|
|
|
|
|
TestRecord testRecordInfo = testRecordService.getById(testRecordSampleDataList.get(0).getTestId()); |
|
|
|
|
List<TestResult> testResultsList = buildTestResult(testRecordSampleDataList, testRecordSampleSolutionList, sampleList);//构建检验结果
|
|
|
|
|
TestRecord testRecordInfo = getTestRecordInfo(testRecordSampleSolutionList); |
|
|
|
|
//实验信息
|
|
|
|
|
bookData.setTestMethod(getTestMethods(testRecordInfo));//设置用到的实验方法
|
|
|
|
|
bookData.setTestMethod(getTestMethods(testRecordSampleSolutionList));//设置用到的实验方法
|
|
|
|
|
//设置检验过程
|
|
|
|
|
bookData.setTestProcessDes(testRecordInfo.getTestProcessDes());//设置检验过程
|
|
|
|
|
bookData.setTestResult(testRecordSampleDataService.generateQualitativeResults(businessId)); |
|
|
|
@ -117,7 +115,6 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
bookData.setTestFinishDate(sdf.format(testRecordInfo.getUpdateTime())); |
|
|
|
|
return bookData; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//获取业务的实验对象
|
|
|
|
|
private TestRecord getTestRecordInfo(List<TestRecordSampleSolution> testRecordSampleSolutionList){ |
|
|
|
|
List<String> testIdList= testRecordSampleSolutionList.stream().map(s -> s.getTestId()).collect(Collectors.toList()); |
|
|
|
@ -129,18 +126,12 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
TestRecord testRecord= testRecordService.getById(testId); |
|
|
|
|
return testRecord; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//获取实验方法
|
|
|
|
|
private String getTestMethods(TestRecord testRecord) { |
|
|
|
|
List<String> testMethodList = testRecord.getTestMethodList(); |
|
|
|
|
if (testMethodList == null || testMethodList.isEmpty()) { |
|
|
|
|
return String.format("没有对应的方法数据!"); // 直接返回空列表,避免 SQL 语法错误
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
List<TestRecordMethod> methodsList = testRecordMethodService.list( |
|
|
|
|
Wrappers.<TestRecordMethod>lambdaQuery().in(TestRecordMethod::getId, testMethodList) |
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
private String getTestMethods(List<TestRecordSampleSolution> testRecordSampleSolutionList){ |
|
|
|
|
TestRecord testRecordInfo= getTestRecordInfo(testRecordSampleSolutionList); |
|
|
|
|
List<String> testMethodList= testRecordInfo.getTestMethodList(); |
|
|
|
|
List<TestRecordMethod> methodsList = testRecordMethodService.list(Wrappers.<TestRecordMethod>lambdaQuery() |
|
|
|
|
.in(TestRecordMethod::getId, testMethodList)); |
|
|
|
|
List<String> methodsName = methodsList.stream().map(s -> s.getMethodName()).collect(Collectors.toList()); |
|
|
|
|
StringBuffer sbMethodNameStr=new StringBuffer(); |
|
|
|
|
methodsName.forEach(item->{ |
|
|
|
@ -149,18 +140,18 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
sbMethodNameStr.delete(sbMethodNameStr.length()-1,sbMethodNameStr.length()); |
|
|
|
|
return sbMethodNameStr.toString(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//获取sampleData
|
|
|
|
|
private List<TestRecordSampleData> getTestRecordSampleData(List<SampleInfo> sampleInfoList){ |
|
|
|
|
if (!sampleInfoList.isEmpty()) { |
|
|
|
|
List<String> sampleNoList = sampleInfoList.stream().map(m -> m.getAcceptNo()).collect(Collectors.toList());//得到样本溶液编号
|
|
|
|
|
List<TestRecordSampleSolution> testRecordSampleSolution = getTestRecordSampleSolution(sampleInfoList); |
|
|
|
|
if (CollUtil.isNotEmpty(testRecordSampleSolution)) { |
|
|
|
|
List<String> sampleNoList= testRecordSampleSolution.stream().map(m -> m.getSampleNo()).collect(Collectors.toList());//得到样本溶液编号
|
|
|
|
|
//根据样本溶液编号查出对应的样本溶液检验数据
|
|
|
|
|
List<TestRecordSampleData> sampleTestDataList= getTestRecordData(sampleNoList); |
|
|
|
|
return sampleTestDataList; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
return null; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//获取样本溶液
|
|
|
|
|
private List<TestRecordSampleSolution> getTestRecordSampleSolution( List<SampleInfo> sampleInfoList){ |
|
|
|
|
List<String> materialIdList= sampleInfoList.stream().map(m -> m.getId()).collect(Collectors.toList()); |
|
|
|
@ -173,20 +164,25 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
.in(TestRecordSampleSolution::getMaterialId, materialIdList)); |
|
|
|
|
return sampleSolutionList; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//构建TestResult
|
|
|
|
|
private List<TestResult> buildTestResult(List<TestRecordSampleData> testRecordSampleDataList, |
|
|
|
|
List<SampleInfo> sampleInfoList) { |
|
|
|
|
List<TestRecordSampleSolution> testRecordSampleSolutionList,List<SampleInfo> sampleInfoList){ |
|
|
|
|
//结果:应该是加入实验的检材的结果,目前暂定受理的检材我们按照受理顺序,全部定义为 1号检材,2号检材,3号检材等
|
|
|
|
|
//拿出实验数据中的所有实验样本编号,就是数据文件中的sampleId,也是溶液编号中的溶液编号,
|
|
|
|
|
List<String> sampleNoList= testRecordSampleDataList.stream().map(s -> s.getSampleNo()).collect(Collectors.toList()); |
|
|
|
|
//取出检材ID
|
|
|
|
|
Map<String, SampleInfo> map = sampleInfoList.stream().collect(Collectors.toMap(s -> s.getAcceptNo(), s -> s)); |
|
|
|
|
|
|
|
|
|
List<String> okTestRecordSampleSolutionIdList=new ArrayList<>(); |
|
|
|
|
testRecordSampleSolutionList.forEach(item->{ |
|
|
|
|
//如果溶液在提供的溶液编号中,则取出来
|
|
|
|
|
if(sampleNoList.contains(item.getSampleNo())){ |
|
|
|
|
okTestRecordSampleSolutionIdList.add(item.getMaterialId()); |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
List<TestResult> retTestResult=new ArrayList<>(); |
|
|
|
|
for (TestRecordSampleData testRecordSampleData : testRecordSampleDataList) { |
|
|
|
|
TestResult eg=new TestResult(); |
|
|
|
|
SampleInfo sampleInfo = map.get(testRecordSampleData.getSampleNo()); |
|
|
|
|
SampleInfo sampleInfo=getSampleInfoBySampleId(testRecordSampleSolutionList, |
|
|
|
|
sampleInfoList,testRecordSampleData.getSampleNo()); |
|
|
|
|
eg.setCompoundName(testRecordSampleData.getCompoundName()); |
|
|
|
|
eg.setMaterialNo(sampleInfo.getOrderNo()+"号"); |
|
|
|
|
eg.setOrderNo(sampleInfo.getOrderNo()); |
|
|
|
@ -196,7 +192,6 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
} |
|
|
|
|
return retTestResult; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//根据sampleID获取对应的检材信息
|
|
|
|
|
private SampleInfo getSampleInfoBySampleId(List<TestRecordSampleSolution> testRecordSampleSolutionList, |
|
|
|
|
List<SampleInfo> sampleInfoList,String sampleId){ |
|
|
|
@ -228,7 +223,6 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
return retObj.get(0); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//构建实验结果
|
|
|
|
|
private List<String> buildTestResultDes(List<TestResult> resultList){ |
|
|
|
|
//按照检材编号先分组,这样的话,如果有n个检材,m个化合物,那么就会分成n组,每组中就m条数据
|
|
|
|
@ -254,7 +248,6 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
List<String> testResultDes= testResultSorted(temp2); |
|
|
|
|
return testResultDes; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//对第一个结果进行排序
|
|
|
|
|
private List<String> testResultSorted(Map<String, List<TestResultDetail>> tmpMap){ |
|
|
|
|
List<Map.Entry<String, List<TestResultDetail>>> targetList=new ArrayList<Map.Entry<String, List<TestResultDetail>>>(tmpMap.entrySet()); |
|
|
|
@ -279,10 +272,8 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
}); |
|
|
|
|
return testResultDes; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 构造出一个检材一共检出了多少个化合物和未检出多少化合物 |
|
|
|
|
* |
|
|
|
|
* @param mapCompound |
|
|
|
|
* @param materialNo |
|
|
|
|
* @return |
|
|
|
@ -332,7 +323,6 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 根据编号获取排序值 |
|
|
|
|
* |
|
|
|
|
* @param materialNo |
|
|
|
|
* @return |
|
|
|
|
*/ |
|
|
|
@ -344,10 +334,8 @@ public class IdentifyBookDataServiceImpl implements IdentifyBookDataService { |
|
|
|
|
} |
|
|
|
|
return ""; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 根据溶液编号(sampleNo)获取仪器检测数据 |
|
|
|
|
* |
|
|
|
|
* @param sampleNoList |
|
|
|
|
* @return |
|
|
|
|
*/ |
|
|
|
|