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 | 301 ++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 277 insertions(+), 24 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 7853b90..38616f5 100644 --- a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java +++ b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java @@ -1,96 +1,349 @@ package com.smartor.service.impl; -import java.util.List; +import java.time.LocalDate; +import java.time.ZoneOffset; +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; +import com.ruoyi.common.utils.StringUtils; +import com.smartor.domain.*; +import com.smartor.mapper.*; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.CollectionUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; -import com.smartor.mapper.PatMedInhospMapper; -import com.smartor.domain.PatMedInhosp; import com.smartor.service.IPatMedInhospService; +import org.springframework.transaction.annotation.Transactional; /** * 鎮h�呬綇闄㈣褰昐ervice涓氬姟灞傚鐞� - * + * * @author smartor * @date 2023-03-04 */ +@Slf4j @Service -public class PatMedInhospServiceImpl implements IPatMedInhospService -{ +public class PatMedInhospServiceImpl implements IPatMedInhospService { @Autowired private PatMedInhospMapper patMedInhospMapper; + @Autowired + private PatArchiveMapper patArchiveMapper; + + @Autowired + private IvrLibaTemplateMapper ivrLibaTemplateMapper; + + @Autowired + private IvrTaskTemplateMapper ivrTaskTemplateMapper; + + @Autowired + private Icd10AssociationMapper icd10AssociationMapper; + + @Autowired + private SvyTaskTemplateMapper svyTaskTemplateMapper; + + @Autowired + private ServiceTaskMapper serviceTaskMapper; + + @Autowired + private ServiceSubtaskMapper serviceSubtaskMapper; + @Autowired + private SysUserDeptMapper sysUserDeptMapper; + + //璁板綍闀挎湡浠诲姟鍩虹淇℃伅 + List<IvrLibaTemplate> libaTemplates = new ArrayList<>(); + List<IvrTaskTemplate> ivrTaskTemplates = new ArrayList<>(); + List<ServiceTask> serviceTaskList = new ArrayList<>(); + /** * 鏌ヨ鎮h�呬綇闄㈣褰� - * + * * @param inhospid 鎮h�呬綇闄㈣褰曚富閿� * @return 鎮h�呬綇闄㈣褰� */ @Override - public PatMedInhosp selectPatMedInhospByInhospid(Long inhospid) - { + public PatMedInhosp selectPatMedInhospByInhospid(Long inhospid) { return patMedInhospMapper.selectPatMedInhospByInhospid(inhospid); } /** * 鏌ヨ鎮h�呬綇闄㈣褰曞垪琛� - * + * * @param patMedInhosp 鎮h�呬綇闄㈣褰� * @return 鎮h�呬綇闄㈣褰� */ @Override - public List<PatMedInhosp> selectPatMedInhospList(PatMedInhosp patMedInhosp) - { + public List<PatMedInhosp> selectPatMedInhospList(PatMedInhosp patMedInhosp) { return patMedInhospMapper.selectPatMedInhospList(patMedInhosp); } /** + * 鏌ヨ褰撳墠鐧婚檰浜鸿嚜宸憋紙鐥呭尯銆侀儴闂級鐨勬偅鑰呬綇闄㈣褰曞垪琛� + * + * @param patMedInhospVO + * @return + */ + public List<PatMedInhosp> selectPatMedInhospListByCondition(PatMedInhospVO patMedInhospVO) { + return patMedInhospMapper.selectPatMedInhospListByCondition(patMedInhospVO); + } + + + @Override + public PatMedInhosp getDeptCodeByPatId(PatMedInhosp patMedInhosp) { + List<PatMedInhosp> patMedInhosps = selectPatMedInhospList(patMedInhosp); + if (!org.springframework.util.CollectionUtils.isEmpty(patMedInhosps)) { + + if (patMedInhosp.getInhospstate().equals("0")) { + //鍏堝幓鎺夋椂闂翠负绌虹殑 + patMedInhosps.removeIf(PatMedInhosp -> PatMedInhosp.getStarttime() == null); + Collections.sort(patMedInhosps, Comparator.comparing(PatMedInhosp::getStarttime).reversed()); + } else if (patMedInhosp.getInhospstate().equals("1")) { + //鍏堝幓鎺夋椂闂翠负绌虹殑 + patMedInhosps.removeIf(PatMedInhosp -> PatMedInhosp.getEndtime() == null); + Collections.sort(patMedInhosps, Comparator.comparing(PatMedInhosp::getEndtime).reversed()); + } + } + if (patMedInhosps != null && patMedInhosps.size() > 0) return patMedInhosps.get(0); + else return null; + } + + /** + * 鏌ヨ鍑哄叆闄汉娆� + * + * @param patMedReq + * @return + */ + @Override + public PatMedRes selectPatMedInhospListCount(PatMedReq patMedReq) { + PatMedRes patMedRes = null; + // 鑾峰彇褰撳墠鐧婚檰浜虹殑閮ㄩ棬鏉冮檺 + if (org.springframework.util.CollectionUtils.isEmpty(patMedReq.getDeptcodeList())) { + Long userId = SecurityUtils.getUserId(); + List<SysDept> sysDepts = sysUserDeptMapper.selectDeptListByUserId(userId); + List<String> deptCode = new ArrayList<>(); + for (SysDept sysDept : sysDepts) { + deptCode.add(sysDept.getDeptId().toString()); + } + patMedReq.setDeptcodeList(deptCode); + patMedRes = patMedInhospMapper.selectPatMedInhospCount(patMedReq); + } + return patMedRes; + } + + /** * 鏂板鎮h�呬綇闄㈣褰� - * + * * @param patMedInhosp 鎮h�呬綇闄㈣褰� * @return 缁撴灉 */ @Override - public int insertPatMedInhosp(PatMedInhosp patMedInhosp) - { + public int insertPatMedInhosp(PatMedInhosp patMedInhosp) { patMedInhosp.setCreateTime(DateUtils.getNowDate()); + patMedInhosp.setUpdateTime(DateUtils.getNowDate()); return patMedInhospMapper.insertPatMedInhosp(patMedInhosp); } /** * 淇敼鎮h�呬綇闄㈣褰� - * + * * @param patMedInhosp 鎮h�呬綇闄㈣褰� * @return 缁撴灉 */ @Override - public int updatePatMedInhosp(PatMedInhosp patMedInhosp) - { + public int updatePatMedInhosp(PatMedInhosp patMedInhosp) { patMedInhosp.setUpdateTime(DateUtils.getNowDate()); return patMedInhospMapper.updatePatMedInhosp(patMedInhosp); } /** * 鎵归噺鍒犻櫎鎮h�呬綇闄㈣褰� - * + * * @param inhospids 闇�瑕佸垹闄ょ殑鎮h�呬綇闄㈣褰曚富閿� * @return 缁撴灉 */ @Override - public int deletePatMedInhospByInhospids(Long[] inhospids) - { + public int deletePatMedInhospByInhospids(Long[] inhospids) { return patMedInhospMapper.deletePatMedInhospByInhospids(inhospids); } /** * 鍒犻櫎鎮h�呬綇闄㈣褰曚俊鎭� - * + * * @param inhospid 鎮h�呬綇闄㈣褰曚富閿� * @return 缁撴灉 */ @Override - public int deletePatMedInhospByInhospid(Long inhospid) - { + public int deletePatMedInhospByInhospid(Long inhospid) { return patMedInhospMapper.deletePatMedInhospByInhospid(inhospid); } + + + @Override + 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()); + //缁欎釜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; + } + + /** + * 鑾峰彇鍑洪櫌锛屼綇闄紝闂ㄨ瘖鏈嶅姟浜烘 + * + * @param patMedReq + * @return + */ + @Override + public List<PatMedRes> getDeptRanking(PatMedReq patMedReq) { + + 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