package com.fzzy.async.fzzy30.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.Api1105; import com.fzzy.api.entity.Api1202; import com.fzzy.api.entity.ApiLog; import com.fzzy.api.entity.GbArea; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.service.ApiTriggerService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.Api1202Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.api.view.repository.GbAreaRep; import com.fzzy.async.fzzy30.entity.InoutRecord; import com.fzzy.async.fzzy30.repository.FzzySync1202Rep; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.Calendar; import java.util.Date; import java.util.List; /** * 粮食入库信息 */ @Slf4j @Component public class Fzzy30Sync1202 { /** * 入库类型 */ private final static String INOUT_TYPE_IN = "IN"; @Autowired private FzzySync1202Rep fzzySync1202Rep; @Autowired private ApiTriggerService apiTriggerService; @Autowired private Api1202Rep api1202Rep; @Autowired private GbAreaRep gbAreaRep; @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("-------------1202接口数据开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1202); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { //获取粮食入库记录信息,根据流程完成时间获取 List list = fzzySync1202Rep.listInoutRecord(deptId, INOUT_TYPE_IN, start, end); if (null == list || list.isEmpty()) { log.info("-------------没有获取到粮食入库信息------------------"); return; } Api1202 apiData; Api1105 api1105; List gbAreaList; Calendar c = Calendar.getInstance(); for (InoutRecord sysData : list) { //获取货位信息 api1105 = commonService.getApi1105Cache(sysData.getDepotId()); if (null == api1105) { continue; } apiData = new Api1202(); //入库业务单号:14+yyMMdd+4为顺序号 apiData.setRkywdh(Constant.INOUT_TYPE_14 + sysData.getId().substring(4)); //货位代码 apiData.setHwdm(api1105.getHwdm()); apiData.setYwlx(Constant.INOUT_TYPE_2); apiData.setYwrq(sysData.getRegisterTime()); apiData.setCyr(sysData.getUserName()); if(null == sysData.getUserContact()){ apiData.setLxdh("13012341234"); }else { apiData.setLxdh(sysData.getUserContact()); } if(null == sysData.getUserId()){ apiData.setSfzh("410183200010100000"); }else { apiData.setSfzh(sysData.getUserId()); } apiData.setXxdz(sysData.getUserAddress()); //运输工具,默认汽车 apiData.setYsgj("1"); //车船号 apiData.setCch(sysData.getPlateNum()); c.setTime(sysData.getRegisterTime()); c.add(Calendar.MINUTE,-5); apiData.setDjsj(c.getTime()); //粮食品种 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety()); apiData.setLspzdm(mappingCode); //粮食性质 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSXZ, sysData.getFoodType()); apiData.setLsxzdm(mappingCode); apiData.setShnd(sysData.getFoodYear()); //产地代码 gbAreaList = gbAreaRep.listByName("%" + sysData.getFoodLocation() + "%"); apiData.setCddm(gbAreaList.get(0).getCode()); //检斤类型,默认0-称重入库 apiData.setJjlx("0"); //毛重信息 apiData.setMz(sysData.getFullWeight()); apiData.setMzjlsj(sysData.getFullWeightTime()); apiData.setMzjby(sysData.getFullWeightUser()); apiData.setMzjly(sysData.getFullWeightUser()); apiData.setZcy(sysData.getHandleUser()); //皮重信息 apiData.setPz(sysData.getEmptyWeight()); apiData.setPzjlsj(sysData.getEmptyWeightTime()); apiData.setPzjby(sysData.getEmptyWeightUser()); apiData.setPzjly(sysData.getEmptyWeightUser()); //扣重 化验总扣重 apiData.setZjklxj( 0 - (sysData.getDeImpurity()+sysData.getDeWet()+sysData.getDeBroken())); apiData.setQzsfzkl(0 - sysData.getDeWet()); apiData.setQzzzzkl(0 - sysData.getDeImpurity()); apiData.setQzbwslkl(0 - sysData.getBroken()); //包装 apiData.setBzwkl(0 - sysData.getDePack()); //其它 apiData.setQtkl( 0 - sysData.getDeOther()); //值仓 现场扣重 apiData.setXckl( 0 - sysData.getDeHandle()); apiData.setJz(sysData.getSettleWeight()); c.setTime(sysData.getCompleteTime()); c.add(Calendar.MINUTE,5); apiData.setCmsj(c.getTime()); //入库结算单号 apiData.setRkjsdh(kqdm + sysData.getId().substring(2)); //操作标志及最后更新时间 apiData.setCzbz(Constant.CZBZ_I); apiData.setZhgxsj(c.getTime()); //业务id、库区编码、同步时间 apiData.setBizId(sysData.getId()); apiData.setKqdm(kqdm); apiData.setSyncTime(new Date()); //保存数据 api1202Rep.save(apiData); log.info("1202---同步数据:{}", apiData.toString()); } } catch (Exception e) { log.error("---同步失败----{}", e); apiLog.setResult("同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }