|
@@ -1,24 +1,32 @@
|
|
|
package com.tuoren.web.layer.service.impl;
|
|
package com.tuoren.web.layer.service.impl;
|
|
|
|
|
|
|
|
|
|
+import cn.hutool.core.collection.CollectionUtil;
|
|
|
import cn.hutool.core.date.DateUtil;
|
|
import cn.hutool.core.date.DateUtil;
|
|
|
-import cn.hutool.json.JSONUtil;
|
|
|
|
|
|
|
+import cn.hutool.core.util.StrUtil;
|
|
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
import com.google.gson.Gson;
|
|
import com.google.gson.Gson;
|
|
|
import com.tuoren.common.utils.ConstastUtils;
|
|
import com.tuoren.common.utils.ConstastUtils;
|
|
|
import com.tuoren.web.layer.d0.PatientDTO;
|
|
import com.tuoren.web.layer.d0.PatientDTO;
|
|
|
|
|
+import com.tuoren.web.layer.entity.BusConstantEntity;
|
|
|
import com.tuoren.web.layer.entity.BusPatientEntity;
|
|
import com.tuoren.web.layer.entity.BusPatientEntity;
|
|
|
import com.tuoren.web.layer.mapper.BusPatientMapper;
|
|
import com.tuoren.web.layer.mapper.BusPatientMapper;
|
|
|
|
|
+import com.tuoren.web.layer.service.IBusConstantService;
|
|
|
import com.tuoren.web.layer.service.IBusPatientService;
|
|
import com.tuoren.web.layer.service.IBusPatientService;
|
|
|
import com.tuoren.web.layer.vo.PatientParam;
|
|
import com.tuoren.web.layer.vo.PatientParam;
|
|
|
|
|
+import com.tuoren.web.rabbit.helper.BusConstantHelper;
|
|
|
|
|
+import com.tuoren.web.utils.enums.BusConstantEnum;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
|
+import org.apache.commons.codec.digest.DigestUtils;
|
|
|
import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
|
import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Service;
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
|
|
import java.time.ZoneId;
|
|
import java.time.ZoneId;
|
|
|
import java.util.*;
|
|
import java.util.*;
|
|
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
|
* <p>
|
|
* <p>
|
|
@@ -34,6 +42,9 @@ public class BusPatientServiceImpl extends ServiceImpl<BusPatientMapper, BusPati
|
|
|
@Autowired
|
|
@Autowired
|
|
|
private RabbitTemplate rabbitTemplate;
|
|
private RabbitTemplate rabbitTemplate;
|
|
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IBusConstantService iBusConstantService;
|
|
|
|
|
+
|
|
|
@Override
|
|
@Override
|
|
|
public IPage<BusPatientEntity> queryFuzzyPatient(PatientParam patientParam) {
|
|
public IPage<BusPatientEntity> queryFuzzyPatient(PatientParam patientParam) {
|
|
|
IPage<BusPatientEntity> iPage = new Page<>(patientParam.getPageNo(), patientParam.getPageSize());
|
|
IPage<BusPatientEntity> iPage = new Page<>(patientParam.getPageNo(), patientParam.getPageSize());
|
|
@@ -116,5 +127,61 @@ public class BusPatientServiceImpl extends ServiceImpl<BusPatientMapper, BusPati
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 处理常量表数据是否修改
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param busPatientEntity
|
|
|
|
|
+ * @author wangzl
|
|
|
|
|
+ * @date 2025/9/3
|
|
|
|
|
+ */
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public List<BusConstantEntity> handleConstantData(BusPatientEntity busPatientEntity) {
|
|
|
|
|
+ if (busPatientEntity == null) {
|
|
|
|
|
+ return new ArrayList<>();
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ String hospitalCode = busPatientEntity.getHospitalCode();
|
|
|
|
|
+ if (StrUtil.isEmpty(hospitalCode) && StrUtil.isNotBlank(busPatientEntity.getPatientId())) {
|
|
|
|
|
+ BusPatientEntity dbEntity = this.baseMapper.selectById(busPatientEntity.getPatientId());
|
|
|
|
|
+ hospitalCode = dbEntity.getHospitalCode();
|
|
|
|
|
+ } else {
|
|
|
|
|
+ return new ArrayList<>();
|
|
|
|
|
+ }
|
|
|
|
|
+ List<BusConstantEntity> busConstantEntities = new ArrayList<>();
|
|
|
|
|
+ // 处理各个字段
|
|
|
|
|
+ addConstantIfValid(busConstantEntities, hospitalCode, busPatientEntity.getWardCode(), BusConstantEnum.wardCode);
|
|
|
|
|
+ addConstantIfValid(busConstantEntities, hospitalCode, busPatientEntity.getOperationName(), BusConstantEnum.operationName);
|
|
|
|
|
+ addConstantIfValid(busConstantEntities, hospitalCode, busPatientEntity.getOperationDoctor(), BusConstantEnum.operationDoctor);
|
|
|
|
|
+ addConstantIfValid(busConstantEntities, hospitalCode, busPatientEntity.getAnesthesiaDoctor1(), BusConstantEnum.anesthesiaDoctor);
|
|
|
|
|
+ addConstantIfValid(busConstantEntities, hospitalCode, busPatientEntity.getAnesthesiaMode(), BusConstantEnum.anesthesiaMode);
|
|
|
|
|
+ addConstantIfValid(busConstantEntities, hospitalCode, busPatientEntity.getEasyMode(), BusConstantEnum.easyMode);
|
|
|
|
|
+ addConstantIfValid(busConstantEntities, hospitalCode, busPatientEntity.getFormula(), BusConstantEnum.formula);
|
|
|
|
|
+ if (CollectionUtil.isNotEmpty(busConstantEntities)) {
|
|
|
|
|
+ List<String> md5s = busConstantEntities.stream().map(BusConstantEntity::getMd5).collect(Collectors.toList());
|
|
|
|
|
+ //先查询md5存在的
|
|
|
|
|
+ List<BusConstantEntity> list = iBusConstantService.list(new LambdaQueryWrapper<BusConstantEntity>()
|
|
|
|
|
+ .in(BusConstantEntity::getMd5, md5s));
|
|
|
|
|
+ //去掉已经存储的数据
|
|
|
|
|
+ return BusConstantHelper.dealConstantList(busConstantEntities, list);
|
|
|
|
|
+ }
|
|
|
|
|
+ return busConstantEntities;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ private void addConstantIfValid(List<BusConstantEntity> list, String hospitalCode, String content, BusConstantEnum type) {
|
|
|
|
|
+ Optional.ofNullable(content)
|
|
|
|
|
+ .filter(StrUtil::isNotEmpty)
|
|
|
|
|
+ .ifPresent(value -> list.add(buildBusConstantEntity(hospitalCode, value, type.getType())));
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ public BusConstantEntity buildBusConstantEntity(String hospitalCode, String content, Integer type) {
|
|
|
|
|
+ String md5 = DigestUtils.md5Hex(hospitalCode + content);
|
|
|
|
|
+ return BusConstantEntity.builder()
|
|
|
|
|
+ .hospitalCode(hospitalCode)
|
|
|
|
|
+ .content(content)
|
|
|
|
|
+ .md5(md5)
|
|
|
|
|
+ .type(type)
|
|
|
|
|
+ .build();
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
}
|
|
}
|