BStrConsultationApplyFacade.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. package com.diagbot.facade.str;
  2. import com.alibaba.fastjson.JSON;
  3. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  4. import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
  5. import com.diagbot.dto.RespDTO;
  6. import com.diagbot.dto.data.ColumnZhAndChDTO;
  7. import com.diagbot.entity.StrConsultationApply;
  8. import com.diagbot.entity.StrConsultationApply;
  9. import com.diagbot.enums.CacheKeyEnum;
  10. import com.diagbot.enums.IsDeleteEnum;
  11. import com.diagbot.facade.data.AMedAbnormalInfoFacade;
  12. import com.diagbot.facade.data.ColumnFacade;
  13. import com.diagbot.service.impl.StrConsultationApplyServiceImpl;
  14. import com.diagbot.util.DateUtil;
  15. import com.diagbot.util.EntityUtil;
  16. import com.diagbot.util.MapUtil;
  17. import com.diagbot.util.StringUtil;
  18. import com.diagbot.vo.data.AStrConsultationApplyVO;
  19. import com.diagbot.vo.str.StrConsultationApplyVO;
  20. import com.diagbot.vo.str.StrContentVO;
  21. import com.google.common.collect.Lists;
  22. import org.springframework.beans.BeanUtils;
  23. import org.springframework.beans.factory.annotation.Autowired;
  24. import org.springframework.beans.factory.annotation.Qualifier;
  25. import org.springframework.beans.factory.annotation.Value;
  26. import org.springframework.stereotype.Component;
  27. import java.util.Date;
  28. import java.util.List;
  29. import java.util.Map;
  30. @Component
  31. public class BStrConsultationApplyFacade extends StrConsultationApplyServiceImpl {
  32. @Autowired
  33. @Qualifier("strConsultationApplyServiceImpl")
  34. private StrConsultationApplyServiceImpl strConsultationApplyService;
  35. @Autowired
  36. private ColumnFacade columnFacade;
  37. @Autowired
  38. private AMedAbnormalInfoFacade aMedAbnormalInfoFacade;
  39. @Value("${log_switch.enable}")
  40. private boolean logSwitch;
  41. public void getColumnZhAndCh(){
  42. List<ColumnZhAndChDTO> list=this.baseMapper.getColumnZhAndCh();
  43. list.forEach(s->{
  44. s.setEn(NamingStrategy.underlineToCamel(s.getEn()));
  45. });
  46. Map<String, String> columnMap= EntityUtil.makeMapWithKeyValue(list,"ch","en");
  47. Boolean flag=columnFacade.createColumn(columnMap,"strConsultationApply");
  48. //Map<String, String> map=columnFacade.getColumn("strConsultationNote");
  49. if(!flag){
  50. return;
  51. }
  52. }
  53. /**
  54. * @Description:不解析时入库
  55. * @Author:liuqq
  56. * @time: ${DATE} ${TIME}
  57. **/
  58. public void dealData(StrContentVO strContentVO){
  59. StrConsultationApply strConsultationApply=new StrConsultationApply();
  60. strConsultationApply.setRecId(strContentVO.getRecId());
  61. strConsultationApply.setBehospitalCode(strContentVO.getBehospitalCode());
  62. strConsultationApply.setHospitalId(strContentVO.getHospitalId());
  63. strConsultationApply.setWholeData(strContentVO.getWholeData());
  64. //判断数据库中是否存在,不存在insert
  65. if (isExist(strConsultationApply)) {
  66. strConsultationApply.setGmtCreate(new Date());//记录创建时间
  67. this.save(strConsultationApply);
  68. } else {
  69. strConsultationApply.setGmtModified(new Date());//记录修改时间
  70. this.update(strConsultationApply, new QueryWrapper<StrConsultationApply>()
  71. .eq("rec_id", strConsultationApply.getRecId())
  72. .eq("hospital_id", strConsultationApply.getHospitalId())
  73. .eq("behospital_code", strConsultationApply.getBehospitalCode()));
  74. }
  75. }
  76. /**
  77. * @Description:解析后存储数据
  78. * @Author:liuqq
  79. * @time: ${DATE} ${TIME}
  80. **/
  81. public void dealData(String columnMap,Map<String, Object> entityMap,Long hospitalId){
  82. StrConsultationApply strConsultationApply=new StrConsultationApply();
  83. try {
  84. AStrConsultationApplyVO strConsultationApplyVO=(AStrConsultationApplyVO) MapUtil.mapToObject(entityMap, AStrConsultationApplyVO.class);
  85. BeanUtils.copyProperties(strConsultationApplyVO,strConsultationApply);
  86. strConsultationApply.setHospitalId(hospitalId);//医院编码
  87. strConsultationApply.setAuditDate(DateUtil.parseDateTime(strConsultationApplyVO.getAuditDate()));//审核时间
  88. strConsultationApply.setRecDate(DateUtil.parseDateTime(strConsultationApplyVO.getRecDate()));//记录时间
  89. strConsultationApply.setBehospitalDate(DateUtil.parseDateTime(strConsultationApplyVO.getBehospitalDate()));//入院日期
  90. strConsultationApply.setRecordDate(DateUtil.parseDateTime(strConsultationApplyVO.getRecordDate()));//病历日期
  91. strConsultationApply.setApplyDate(DateUtil.parseDateTime(strConsultationApplyVO.getApplyDate()));//申请日期
  92. strConsultationApply.setConsultationDate(DateUtil.parseDateTime(strConsultationApplyVO.getConsultationDate()));//会诊时间
  93. strConsultationApply.setWholeData(columnMap);
  94. //判断数据库中是否存在,不存在insert
  95. if(isExist(strConsultationApply)){
  96. strConsultationApply.setGmtCreate(new Date());//记录创建时间
  97. this.save(strConsultationApply);
  98. }else{
  99. strConsultationApply.setGmtModified(new Date());//记录修改时间
  100. this.update(strConsultationApply,new QueryWrapper<StrConsultationApply>()
  101. .eq("rec_id", strConsultationApply.getRecId())
  102. .eq("hospital_id", strConsultationApply.getHospitalId())
  103. .eq("behospital_code", strConsultationApply.getBehospitalCode()));
  104. }
  105. }catch (Exception e){
  106. log.error(e.getMessage(),e);
  107. aMedAbnormalInfoFacade.saveAbnormalInfo("会诊申请单",strConsultationApply.getRecId(), JSON.toJSONString(entityMap),"",e.getMessage());
  108. }
  109. }
  110. public Boolean isExist(StrConsultationApply strConsultationApply){
  111. Boolean flag=true;
  112. int count = this.baseMapper.selectCount(new QueryWrapper<StrConsultationApply>()
  113. .eq("rec_id", strConsultationApply.getRecId())
  114. .eq("hospital_id", strConsultationApply.getHospitalId())
  115. .eq("behospital_code", strConsultationApply.getBehospitalCode()));
  116. if(count>0){
  117. flag=false;
  118. }
  119. return flag;
  120. }
  121. /**
  122. * @Description:会诊申请单-结构化-独立入口
  123. * @Author:liuqq
  124. * @time: ${DATE} ${TIME}
  125. **/
  126. public RespDTO execDealData(List<StrConsultationApplyVO> list){
  127. try {
  128. if(list!=null && list.size()>0){
  129. //循环验证数据有效性
  130. for (StrConsultationApplyVO strConsultationApplyVO:list) {
  131. if("".equals(strConsultationApplyVO.getRecId())) {
  132. return RespDTO.onError("请输入记录编号!");
  133. }else if(strConsultationApplyVO.getHospitalId()==null){
  134. return RespDTO.onError("请输入医院编码!");
  135. }else if("".equals(strConsultationApplyVO.getBehospitalCode())){
  136. return RespDTO.onError("请输入病人住院编码!");
  137. }
  138. }
  139. //初始、格式化数据
  140. List<StrConsultationApply> strConsultationApplyList= initData(list);
  141. execute(strConsultationApplyList);
  142. if(logSwitch){
  143. strConsultationApplyList.forEach(s->{
  144. aMedAbnormalInfoFacade.saveAbnormalInfo("结构化-会诊申请单-正常", s.getRecId(), JSON.toJSONString(list), "", "");
  145. });
  146. }
  147. return RespDTO.onSuc("操作正常!");
  148. }else{
  149. return RespDTO.onError("未接收到数据!");
  150. }
  151. }catch (Exception e){
  152. log.error(e.getMessage(),e);
  153. if(list!=null && list.size()>0) {
  154. list.forEach(s->{
  155. aMedAbnormalInfoFacade.saveAbnormalInfo("结构化-会诊申请单-异常", s.getRecId(), JSON.toJSONString(s), "", e.getMessage());
  156. });
  157. }
  158. return RespDTO.onError("数据处理异常,详情查看日志表");
  159. }
  160. }
  161. private List<StrConsultationApply> initData(List<StrConsultationApplyVO> list) throws Exception{
  162. List<StrConsultationApply> tList=Lists.newArrayList();
  163. for (StrConsultationApplyVO s:list) {
  164. StrConsultationApply t=new StrConsultationApply();
  165. BeanUtils.copyProperties(s,t);
  166. if(StringUtil.isNotEmpty(s.getRecordDate())){
  167. t.setRecordDate(DateUtil.parseDateTime(s.getRecordDate()));//病历日期
  168. }
  169. if(StringUtil.isNotEmpty(s.getBehospitalDate())){
  170. t.setBehospitalDate(DateUtil.parseDateTime(s.getBehospitalDate()));//入院日期
  171. }
  172. if(StringUtil.isNotEmpty(s.getApplyDate())){
  173. t.setApplyDate(DateUtil.parseDateTime(s.getApplyDate()));//申请日期
  174. }
  175. if(StringUtil.isNotEmpty(s.getConsultationDate())){
  176. t.setConsultationDate(DateUtil.parseDateTime(s.getConsultationDate()));//会诊时间
  177. }
  178. if(StringUtil.isNotEmpty(s.getRecDate())){
  179. t.setRecDate(DateUtil.parseDateTime(s.getRecDate()));//记录时间
  180. }
  181. if(StringUtil.isNotEmpty(s.getAuditDate())){
  182. t.setAuditDate(DateUtil.parseDateTime(s.getAuditDate()));//审核时间
  183. }
  184. Map<String, String> columnMap=columnFacade.getColumn(CacheKeyEnum.CONSULTATION_APPLY.getName());
  185. Map<String, Object> entityMap=MapUtil.objectToMap(s);
  186. Map<String, Object> wholeMap=MapUtil.objcetKeyConvert(columnMap,entityMap);
  187. //t.setWholeData(JSON.toJSONString(wholeMap));
  188. tList.add(t);
  189. }
  190. return tList;
  191. }
  192. public void execute(List<StrConsultationApply> list) throws Exception{
  193. List<StrConsultationApply> addE = Lists.newLinkedList();
  194. List<StrConsultationApply> updateE = Lists.newLinkedList();
  195. if (list != null && list.size() > 0) {
  196. list.stream().forEach(s -> {
  197. StrConsultationApply strConsultationApply = this.getOne(new QueryWrapper<StrConsultationApply>()
  198. .eq("is_deleted", IsDeleteEnum.N.getKey())
  199. .eq("rec_id", s.getRecId())
  200. .eq("hospital_id", s.getHospitalId())
  201. .eq("behospital_code",s.getBehospitalCode()), false);
  202. if (strConsultationApply != null) {
  203. s.setGmtModified(new Date());
  204. updateE.add(s);
  205. } else {
  206. s.setGmtCreate(new Date());
  207. addE.add(s);
  208. }
  209. });
  210. }
  211. if(addE.size()>0){
  212. strConsultationApplyService.saveBatch(addE);
  213. }
  214. if(updateE.size()>0){
  215. this.baseMapper.updateBatchByKey(updateE);
  216. }
  217. }
  218. }