|
@@ -0,0 +1,70 @@
|
|
|
+package com.diagbot.facade;
|
|
|
+
|
|
|
+import com.alibaba.fastjson.JSON;
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
+import com.diagbot.client.bean.FeatureRate;
|
|
|
+import com.diagbot.client.bean.GdbResponse;
|
|
|
+import com.diagbot.client.bean.MedicalIndication;
|
|
|
+import com.diagbot.client.bean.MedicalIndicationDetail;
|
|
|
+import com.diagbot.client.bean.ResponseData;
|
|
|
+import com.diagbot.client.bean.SearchData;
|
|
|
+import com.diagbot.dto.RespDTO;
|
|
|
+import com.diagbot.entity.ScaleContent;
|
|
|
+import com.diagbot.enums.DisTypeEnum;
|
|
|
+import com.diagbot.enums.FeatureTypeEnum;
|
|
|
+import com.diagbot.exception.CommonErrorCode;
|
|
|
+import com.diagbot.exception.CommonException;
|
|
|
+import com.diagbot.util.BeanUtil;
|
|
|
+import com.diagbot.util.FastJsonUtils;
|
|
|
+import com.diagbot.util.ListUtil;
|
|
|
+import com.diagbot.util.RespDTOUtil;
|
|
|
+import com.diagbot.util.StringUtil;
|
|
|
+import com.diagbot.vo.SearchVo;
|
|
|
+import com.google.common.collect.Lists;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.stereotype.Component;
|
|
|
+
|
|
|
+import java.util.Arrays;
|
|
|
+import java.util.HashMap;
|
|
|
+import java.util.HashSet;
|
|
|
+import java.util.LinkedHashMap;
|
|
|
+import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+import java.util.Set;
|
|
|
+import java.util.stream.Collectors;
|
|
|
+
|
|
|
+/**
|
|
|
+ * @Description:
|
|
|
+ * @Author:zhaops
|
|
|
+ * @time: 2019/5/7 16:12
|
|
|
+ */
|
|
|
+@Component
|
|
|
+public class PushFacade {
|
|
|
+ @Autowired
|
|
|
+ private ClinicalFacade clinicalFacade;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 推理接口
|
|
|
+ *
|
|
|
+ * @param searchVo
|
|
|
+ * @return ResponseData
|
|
|
+ */
|
|
|
+ public void pushInner(SearchVo searchVo) {
|
|
|
+ ResponseData data = clinicalFacade.processClinicalData(searchVo);
|
|
|
+ //大数据返回内容
|
|
|
+ List<FeatureRate> dis = data.getDis();
|
|
|
+
|
|
|
+ String featureType = searchVo.getFeatureType();
|
|
|
+ String[] featureTypes = featureType.split(",|,");
|
|
|
+ Set<String> featureTypeSet = new HashSet(Arrays.asList(featureTypes));
|
|
|
+
|
|
|
+ //症状 标签列表
|
|
|
+ if (featureTypeSet.contains(String.valueOf(FeatureTypeEnum.Feature_Type_Symptom.getKey()))) {
|
|
|
+ List<FeatureRate> symptom = data.getSymptom();
|
|
|
+ if (ListUtil.isNotEmpty(symptom)) {
|
|
|
+ List<String> nameList = symptom.stream().map(featureRate -> featureRate.getFeatureName()).collect(Collectors.toList());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|