package com.fzzy.async.fzzy61.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.Api1105; import com.fzzy.api.entity.Api1209; import com.fzzy.api.entity.ApiLog; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.Api1209Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.async.fzzy61.entity.Fz61InoutLossOver; import com.fzzy.async.fzzy61.repository.Fzzy61Sync1209Rep; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.time.DateUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.math.BigDecimal; import java.math.RoundingMode; import java.util.Date; import java.util.List; /** * 粮食损溢 */ @Slf4j @Component public class Fzzy61Sync1209 { /** * 损溢类型-损耗 */ public static final String LOSS_OVER_LOSS = "LOSS"; /** * 损溢类型-溢出 */ public static final String LOSS_OVER_OVER = "OVER"; @Autowired private Fzzy61Sync1209Rep fzzySync1209Rep; @Autowired private Api1209Rep api1209Rep; @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("-------------1209接口数据开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1209); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { List list = fzzySync1209Rep.listMLossOver(deptId, start, end); if (null == list || list.isEmpty()) { log.info("-------------没有获取到粮食损溢信息------------------"); return; } Api1209 apiData; Api1105 api1105; List api1209List; for (Fz61InoutLossOver sysData : list) { //获取货位信息 api1105 = commonService.getApi1105Cache(sysData.getDepotId()); if (null == api1105) { continue; } apiData = new Api1209(); apiData.setSydh(api1105.getHwdm() + sysData.getId()); apiData.setHwdm(api1105.getHwdm()); apiData.setYwrq(sysData.getSubmitTime()); apiData.setSylx(sysData.getType()); //净重损溢数量,损耗为正,溢出为负 apiData.setJzsysl(sysData.getAmount()); if (LOSS_OVER_LOSS.equals(sysData.getType())) { sysData.setType("2"); } if (LOSS_OVER_OVER.equals(sysData.getType())) { sysData.setType("3"); apiData.setJzsysl(0 - sysData.getAmount()); } apiData.setRkjz(sysData.getRkjz()); apiData.setCkjz(sysData.getCkjz()); apiData.setRksj(sysData.getRksj()); apiData.setCksj(sysData.getCksj()); apiData.setCcsc(sysData.getCcsc()); apiData.setRksf(sysData.getRksf()); apiData.setRkzz(sysData.getRkzz()); apiData.setCksf(sysData.getCksf()); apiData.setCkzz(sysData.getCkzz()); apiData.setQzszkl(sysData.getQzszkl()); BigDecimal bigDecimal = BigDecimal.valueOf(sysData.getQzzrshde()); apiData.setQzzrshde(bigDecimal.setScale(3, RoundingMode.UP).doubleValue()); apiData.setChsl(sysData.getChsl()); apiData.setCqqrbs(1); apiData.setCqqrsj(sysData.getCqqrsj() == null ? DateUtils.addSeconds(sysData.getCksj(), 120) : sysData.getCqqrsj()); apiData.setSyhj("2"); apiData.setSysfzc(StringUtils.isEmpty(sysData.getSysfzc()) ? "0" : sysData.getSysfzc()); apiData.setSfch(sysData.getSfch()); apiData.setSyyy(sysData.getSyyy()); apiData.setCcshr(StringUtils.isEmpty(sysData.getCcshr()) ? "审核人" : sysData.getCcshr()); apiData.setZjshr(StringUtils.isEmpty(sysData.getZjshr()) ? "审核人" : sysData.getZjshr()); apiData.setTjshr(StringUtils.isEmpty(sysData.getTjshr()) ? "审核人" : sysData.getTjshr()); apiData.setKjshr(StringUtils.isEmpty(sysData.getKjshr()) ? "审核人" : sysData.getKjshr()); apiData.setLdshr(StringUtils.isEmpty(sysData.getLdshr()) ? "审核人" : sysData.getLdshr()); apiData.setBz(StringUtils.isEmpty(sysData.getRemark()) ? "备注信息" : sysData.getRemark()); //操作标志及最后更新时间 apiData.setZhgxsj(new Date()); //业务id、库区编码、同步时间 apiData.setBizId(sysData.getId()); apiData.setKqdm(kqdm); apiData.setSyncTime(new Date()); api1209List = api1209Rep.getDataBySydh(apiData.getSydh()); if (null == api1209List || api1209List.isEmpty()) { apiData.setCzbz(Constant.CZBZ_I); } else { apiData.setCzbz(api1209List.get(0).getCzbz()); } //保存数据 api1209Rep.save(apiData); } } catch (Exception e) { log.error("---1209损溢信息同步失败----{}", e.toString()); apiLog.setResult("同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }