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 | 280 ++++++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 212 insertions(+), 68 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 27a3555..38616f5 100644
--- a/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/PatMedInhospServiceImpl.java
@@ -2,12 +2,14 @@
import java.time.LocalDate;
import java.time.ZoneOffset;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
+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.*;
@@ -41,10 +43,18 @@
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<>();
@@ -71,6 +81,59 @@
@Override
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;
}
/**
@@ -120,86 +183,167 @@
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;
}
+
+ /**
+ * 鑾峰彇鍑洪櫌锛屼綇闄紝闂ㄨ瘖鏈嶅姟浜烘
+ *
+ * @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