package com.fzzy.async.fzzy40.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.*; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.Api1102Rep; import com.fzzy.api.view.repository.Api1108Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.async.fzzy40.entity.Fz40Drug; import com.fzzy.async.fzzy40.repository.Fzzy40Sync1108Rep; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; /** * 药剂信息同步 * * @Author:YAN */ @Slf4j @Component public class Fzzy40Sync1108 { @Autowired private Fzzy40Sync1108Rep fzzy40Sync1108Rep; @Autowired private ApiLogRep apiLogRep; @Autowired private Api1102Rep api1102Rep; @Autowired private Api1108Rep api1108Rep; /** * 同步药剂信息 * * @param kqdm * @param deptId * @param start * @param end */ public void syncData(String kqdm, String deptId, Date start, Date end) { log.info("-------------1108接口药剂信息开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1108); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { List list = fzzy40Sync1108Rep.listDrug(deptId, start, end); if (null == list || list.isEmpty()) { log.info("-------------没有获取到药剂信息------------------"); return; } Api1102 api1102 = api1102Rep.findById(kqdm).get(); Api1108 apiData; List api1108List; for (Fz40Drug sysData : list) { apiData = new Api1108(); apiData.setId(kqdm + sysData.getId());//ID apiData.setBizId(sysData.getId());//业务id apiData.setDwdm(api1102.getDwdm());//单位代码 apiData.setKqdm(api1102.getKqdm());//库区代码 apiData.setKqmc(api1102.getKqmc());//库区名称 apiData.setYjbh(kqdm + sysData.getId().substring(8));//药剂编号 apiData.setYjmc(sysData.getName());//药剂名称 apiData.setBzw(StringUtils.isEmpty(sysData.getBzw())?"":sysData.getBzw());//包装物 apiData.setGgxh(StringUtils.isEmpty(sysData.getGgxh())?"":sysData.getGgxh());//型号规格 apiData.setAqsysms(StringUtils.isEmpty(sysData.getAqsysms())?"":sysData.getAqsysms());//安全使用说明书 apiData.setSccj(StringUtils.isEmpty(sysData.getSccj())?"":sysData.getSccj());//生产厂家 apiData.setCgly(StringUtils.isEmpty(sysData.getCgly())?"":sysData.getCgly());//采购来源 apiData.setCctj(StringUtils.isEmpty(sysData.getCctj())?"":sysData.getCctj());//存储条件 apiData.setCcdd(StringUtils.isEmpty(sysData.getCcdd())?"":sysData.getCcdd());//储存地点 apiData.setBzwclfs(StringUtils.isEmpty(sysData.getBzwclfs())?"":sysData.getBzwclfs());//包装物处理方式 apiData.setCzclfs(StringUtils.isEmpty(sysData.getCzclfs())?"":sysData.getCzclfs());//残渣处理方式 apiData.setBzq(StringUtils.isEmpty(sysData.getBzw())? "1年": sysData.getBzq());//保质期 apiData.setCgrq(null == sysData.getBzw()?new Date():sysData.getCgrq());//采购日期 apiData.setKcsl(sysData.getCount());//库存数量 apiData.setKcsldw(StringUtils.isEmpty(sysData.getKcsldw())?"":sysData.getKcsldw());//库存数量单位 apiData.setZhgxsj(sysData.getUpdateTime());//最后更新时间 apiData.setBizId(sysData.getId());//业务id api1108List = api1108Rep.getDataByBizId(apiData.getBizId()); if (null == api1108List || api1108List.isEmpty()) { apiData.setCzbz(Constant.CZBZ_I); } else { apiData.setCzbz(api1108List.get(0).getCzbz()); } //保存数据 api1108Rep.save(apiData); log.info("1108---同步数据:{}", apiData.toString()); } } catch (Exception e) { log.error("---药剂信息同步执行失败----{}", e.toString()); apiLog.setResult("药剂信息同步执行失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }