StrConsultationApplyFacade.java 11 KB

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