From 907641e56c2085aaa81f267946dc3e3e9fca73e7 Mon Sep 17 00:00:00 2001 From: liusheng <337615773@qq.com> Date: 星期三, 18 九月 2024 09:39:02 +0800 Subject: [PATCH] 代码提交 --- smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java | 215 +++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 150 insertions(+), 65 deletions(-) diff --git a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java index f3aa58c..38616f5 100644 --- a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java +++ b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java @@ -5,6 +5,8 @@ import java.util.*; import com.ruoyi.common.core.domain.entity.SysDept; +import com.ruoyi.common.core.domain.entity.SysUser; +import com.ruoyi.common.core.domain.model.LoginUser; import com.ruoyi.common.utils.DateUtils; import com.ruoyi.common.utils.DtoConversionUtils; import com.ruoyi.common.utils.SecurityUtils; @@ -41,6 +43,12 @@ private IvrTaskTemplateMapper ivrTaskTemplateMapper; @Autowired + private Icd10AssociationMapper icd10AssociationMapper; + + @Autowired + private SvyTaskTemplateMapper svyTaskTemplateMapper; + + @Autowired private ServiceTaskMapper serviceTaskMapper; @Autowired @@ -73,6 +81,16 @@ @Override public List<PatMedInhosp> selectPatMedInhospList(PatMedInhosp patMedInhosp) { return patMedInhospMapper.selectPatMedInhospList(patMedInhosp); + } + + /** + * 鏌ヨ褰撳墠鐧婚檰浜鸿嚜宸憋紙鐥呭尯銆侀儴闂級鐨勬偅鑰呬綇闄㈣褰曞垪琛� + * + * @param patMedInhospVO + * @return + */ + public List<PatMedInhosp> selectPatMedInhospListByCondition(PatMedInhospVO patMedInhospVO) { + return patMedInhospMapper.selectPatMedInhospListByCondition(patMedInhospVO); } @@ -165,85 +183,143 @@ return patMedInhospMapper.deletePatMedInhospByInhospid(inhospid); } - @Transactional(rollbackFor = Exception.class) + @Override - public int dealOupHospInfo() { - //鑾峰彇闀挎湡妯℃澘 - IvrLibaTemplate ivrTemp = new IvrLibaTemplate(); - ivrTemp.setDelFlag("0"); - ivrTemp.setLongTemp(1); - List<IvrLibaTemplate> ivrLibaTemplates = ivrLibaTemplateMapper.selectIvrLibaTemplateList(ivrTemp); - - if (CollectionUtils.isNotEmpty(ivrLibaTemplates)) { - for (IvrLibaTemplate ivrLibaTemplate : ivrLibaTemplates) { - //鑾峰彇鍒颁换鍔℃ā鏉夸俊鎭� - IvrTaskTemplate ivrTaskTemplate = new IvrTaskTemplate(); - ivrTaskTemplate.setLibtemplateid(ivrLibaTemplate.getId().toString()); - List<IvrTaskTemplate> ivrTaskTemplates = ivrTaskTemplateMapper.selectIvrTaskTemplateList(ivrTaskTemplate); - if (CollectionUtils.isNotEmpty(ivrTaskTemplates)) { - IvrTaskTemplate ivrTaskTemplate1 = ivrTaskTemplates.get(0); - //閫氳繃浠诲姟妯℃澘ID鑾峰彇浠诲姟 - ServiceTask ServiceTask = new ServiceTask(); - ServiceTask.setTemplateid(ivrTaskTemplate1.getId()); - List<ServiceTask> serviceTasks = serviceTaskMapper.selectServiceTaskList(ServiceTask); - if (CollectionUtils.isNotEmpty(serviceTasks)) { - serviceTaskList.add(serviceTasks.get(0)); - } - ivrTaskTemplates.add(ivrTaskTemplate1); - } - libaTemplates.add(ivrLibaTemplate); - } - } - + public int dealOutHospInfo() { PatMedInhosp patMedInhosp = new PatMedInhosp(); //鑾峰彇鏈鐞嗙殑鏁版嵁 patMedInhosp.setCheckFlag("0"); patMedInhosp.setInhospstate("1"); List<PatMedInhosp> patMedInhosps = patMedInhospMapper.selectPatMedInhospList(patMedInhosp); + for (PatMedInhosp patMedInhosp1 : patMedInhosps) { + //鏍规嵁鎮h�呮墍鍦ㄧ瀹わ紝鑾峰彇璇ョ瀹ょ殑闀挎湡浠诲姟妯℃澘 + Long taskid = null; + SvyTaskTemplate svyTaskTemplate = new SvyTaskTemplate(); + svyTaskTemplate.setDeptCode(patMedInhosp1.getLeaveldeptcode()); + svyTaskTemplate.setLongTemp(1); + List<SvyTaskTemplate> svyTaskTemplates = svyTaskTemplateMapper.selectSvyTaskTemplateList(svyTaskTemplate); + //濡傛灉閮ㄩ棬妯℃澘涓虹┖锛堟殏瀹氾紝灏嗗嚭鍏ラ櫌琛ㄧ殑check_flag璁剧疆涓�2 锛宭ong_task_reason 璁板綍鍘熷洜锛� + if (CollectionUtils.isEmpty(svyTaskTemplates) || svyTaskTemplates.size() == 0) { + patMedInhosp1.setCheckFlag("2"); + patMedInhosp1.setLongTaskReason("璇ユ偅鑰呮墍鍦ㄧ瀹わ紝鏈厤缃换鍔℃ā鏉�"); + patMedInhospMapper.updatePatMedInhosp(patMedInhosp1); + continue; + } + + //鑾峰彇鎮h�呬俊鎭� PatArchive patArchive = patArchiveMapper.selectPatArchiveByPatid(patMedInhosp1.getPatid()); - //閫氳繃icd10code鍘昏幏鍙栫浉搴旂殑ivr_liba_template_id - if (StringUtils.isNotEmpty(patMedInhosp1.getIcd10code())) { - for (IvrLibaTemplate ivrLibaTemplate : libaTemplates) { - String icdCode = patMedInhosp1.getIcd10code().split(",")[0]; - if (ivrLibaTemplate.getIcd10code().equals(icdCode)) { - //閫氳繃妯℃澘ID鑾峰彇浠诲姟妯℃澘 - for (IvrTaskTemplate ivrTaskTemplate : ivrTaskTemplates) { - if (ivrTaskTemplate.getLibtemplateid().equals(ivrLibaTemplate.getId().toString())) { - for (ServiceTask serviceTask : serviceTaskList) { - if (serviceTask.getTemplateid() == ivrTaskTemplate.getId()) { - //灏嗚鎮h�咃紝鎻掑叆鍒板瓙浠诲姟琛ㄤ腑 - ServiceSubtask serviceSubtask = DtoConversionUtils.sourceToTarget(serviceTask, ServiceSubtask.class); - serviceSubtask.setId(null); - serviceSubtask.setTaskid(serviceTask.getTaskid()); - serviceSubtask.setLibtemplateid(ivrLibaTemplate.getId()); - serviceSubtask.setTemplateid(ivrTaskTemplate.getId()); - serviceSubtask.setTemplatename(ivrLibaTemplate.getTemplateName()); - serviceSubtask.setPatid(patMedInhosp1.getPatid()); - serviceSubtask.setSendname(patMedInhosp1.getPatname()); - serviceSubtask.setPhone(patArchive.getTelcode()); - serviceSubtask.setSex(patArchive.getSex()); - serviceSubtask.setAge(patArchive.getAge()); - serviceSubtask.setSendstate(2L); - serviceSubtask.setServiceform(serviceTask.getPreachform()); - serviceSubtask.setHospType("2"); - //鎮h�呭彂閫佹椂闂� - LocalDate currentDate = LocalDate.now(); - LocalDate newDate = currentDate.plusDays(ivrTaskTemplate.getSendDay()); - serviceSubtask.setLongSendTime(Date.from(newDate.atStartOfDay(ZoneOffset.ofHours(8)).toInstant())); - serviceSubtaskMapper.insertServiceSubtask(serviceSubtask); - //灏哻heck_flag鏀规垚1锛堝凡澶勭悊锛� - PatMedInhosp patMedInhosp2 = new PatMedInhosp(); - patMedInhosp2.setInhospid(patMedInhosp1.getInhospid()); - patMedInhosp2.setCheckFlag("1"); - patMedInhospMapper.updatePatMedInhosp(patMedInhosp2); - } + //缁欎釜remark(鐢ㄦ潵鍋氭槸鍚﹁缁欏彂閫佹椂闂存爣璇�) + String remark = null; + //瀹氫箟涓�涓ā鏉垮彉閲忥紝鐢ㄤ笌涓存椂淇濆瓨涓�涓嬫壘鍑烘潵鐨勬ā鏉� + SvyTaskTemplate stt = null; + if (CollectionUtils.isNotEmpty(svyTaskTemplates) && svyTaskTemplates.size() == 1) { + stt = svyTaskTemplates.get(0); + taskid = svyTaskTemplates.get(0).getTaskid(); + + } else if (CollectionUtils.isNotEmpty(svyTaskTemplates) && svyTaskTemplates.size() > 1) { + //閫氳繃鎮h�呯殑鐤剧梾鍘绘壘妯℃澘 + if (StringUtils.isNotEmpty(patMedInhosp1.getIcd10code())) { + aa: + for (SvyTaskTemplate svyTaskTemplate1 : svyTaskTemplates) { + //閫氳繃鍩虹妯℃澘ID鑾峰彇鍏宠仈鐨勭柧鐥卌ode + Icd10Association icd10Association = new Icd10Association(); + icd10Association.setType(5L); + icd10Association.setOutid(svyTaskTemplate1.getTemplateid()); + List<Icd10Association> icd10Associations = icd10AssociationMapper.selectIcd10AssociationList(icd10Association); + if (CollectionUtils.isEmpty(icd10Associations)) { + //濡傝兘妯℃澘鐨勭柧鐥呬负绌猴紝鍒欐槸鏈瀹ょ殑閫氱敤榛樿妯℃澘 + stt = svyTaskTemplate1; + taskid = stt.getTaskid(); + continue; + } else { + //濡傝兘妯℃澘鐨勭柧鐥呬笉涓虹┖锛屽垯鏄敤鍖归厤鍒扮柧鐥呯殑妯℃澘锛堝鏋滃尮閰嶅嚭鏉ュ涓ā鏉匡紝鍙敤绗竴涓級 + for (Icd10Association icd10Association1 : icd10Associations) { + if (patMedInhosp1.getIcd10code().equals(icd10Association1.getIcd10code())) { + stt = svyTaskTemplate1; + taskid = stt.getTaskid(); + break aa; } } } } + //濡傛灉寰幆瀹岋紝stt杩樻槸涓虹┖锛屽垯璇ョ瀹ゆ病鏈夐粯璁ゆā鏉� + if (Objects.isNull(stt)) { + //鍦ㄥ嚭鍏ラ櫌琛ㄨ褰曚竴涓嬭鎮h�呯姸鎬侊紙璇ョ瀹ゆ病鏈夋ā鏉匡紝鎵�浠ユ棤娉曞湪瀛愪换鍔¢噷鐢熸垚浠诲姟锛屾墍浠ヤ换鍔℃槸澶辫触鏄殑锛宑hect_flag=2锛� + patMedInhosp1.setCheckFlag("2"); + patMedInhosp1.setLongTaskReason("鏃犳硶鍖归厤鍒拌绉戝妯℃澘锛岃绉戝涔熸棤榛樿妯℃澘"); + patMedInhospMapper.updatePatMedInhosp(patMedInhosp1); + continue; + } + } else { + //涓虹┖鐨勮瘽锛岀洿鎺ョ敤绉戝鐨勯�氱敤妯℃澘鐨勪换鍔D锛岃鎮h�呯洿鎺ュ線瀛愪换鍔¤〃閲屾彃鍏ワ紝浣嗕笉瑕佹墽琛岋紝闇�瑕佷汉宸ュ共锛堝皢涓嶈兘鎵ц鐨勫師鍥犲娉ㄥソ锛� + for (SvyTaskTemplate svyTaskTemplate1 : svyTaskTemplates) { + //閫氳繃鍩虹妯℃澘ID鑾峰彇鍏宠仈鐨勭柧鐥卌ode + Icd10Association icd10Association = new Icd10Association(); + icd10Association.setType(5L); + icd10Association.setOutid(svyTaskTemplate1.getTemplateid()); + //鎵惧嚭璇ョ瀹ょ殑閫氱敤妯℃澘 + List<Icd10Association> icd10Associations = icd10AssociationMapper.selectIcd10AssociationList(icd10Association); + if (CollectionUtils.isEmpty(icd10Associations)) { + stt = svyTaskTemplate1; + //涓嶉厤缃彂閫佹椂闂� + remark = "鎮h�呭叆闄㈢柧鐥呬负绌�"; + //鍦ㄥ嚭鍏ラ櫌琛ㄨ褰曚竴涓嬭鎮h�呯姸鎬侊紙璇ョ瀹ゆ槸鏈夌柧鐥呬负绌虹殑妯℃澘锛屾墍浠ュ彲浠ュ湪瀛愪换鍔¢噷鐢熸垚浠诲姟锛屾墍浠ヤ换鍔℃槸鎴愬姛鐨勶紝chect_flag=1锛� + patMedInhosp1.setCheckFlag("1"); + patMedInhosp1.setLongTaskReason("鎮h�呭叆闄㈢柧鐥呬负绌猴紝宸叉壘鍒扮瀹ゆā鏉�"); + patMedInhospMapper.updatePatMedInhosp(patMedInhosp1); + continue; + } + } + if (Objects.isNull(stt)) { + //鍦ㄥ嚭鍏ラ櫌琛ㄨ褰曚竴涓嬭鎮h�呯姸鎬侊紙璇ョ瀹ゆ病鏈夋ā鏉匡紝鎵�浠ユ棤娉曞湪瀛愪换鍔¢噷鐢熸垚浠诲姟锛屾墍浠ヤ换鍔℃槸澶辫触鏄殑锛宑hect_flag=2锛� + patMedInhosp1.setCheckFlag("2"); + patMedInhosp1.setLongTaskReason("鎮h�呭叆闄㈢柧鐥呬负绌猴紝鏈壘鍒扮瀹ゆā鏉�"); + patMedInhospMapper.updatePatMedInhosp(patMedInhosp1); + continue; + } } } + + ServiceTask serviceTask = serviceTaskMapper.selectServiceTaskByTaskid(taskid); + ServiceSubtask serviceSubtask = DtoConversionUtils.sourceToTarget(serviceTask, ServiceSubtask.class); + serviceSubtask.setTaskid(serviceTask.getTaskid()); + serviceSubtask.setLibtemplateid(stt.getTemplateid()); + serviceSubtask.setTemplateid(stt.getId()); + serviceSubtask.setTemplatename(stt.getSvyname()); + serviceSubtask.setPatid(patArchive.getId()); + serviceSubtask.setSendname(patArchive.getName()); + serviceSubtask.setPhone(patArchive.getTelcode()); + serviceSubtask.setSex(patArchive.getSex()); + serviceSubtask.setAge(patArchive.getAge()); + serviceSubtask.setSendstate(2L); + serviceSubtask.setServiceType("2"); + serviceSubtask.setServiceform(serviceTask.getPreachform()); + serviceSubtask.setHospType("2"); + //璁剧疆鍙戦�佹椂闂� + Date newDate = addDays(patMedInhosp1.getEndtime(), stt.getSendDay()); + serviceSubtask.setLongSendTime(newDate); + //鎮h�呭彂閫佹椂闂� + if (StringUtils.isNotEmpty(remark)) { + serviceSubtask.setSendstate(4L); + serviceSubtask.setRemark(remark); + serviceSubtask.setResult("error"); + serviceSubtask.setFinishtime(new Date()); + //涓嶆墽琛� + serviceSubtask.setSendstate(4L); + } else if (patArchive.getNotrequiredFlag().equals("4")) { + //浜轰笉鍦ㄤ簡锛屾垨鑰呭叾瀹冨師鍥狅紝涔熶笉鑳介殢璁� + serviceSubtask.setSendstate(4L); + serviceSubtask.setRemark(patArchive.getNotrequiredreason()); + serviceSubtask.setResult("error"); + serviceSubtask.setFinishtime(new Date()); + } + serviceSubtaskMapper.insertServiceSubtask(serviceSubtask); + //灏哻heck_flag鏀规垚1锛堝凡澶勭悊锛� + PatMedInhosp patMedInhosp2 = new PatMedInhosp(); + patMedInhosp2.setInhospid(patMedInhosp1.getInhospid()); + patMedInhosp2.setCheckFlag("1"); + patMedInhospMapper.updatePatMedInhosp(patMedInhosp2); } return 1; } @@ -260,5 +336,14 @@ return patMedInhospMapper.getDeptRanking(patMedReq); } + private Date addDays(Date date, Integer days) { + if (days == null) { + days = 1; + } + Calendar calendar = Calendar.getInstance(); + calendar.setTime(date); + calendar.add(Calendar.DAY_OF_MONTH, days); + return calendar.getTime(); + } } -- Gitblit v1.9.3