|
@@ -1,16 +1,24 @@
|
|
|
package com.diagbot.facade;
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
+import com.diagbot.client.AiptServiceClient;
|
|
|
+import com.diagbot.dto.ConceptBaseDTO;
|
|
|
import com.diagbot.dto.QuestionUsualDTO;
|
|
|
-import com.diagbot.entity.DeptInfo;
|
|
|
+import com.diagbot.dto.RespDTO;
|
|
|
+import com.diagbot.entity.QuestionInfo;
|
|
|
import com.diagbot.enums.IsDeleteEnum;
|
|
|
import com.diagbot.service.impl.QuestionUsualServiceImpl;
|
|
|
+import com.diagbot.util.BeanUtil;
|
|
|
import com.diagbot.util.ListUtil;
|
|
|
+import com.diagbot.util.RespDTOUtil;
|
|
|
+import com.diagbot.vo.ConceptUsualVO;
|
|
|
import com.diagbot.vo.QuestionUsualVO;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
* @Description:
|
|
@@ -21,6 +29,10 @@ import java.util.List;
|
|
|
public class QuestionUsualFacade extends QuestionUsualServiceImpl {
|
|
|
@Autowired
|
|
|
DeptInfoFacade deptInfoFacade;
|
|
|
+ @Autowired
|
|
|
+ AiptServiceClient aiptServiceClient;
|
|
|
+ @Autowired
|
|
|
+ QuestionFacade questionFacade;
|
|
|
|
|
|
/**
|
|
|
* 获取常用标签
|
|
@@ -29,14 +41,28 @@ public class QuestionUsualFacade extends QuestionUsualServiceImpl {
|
|
|
* @return
|
|
|
*/
|
|
|
public List<QuestionUsualDTO> getQuestionUsual(QuestionUsualVO questionUsualVO) {
|
|
|
- List<QuestionUsualDTO> questionUsualDTOList = this.getQuestionUsualName(questionUsualVO);
|
|
|
- if(ListUtil.isEmpty(questionUsualDTOList)){
|
|
|
- QueryWrapper<DeptInfo> queryWrapper = new QueryWrapper<>();
|
|
|
- queryWrapper.eq("is_deleted", IsDeleteEnum.N.getKey())
|
|
|
- .eq("name","全科");
|
|
|
- DeptInfo deptInfo = deptInfoFacade.getOne(queryWrapper);
|
|
|
- questionUsualVO.setDeptId(deptInfo.getId());
|
|
|
- questionUsualDTOList = this.getQuestionUsualName(questionUsualVO);
|
|
|
+ ConceptUsualVO conceptUsualVO = new ConceptUsualVO();
|
|
|
+ BeanUtil.copyProperties(questionUsualVO,conceptUsualVO);
|
|
|
+ //从知识库获取常用标签
|
|
|
+ RespDTO<List<ConceptBaseDTO>> conceptBaseDTORespDTO = aiptServiceClient.getConceptUsual(conceptUsualVO);
|
|
|
+ //如果该科室没有常用,返回全科常用
|
|
|
+ if( conceptBaseDTORespDTO != null && ListUtil.isEmpty(conceptBaseDTORespDTO.data)){
|
|
|
+ conceptUsualVO.setDeptName("全科");
|
|
|
+ conceptBaseDTORespDTO = aiptServiceClient.getConceptUsual(conceptUsualVO);
|
|
|
+ }
|
|
|
+ RespDTOUtil.respNGDeal(conceptBaseDTORespDTO,"获取常用标签失败");
|
|
|
+ //提取标签名称
|
|
|
+ List<String> conceptName = conceptBaseDTORespDTO.data.stream().map(ConceptBaseDTO::getName).collect(Collectors.toList());
|
|
|
+ //与question标签匹配
|
|
|
+ QueryWrapper<QuestionInfo> questionInfoQueryWrapper = new QueryWrapper<>();
|
|
|
+ questionInfoQueryWrapper.eq("is_deleted",IsDeleteEnum.N.getKey())
|
|
|
+ .in("tag_name",conceptName)
|
|
|
+ .eq("type",questionUsualVO.getType());
|
|
|
+ List<QuestionInfo> questionInfoList = questionFacade.list(questionInfoQueryWrapper);
|
|
|
+ Map<String,QuestionInfo> questionInfoMap = questionInfoList.stream().collect(Collectors.toMap(QuestionInfo::getTagName,questionInfo -> questionInfo));
|
|
|
+ List<QuestionUsualDTO> questionUsualDTOList = BeanUtil.listCopyTo(conceptBaseDTORespDTO.data,QuestionUsualDTO.class);
|
|
|
+ for (QuestionUsualDTO questionUsualDTO: questionUsualDTOList) {
|
|
|
+ questionUsualDTO.setQuestionId(questionInfoMap.get(questionUsualDTO.getName()).getId());
|
|
|
}
|
|
|
return questionUsualDTOList;
|
|
|
}
|