package com.fzzy.async.fzzy40.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.*; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.service.ApiTriggerService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.*; import com.fzzy.async.fzzy40.entity.Fz40InoutNoticeOut; import com.fzzy.async.fzzy40.entity.Fz40InoutRecord; import com.fzzy.async.fzzy40.entity.Fz40InoutRecordItem; import com.fzzy.async.fzzy40.repository.Fzzy40Sync1202Rep; import com.fzzy.async.fzzy40.repository.Fzzy40SyncInoutRecordItemRep; import com.fzzy.async.fzzy40.repository.Fzzy40SyncNoticeOutRep; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.time.DateFormatUtils; import org.apache.commons.lang.time.DateUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.*; /** * 粮食出库信息 */ @Slf4j @Component public class Fzzy40Sync1205 { /** * 出库类型 */ private final static String INOUT_TYPE_OUT = "OUT"; @Autowired private Fzzy40Sync1202Rep fzzySync1202Rep; @Autowired private Fzzy40SyncInoutRecordItemRep fzzy40SyncInoutRecordItemRep; @Autowired private Fzzy40SyncNoticeOutRep fzzySyncNoticeOutRep; @Autowired private ApiTriggerService apiTriggerService; @Autowired private Api1201Rep api1201Rep; @Autowired private Api1205Rep api1205Rep; @Autowired private Api1206Rep api1206Rep; @Autowired private Api1404Rep api1404Rep; @Autowired private ApiCommonService commonService; @Autowired private ApiLogRep apiLogRep; /** * 粮食出库信息 * * @param deptId * @param start * @param end */ public void syncData(String kqdm, String deptId, Date start, Date end) { log.info("-------------1205接口数据开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1205); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { //获取粮食出库信息,根据流程完成时间获取 List list = fzzySync1202Rep.listInoutRecord(deptId, INOUT_TYPE_OUT, start, end); if (null == list || list.isEmpty()) { log.info("-------------没有获取到粮食出库信息------------------"); return; } Api1205 apiData; Api1105 api1105; List listInoutNotice; List api1205List; List api1206List; List listInoutRecordItem; for (Fz40InoutRecord sysData : list) { if(sysData.getRecordStatus().equals("DEL") || sysData.getRecordStatus().equals("ERROR")){ continue; } if(null == sysData.getRecordWeight() || sysData.getRecordWeight() == 0){ sysData.setRecordWeight(sysData.getSettleWeight()); } //判断净重是否大于0,等于0表示不合格,不进行同步上传 if(null == sysData.getRecordWeight() || sysData.getRecordWeight() == 0){ continue; } //获取货位信息 api1105 = commonService.getApi1105Cache(sysData.getDepotId()); if(null == api1105){ continue; } apiData = new Api1205(); apiData.setCkywdh(Constant.INOUT_TYPE_15 + sysData.getId().substring(4)); //货位代码 apiData.setHwdm(api1105.getHwdm()); apiData.setYwlx(Constant.INOUT_TYPE_1); apiData.setYwrq(DateUtils.parseDate(sysData.getId().substring(2, 10), new String[] { "yyyyMMdd" })); apiData.setCyr(sysData.getUserName()); //默认一个随便值 apiData.setLxdh(StringUtils.isEmpty(sysData.getUserContact()) ? "13012345678" : sysData.getUserContact().trim()); if(StringUtils.isEmpty(sysData.getUserId()) || sysData.getUserId().length() != 18){ sysData.setUserId("410183199003187055"); } apiData.setSfzh(sysData.getUserId()); //通知单号 apiData.setCktzdh(sysData.getNoticeId()); //获取合同号 listInoutNotice = fzzySyncNoticeOutRep.listInoutNoticeOutById(sysData.getNoticeId()); if (null != listInoutNotice && listInoutNotice.size() > 0) { //合同号 if (StringUtils.isNotEmpty(listInoutNotice.get(0).getContractId())) { List api1201List = api1201Rep.getDataByBizId(listInoutNotice.get(0).getContractId()); if(null != api1201List && api1201List.size() > 0){ apiData.setHth(api1201List.get(0).getHth()); } } if (StringUtils.isNotEmpty(listInoutNotice.get(0).getPlanId())) { List api1404List = api1404Rep.getDataByBizIdAndKqdm(listInoutNotice.get(0).getPlanId(), kqdm); if(null != api1404List && api1404List.size() > 0){ apiData.setJhmxh(api1404List.get(0).getJhmxdh()); if(StringUtils.isEmpty(sysData.getFoodYear())){ sysData.setFoodYear(api1404List.get(0).getShnd()); } } } } //运输工具,若为空,则默认给1-汽车 apiData.setYsgj(StringUtils.isEmpty(sysData.getTransType()) ? "1":sysData.getTransType()); //车船号 apiData.setCch(sysData.getPlateNum()); apiData.setDjsj(sysData.getRegisterTime()); //粮食品种 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety().substring(0, 3)); apiData.setLspzdm(mappingCode); //粮食等级 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSDJ, sysData.getFoodLevel()); apiData.setLsdjdm(mappingCode); //粮食性质 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSXZ, sysData.getFoodType()); apiData.setLsxzdm(mappingCode); apiData.setShnd(StringUtils.isEmpty(sysData.getFoodYear())? DateFormatUtils.format(sysData.getRegisterTime(), "yyyy") :sysData.getFoodYear()); //产地代码 mappingCode = commonService.getFoodLocationIdFromCache(sysData.getFoodLocation()); if(StringUtils.isEmpty(mappingCode)){ mappingCode = apiData.getHwdm().substring(2,8); } apiData.setCddm(mappingCode); //皮重信息 apiData.setPz(sysData.getEmptyWeight()); if (null == sysData.getEmptyWeightTime()) { sysData.setEmptyWeightTime(DateUtils.addMinutes(sysData.getRegisterTime(), 25)); } if(!sysData.getEmptyWeightTime().after(sysData.getRegisterTime())){ sysData.setEmptyWeightTime(DateUtils.addMinutes(sysData.getRegisterTime(), 25)); } apiData.setPzjlsj(sysData.getEmptyWeightTime()); apiData.setPzjby(StringUtils.isEmpty(sysData.getEmptyWeightUser())?"监磅员":sysData.getEmptyWeightUser()); apiData.setPzjly(StringUtils.isEmpty(sysData.getEmptyWeightUser())?"计量员":sysData.getEmptyWeightUser()); //毛重信息 apiData.setMz(sysData.getFullWeight()); if (null == sysData.getFullWeightTime()) { sysData.setFullWeightTime(DateUtils.addMinutes(sysData.getEmptyWeightTime(), 60)); } if(!sysData.getFullWeightTime().after(sysData.getEmptyWeightTime())){ sysData.setFullWeightTime(DateUtils.addMinutes(sysData.getEmptyWeightTime(), 60)); } apiData.setMzjlsj(sysData.getFullWeightTime()); apiData.setMzjby(StringUtils.isEmpty(sysData.getFullWeightUser())?"监磅员":sysData.getFullWeightUser()); apiData.setMzjly(StringUtils.isEmpty(sysData.getFullWeightUser())?"计量员":sysData.getFullWeightUser()); //净重 apiData.setJz(sysData.getRecordWeight()); if(!sysData.getCompleteTime().after(sysData.getFullWeightTime())){ sysData.setCompleteTime(DateUtils.addMinutes(sysData.getFullWeightTime(), 10)); } apiData.setCmsj(sysData.getCompleteTime()); //结算单号 if(StringUtils.isNotEmpty(sysData.getSettleId())){ apiData.setCkjsdh(kqdm + sysData.getSettleId()); } if(StringUtils.isNotEmpty(apiData.getHth())){ api1206List = api1206Rep.getDataByHthAndHwdm(apiData.getHth(), apiData.getHwdm()); if(null == api1206List || api1206List.isEmpty()){ api1206List = api1206Rep.getDataByHth(apiData.getHth()); if(null != api1206List && api1206List.size() > 0){ apiData.setCkjsdh(api1206List.get(0).getCkjsdh()); } }else { apiData.setCkjsdh(api1206List.get(0).getCkjsdh()); } } apiData.setCchlx("01"); apiData.setXldd("库内"); apiData.setBz(StringUtils.isEmpty(sysData.getRemarks())?"暂无备注信息":sysData.getRemarks()); apiData.setBzbdbz(25); apiData.setBzbjs(0); apiData.setCmqrmgryxm(StringUtils.isEmpty(sysData.getRegisterUser())?"门岗人":sysData.getRegisterUser()); apiData.setDjmgryxm(StringUtils.isEmpty(sysData.getRegisterUser())?"登记人":sysData.getRegisterUser()); apiData.setZcbgyxm(StringUtils.isEmpty(sysData.getHandleUser())?"值仓员":sysData.getHandleUser()); apiData.setZxzydw("外聘单位"); //操作标志及最后更新时间 apiData.setZhgxsj(sysData.getUpdateTime()); //业务id、库区编码、同步时间 apiData.setBizId(sysData.getId()); apiData.setKqdm(kqdm); apiData.setSyncTime(new Date()); log.info("1205---同步数据:{}",apiData.toString()); //判断是否为船运 if(StringUtils.isNotEmpty(sysData.getTransType()) && sysData.getTransType().equals("3")){ listInoutRecordItem = fzzy40SyncInoutRecordItemRep.findDataByRecordId(sysData.getId()); if(null == listInoutRecordItem || listInoutRecordItem.isEmpty()){ api1205Rep.save(apiData); continue; } int idNum = Integer.valueOf(sysData.getId().substring(12))*100 + 10001; for (Fz40InoutRecordItem fz40InoutRecordItem : listInoutRecordItem) { if ("DEL".equals(fz40InoutRecordItem.getRecordStatus())) { continue; } if(fz40InoutRecordItem.getSettleWeight() <= 0){ continue; } apiData.setCkywdh(Constant.INOUT_TYPE_15 + sysData.getId().substring(4,10) + String.valueOf(idNum).substring(1)); apiData.setMz(fz40InoutRecordItem.getFullWeight()); apiData.setPz(fz40InoutRecordItem.getEmptyWeight()); apiData.setJz(fz40InoutRecordItem.getSettleWeight()); apiData.setMzjlsj(fz40InoutRecordItem.getFullWeightTime()); apiData.setPzjlsj(fz40InoutRecordItem.getEmptyWeightTime()); apiData.setKzl(0 - fz40InoutRecordItem.getDe()); api1205List = api1205Rep.getDataById(apiData.getCkywdh()); if(null == api1205List || api1205List.isEmpty()){ apiData.setCzbz(Constant.CZBZ_I); }else { apiData.setCzbz(api1205List.get(0).getCzbz()); } api1205Rep.save(apiData); idNum ++; } }else { api1205List = api1205Rep.getDataById(apiData.getCkywdh()); if(null == api1205List || api1205List.isEmpty()){ apiData.setCzbz(Constant.CZBZ_I); }else { apiData.setCzbz(api1205List.get(0).getCzbz()); } //保存数据 api1205Rep.save(apiData); } } } catch (Exception e) { log.error("---同步失败----{}", e); apiLog.setResult("同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }