|
@@ -1,19 +1,14 @@
|
|
|
package org.jeecg.modules.medical.ruleengine;
|
|
package org.jeecg.modules.medical.ruleengine;
|
|
|
|
|
|
|
|
import cn.hutool.core.collection.CollectionUtil;
|
|
import cn.hutool.core.collection.CollectionUtil;
|
|
|
-import cn.hutool.core.date.DateUtil;
|
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
import org.apache.commons.lang.StringUtils;
|
|
import org.apache.commons.lang.StringUtils;
|
|
|
-import org.apache.poi.ss.formula.functions.Even;
|
|
|
|
|
import org.jeecg.common.constant.CommonConstant;
|
|
import org.jeecg.common.constant.CommonConstant;
|
|
|
import org.jeecg.common.util.SpringContextUtils;
|
|
import org.jeecg.common.util.SpringContextUtils;
|
|
|
-import org.jeecg.common.util.dynamic.db.DynamicDBUtil;
|
|
|
|
|
-import org.jeecg.modules.medical.ColumnTypeEnum;
|
|
|
|
|
import org.jeecg.modules.medical.Constant;
|
|
import org.jeecg.modules.medical.Constant;
|
|
|
import org.jeecg.modules.medical.EnchanceTypeEnum;
|
|
import org.jeecg.modules.medical.EnchanceTypeEnum;
|
|
|
-import org.jeecg.modules.medical.entity.AfterIncidentLog;
|
|
|
|
|
import org.jeecg.modules.medical.entity.AfterwardsAudit;
|
|
import org.jeecg.modules.medical.entity.AfterwardsAudit;
|
|
|
import org.jeecg.modules.medical.entity.AfterwardsAuditDetail;
|
|
import org.jeecg.modules.medical.entity.AfterwardsAuditDetail;
|
|
|
import org.jeecg.modules.medical.entity.EventAttr;
|
|
import org.jeecg.modules.medical.entity.EventAttr;
|
|
@@ -34,8 +29,6 @@ import org.jeecg.modules.medical.service.IFactorCondRelaService;
|
|
|
import org.jeecg.modules.medical.service.IMidIncidentAuditDetailService;
|
|
import org.jeecg.modules.medical.service.IMidIncidentAuditDetailService;
|
|
|
import org.jeecg.modules.medical.service.IMidIncidentAuditService;
|
|
import org.jeecg.modules.medical.service.IMidIncidentAuditService;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
-import org.springframework.jdbc.core.JdbcTemplate;
|
|
|
|
|
-import org.springframework.jdbc.support.rowset.SqlRowSet;
|
|
|
|
|
import org.springframework.stereotype.Component;
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
|
|
import javax.annotation.PostConstruct;
|
|
import javax.annotation.PostConstruct;
|
|
@@ -45,7 +38,6 @@ import java.util.Date;
|
|
|
import java.util.HashMap;
|
|
import java.util.HashMap;
|
|
|
import java.util.List;
|
|
import java.util.List;
|
|
|
import java.util.Map;
|
|
import java.util.Map;
|
|
|
-import java.util.Set;
|
|
|
|
|
import java.util.stream.Collectors;
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
@@ -90,8 +82,7 @@ public class FactorEnchangeFactory {
|
|
|
factorCondRelaMap = factorCondRelaList.stream().collect(Collectors.groupingBy(FactorCondRela::getFactorEnhanceId));
|
|
factorCondRelaMap = factorCondRelaList.stream().collect(Collectors.groupingBy(FactorCondRela::getFactorEnhanceId));
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-
|
|
|
|
|
- public boolean runFactorEnchange(Integer medicalInfoRuleInfoId, MedicalInsRuleInfo medicalInsRuleInfo, Object audit, Map<String, Object> localMap, List<RuleFactorRela> ruleFactorRelaList, List<FactorEnchance> factorEnchanceList,List<Map<String,Object>> itemList) {
|
|
|
|
|
|
|
+ public boolean runFactorEnchange(Integer medicalInfoRuleInfoId, MedicalInsRuleInfo medicalInsRuleInfo, Object audit, Map<String, Object> localMap, List<RuleFactorRela> ruleFactorRelaList, List<FactorEnchance> factorEnchanceList, List<Map<String, Object>> itemList) {
|
|
|
Map<Integer, FactorEnchance> factorEnchanceMap = factorEnchanceList.stream().collect(Collectors.toMap(FactorEnchance::getId, v -> v, (v1, v2) -> v1));
|
|
Map<Integer, FactorEnchance> factorEnchanceMap = factorEnchanceList.stream().collect(Collectors.toMap(FactorEnchance::getId, v -> v, (v1, v2) -> v1));
|
|
|
boolean result = false;
|
|
boolean result = false;
|
|
|
for (RuleFactorRela ruleFactorRela : ruleFactorRelaList) {
|
|
for (RuleFactorRela ruleFactorRela : ruleFactorRelaList) {
|
|
@@ -160,26 +151,29 @@ public class FactorEnchangeFactory {
|
|
|
return ioTypeMap;
|
|
return ioTypeMap;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- public void insertWarningDetail(Map<String, Object> itemMap, MedicalInsRuleInfo medicalInsRuleInfo, Object audit,List<Map<String,Object>> itemList){
|
|
|
|
|
- if(audit instanceof MidIncidentAudit) {
|
|
|
|
|
|
|
+ public void insertWarningDetail(Map<String, Object> itemMap, MedicalInsRuleInfo medicalInsRuleInfo, Object audit, List<Map<String, Object>> itemList) {
|
|
|
|
|
+ if(null == audit || CollectionUtil.isEmpty(itemList)){
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ if (audit instanceof MidIncidentAudit) {
|
|
|
MidIncidentAudit midIncidentAudit = (MidIncidentAudit) audit;
|
|
MidIncidentAudit midIncidentAudit = (MidIncidentAudit) audit;
|
|
|
insertMidWarningDetail(itemMap, medicalInsRuleInfo, midIncidentAudit, itemList);
|
|
insertMidWarningDetail(itemMap, medicalInsRuleInfo, midIncidentAudit, itemList);
|
|
|
- }else{
|
|
|
|
|
|
|
+ } else {
|
|
|
AfterwardsAudit afterwardsAudit = (AfterwardsAudit) audit;
|
|
AfterwardsAudit afterwardsAudit = (AfterwardsAudit) audit;
|
|
|
insertAfterWarningDetail(itemMap, medicalInsRuleInfo, afterwardsAudit, itemList);
|
|
insertAfterWarningDetail(itemMap, medicalInsRuleInfo, afterwardsAudit, itemList);
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- public void insertAfterWarningDetail(Map<String, Object> itemMap, MedicalInsRuleInfo medicalInsRuleInfo, AfterwardsAudit afterwardsAudit, List<Map<String,Object>> itemList) {
|
|
|
|
|
|
|
+ public void insertAfterWarningDetail(Map<String, Object> itemMap, MedicalInsRuleInfo medicalInsRuleInfo, AfterwardsAudit afterwardsAudit, List<Map<String, Object>> itemList) {
|
|
|
|
|
|
|
|
- if(Constant.VALIDATION_HANDER_METHOD_RETURN.equals(medicalInsRuleInfo.getViolationHandingMethod())) {
|
|
|
|
|
|
|
+ if (Constant.VALIDATION_HANDER_METHOD_RETURN.equals(medicalInsRuleInfo.getViolationHandingMethod())) {
|
|
|
afterwardsAuditService.lambdaUpdate().set(AfterwardsAudit::getAmount, afterwardsAudit.getAmount()).eq(AfterwardsAudit::getId, afterwardsAudit.getId()).update();
|
|
afterwardsAuditService.lambdaUpdate().set(AfterwardsAudit::getAmount, afterwardsAudit.getAmount()).eq(AfterwardsAudit::getId, afterwardsAudit.getId()).update();
|
|
|
List<AfterwardsAuditDetail> afterwardsAuditDetailList = new ArrayList<>();
|
|
List<AfterwardsAuditDetail> afterwardsAuditDetailList = new ArrayList<>();
|
|
|
QueryWrapper queryWrapper = new QueryWrapper();
|
|
QueryWrapper queryWrapper = new QueryWrapper();
|
|
|
queryWrapper.eq("afterwards_audit_id", afterwardsAudit.getId());
|
|
queryWrapper.eq("afterwards_audit_id", afterwardsAudit.getId());
|
|
|
afterwardsAuditDetailService.remove(queryWrapper);
|
|
afterwardsAuditDetailService.remove(queryWrapper);
|
|
|
Date date = new Date(System.currentTimeMillis());
|
|
Date date = new Date(System.currentTimeMillis());
|
|
|
- for(Map<String,Object> otherMap : itemList){
|
|
|
|
|
|
|
+ for (Map<String, Object> otherMap : itemList) {
|
|
|
AfterwardsAuditDetail afterwardsAuditDetail = new AfterwardsAuditDetail();
|
|
AfterwardsAuditDetail afterwardsAuditDetail = new AfterwardsAuditDetail();
|
|
|
BigDecimal amount = (BigDecimal) otherMap.getOrDefault(Constant.AMOUNT_KEY, 0);
|
|
BigDecimal amount = (BigDecimal) otherMap.getOrDefault(Constant.AMOUNT_KEY, 0);
|
|
|
afterwardsAuditDetail.setAmount(amount);
|
|
afterwardsAuditDetail.setAmount(amount);
|
|
@@ -212,7 +206,7 @@ public class FactorEnchangeFactory {
|
|
|
|
|
|
|
|
}
|
|
}
|
|
|
afterwardsAuditDetailService.saveBatch(afterwardsAuditDetailList);
|
|
afterwardsAuditDetailService.saveBatch(afterwardsAuditDetailList);
|
|
|
- }else {
|
|
|
|
|
|
|
+ } else {
|
|
|
BigDecimal amount = (BigDecimal) itemMap.getOrDefault(Constant.AMOUNT_KEY, 0);
|
|
BigDecimal amount = (BigDecimal) itemMap.getOrDefault(Constant.AMOUNT_KEY, 0);
|
|
|
AfterwardsAuditDetail afterwardsAuditDetail = new AfterwardsAuditDetail();
|
|
AfterwardsAuditDetail afterwardsAuditDetail = new AfterwardsAuditDetail();
|
|
|
afterwardsAuditDetail.setProejctCode(itemMap.get(Constant.PROJECT_CODE_KEY).toString());
|
|
afterwardsAuditDetail.setProejctCode(itemMap.get(Constant.PROJECT_CODE_KEY).toString());
|
|
@@ -243,24 +237,23 @@ public class FactorEnchangeFactory {
|
|
|
afterwardsAuditDetail.setTreatmentType(medicalInsRuleInfo.getTreatmentType());
|
|
afterwardsAuditDetail.setTreatmentType(medicalInsRuleInfo.getTreatmentType());
|
|
|
afterwardsAuditDetail.setAfterwardsAuditId(afterwardsAudit.getId());
|
|
afterwardsAuditDetail.setAfterwardsAuditId(afterwardsAudit.getId());
|
|
|
|
|
|
|
|
- afterwardsAuditService.lambdaUpdate().setSql("amount = amount +"+amount.doubleValue()).eq(AfterwardsAudit::getId, afterwardsAudit.getId()).update();
|
|
|
|
|
|
|
+ afterwardsAuditService.lambdaUpdate().setSql("amount = amount +" + amount.doubleValue()).eq(AfterwardsAudit::getId, afterwardsAudit.getId()).update();
|
|
|
afterwardsAuditDetailService.save(afterwardsAuditDetail);
|
|
afterwardsAuditDetailService.save(afterwardsAuditDetail);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
-
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- public void insertMidWarningDetail(Map<String, Object> itemMap, MedicalInsRuleInfo medicalInsRuleInfo, MidIncidentAudit midIncidentAudit,List<Map<String,Object>> itemList) {
|
|
|
|
|
|
|
+ public void insertMidWarningDetail(Map<String, Object> itemMap, MedicalInsRuleInfo medicalInsRuleInfo, MidIncidentAudit midIncidentAudit, List<Map<String, Object>> itemList) {
|
|
|
MidIncidentWarningVO midIncidentWarningVO = RuleEngine.midIncidentWarningVOThreadLocal.get();
|
|
MidIncidentWarningVO midIncidentWarningVO = RuleEngine.midIncidentWarningVOThreadLocal.get();
|
|
|
|
|
|
|
|
- if(Constant.VALIDATION_HANDER_METHOD_RETURN.equals(medicalInsRuleInfo.getViolationHandingMethod())) {
|
|
|
|
|
|
|
+ if (Constant.VALIDATION_HANDER_METHOD_RETURN.equals(medicalInsRuleInfo.getViolationHandingMethod())) {
|
|
|
midIncidentAuditService.lambdaUpdate().set(MidIncidentAudit::getAmount, midIncidentAudit.getAmount()).eq(MidIncidentAudit::getId, midIncidentAudit.getId()).update();
|
|
midIncidentAuditService.lambdaUpdate().set(MidIncidentAudit::getAmount, midIncidentAudit.getAmount()).eq(MidIncidentAudit::getId, midIncidentAudit.getId()).update();
|
|
|
QueryWrapper<MidIncidentAuditDetail> queryWrapper = new QueryWrapper();
|
|
QueryWrapper<MidIncidentAuditDetail> queryWrapper = new QueryWrapper();
|
|
|
queryWrapper.eq("mid_incident_audit_id", midIncidentAudit.getId());
|
|
queryWrapper.eq("mid_incident_audit_id", midIncidentAudit.getId());
|
|
|
midIncidentAuditDetailService.remove(queryWrapper);
|
|
midIncidentAuditDetailService.remove(queryWrapper);
|
|
|
List<MidIncidentAuditDetail> otherList = new ArrayList();
|
|
List<MidIncidentAuditDetail> otherList = new ArrayList();
|
|
|
- for(Map<String,Object> otherItemMap : itemList){
|
|
|
|
|
|
|
+ for (Map<String, Object> otherItemMap : itemList) {
|
|
|
MidIncidentAuditDetail midIncidentAuditDetail = new MidIncidentAuditDetail();
|
|
MidIncidentAuditDetail midIncidentAuditDetail = new MidIncidentAuditDetail();
|
|
|
midIncidentAuditDetail.setMedicalDeptCode(midIncidentWarningVO.getMedical_dept_code());
|
|
midIncidentAuditDetail.setMedicalDeptCode(midIncidentWarningVO.getMedical_dept_code());
|
|
|
midIncidentAuditDetail.setMedicalDeptName(midIncidentWarningVO.getMedical_dept_name());
|
|
midIncidentAuditDetail.setMedicalDeptName(midIncidentWarningVO.getMedical_dept_name());
|
|
@@ -291,7 +284,7 @@ public class FactorEnchangeFactory {
|
|
|
otherList.add(midIncidentAuditDetail);
|
|
otherList.add(midIncidentAuditDetail);
|
|
|
}
|
|
}
|
|
|
midIncidentAuditDetailService.saveBatch(otherList);
|
|
midIncidentAuditDetailService.saveBatch(otherList);
|
|
|
- }else {
|
|
|
|
|
|
|
+ } else {
|
|
|
MidIncidentAuditDetail midIncidentAuditDetail = new MidIncidentAuditDetail();
|
|
MidIncidentAuditDetail midIncidentAuditDetail = new MidIncidentAuditDetail();
|
|
|
midIncidentAuditDetail.setAmount(midIncidentAudit.getAmount());
|
|
midIncidentAuditDetail.setAmount(midIncidentAudit.getAmount());
|
|
|
BigDecimal amount = (BigDecimal) itemMap.getOrDefault(Constant.AMOUNT_KEY, 0);
|
|
BigDecimal amount = (BigDecimal) itemMap.getOrDefault(Constant.AMOUNT_KEY, 0);
|
|
@@ -320,7 +313,7 @@ public class FactorEnchangeFactory {
|
|
|
midIncidentAuditDetail.setMedicalProjectName(itemMap.get(Constant.MEDICAL_PROJECT_NAME_KEY).toString());
|
|
midIncidentAuditDetail.setMedicalProjectName(itemMap.get(Constant.MEDICAL_PROJECT_NAME_KEY).toString());
|
|
|
|
|
|
|
|
midIncidentAuditDetail.setProjectType(itemMap.getOrDefault(Constant.PROJECT_TYPE_KEY, "default").toString());
|
|
midIncidentAuditDetail.setProjectType(itemMap.getOrDefault(Constant.PROJECT_TYPE_KEY, "default").toString());
|
|
|
- midIncidentAuditService.lambdaUpdate().setSql("amount = amount +"+amount.doubleValue()).eq(MidIncidentAudit::getId, midIncidentAudit.getId()).update();
|
|
|
|
|
|
|
+ midIncidentAuditService.lambdaUpdate().setSql("amount = amount +" + amount.doubleValue()).eq(MidIncidentAudit::getId, midIncidentAudit.getId()).update();
|
|
|
|
|
|
|
|
midIncidentAuditDetailService.save(midIncidentAuditDetail);
|
|
midIncidentAuditDetailService.save(midIncidentAuditDetail);
|
|
|
}
|
|
}
|