| package com.fzzy.async.fzzy35.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.service.ApiCommonService; | 
| import com.fzzy.api.service.ApiTriggerService; | 
| import com.fzzy.api.utils.ContextUtil; | 
| import com.fzzy.api.utils.DateUtil; | 
| import com.fzzy.api.view.repository.Api1202Rep; | 
| import com.fzzy.api.view.repository.ApiLogRep; | 
| import com.fzzy.async.fzzy35.entity.Fz35InoutNoticeIn; | 
| import com.fzzy.async.fzzy35.entity.Fz35InoutRecord; | 
| import com.fzzy.async.fzzy35.repository.Fzzy35Sync1202Rep; | 
| import com.fzzy.async.fzzy35.repository.Fzzy35SyncNoticeInRep; | 
| 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.text.SimpleDateFormat; | 
| import java.util.*; | 
|   | 
| /** | 
|  * 粮食入库信息 | 
|  */ | 
| @Slf4j | 
| @Component | 
| public class Fzzy35Sync1202 { | 
|   | 
|     /** | 
|      * 入库类型 | 
|      */ | 
|     private final static String INOUT_TYPE_IN = "IN"; | 
|   | 
|     @Autowired | 
|     private Fzzy35Sync1202Rep fzzySync1202Rep; | 
|     @Autowired | 
|     private Fzzy35SyncNoticeInRep fzzy35SyncNoticeInRep; | 
|     @Autowired | 
|     private ApiTriggerService apiTriggerService; | 
|     @Autowired | 
|     private Api1202Rep api1202Rep; | 
|     @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<Fz35InoutRecord> list = fzzySync1202Rep.listInoutRecord(deptId, INOUT_TYPE_IN, start, end); | 
|   | 
|             if (null == list || list.isEmpty()) { | 
|                 log.info("-------------没有获取到粮食入库信息------------------"); | 
|                 return; | 
|             } | 
|   | 
|             Api1202 apiData; | 
|             Api1105 api1105; | 
|             List<Fz35InoutNoticeIn> listInoutNotice; | 
|             List<Api1202> api1202List; | 
|             for (Fz35InoutRecord 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 Api1202(); | 
|   | 
|                 apiData.setRkywdh(Constant.INOUT_TYPE_14 + sysData.getId().substring(4)); | 
|   | 
|                 //判断业务时间与单据号是否匹配,若不匹配,则更改业务时间为单据号所在的时间 | 
|                 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMdd"); | 
|                 Date time = dateFormat.parse(sysData.getId().substring(2, 10)); | 
|                 int numDay = DateUtil.difDay(DateUtil.getCurZero(sysData.getCompleteTime()), DateUtil.getCurZero(time)); | 
|                 if (numDay != 0) { | 
|                     sysData.setFullWeightTime(DateUtils.addDays(sysData.getFullWeightTime(), numDay)); | 
|                     sysData.setEmptyWeightTime(DateUtils.addDays(sysData.getEmptyWeightTime(), numDay)); | 
|                     sysData.setCompleteTime(DateUtils.addDays(sysData.getCompleteTime(), numDay)); | 
|                 } | 
|   | 
|                 //货位代码 | 
|                 apiData.setHwdm(api1105.getHwdm()); | 
|                 apiData.setYwlx(Constant.INOUT_TYPE_2); | 
|                 apiData.setYwrq(sysData.getRegisterTime()); | 
|                 apiData.setCyr(sysData.getUserName()); | 
|                 apiData.setBz(null == sysData.getRemarks() ? "备注" : sysData.getRemarks()); | 
|                 apiData.setKlyy("扣量原因"); | 
|   | 
|                 apiData.setCmqrmgryxm(sysData.getRegisterUser()); | 
|                 apiData.setDjmgryxm(sysData.getRegisterUser()); | 
|                 //01:表示大型汽车号牌,黄底黑字; 02:表示小型汽车号牌,蓝底白字; 03:表示新能源汽车号牌,绿底黑 字; | 
|                 //04:表示农用车车牌号,绿底白字; LS:表示临时虚拟号牌,仅限于售 粮车无固定号牌时使用 | 
|                 apiData.setCchlx("01"); | 
|                 apiData.setLdd("装粮地点"); | 
|                 apiData.setQzbwslkl(0.0); | 
|                 apiData.setQzzzzkl(0.0); | 
|                 apiData.setQzgwcmkl(0.0); | 
|                 apiData.setQzhhkl(0.0); | 
|                 apiData.setQzbwslkl(0.0); | 
|                 apiData.setQzhlmkl(0.0); | 
|                 apiData.setQzsmlkl(0.0); | 
|                 apiData.setQzzjmlkl(0.0); | 
|                 apiData.setQzqtkl(0.0); | 
|                 apiData.setZxzydw(api1105.getBgdw()); | 
|                 if (sysData.getCompanyId().equals("5329")) { | 
|                     apiData.setLqgsdwdm("91440604MA56D2AM1X"); | 
|                 } | 
|   | 
|   | 
|                 //默认一个随便值 | 
|                 apiData.setLxdh(StringUtils.isEmpty(sysData.getUserContact()) ? "13012345678" : sysData.getUserContact()); | 
|   | 
|                 apiData.setSfzh(null == sysData.getUserId() ? "410183199003187055" : sysData.getUserId().trim()); | 
|   | 
|                 //获取合同号 | 
|                 listInoutNotice = fzzy35SyncNoticeInRep.listInoutNoticeInById(sysData.getNoticeId()); | 
|                 if (null != listInoutNotice && listInoutNotice.size() > 0) { | 
|                     apiData.setHth(api1105.getHwdm().substring(0, 18) + listInoutNotice.get(0).getContractId()); | 
|                 } else { | 
|                     apiData.setHth(api1105.getHwdm().substring(0, 18) + apiData.getRkywdh()); | 
|                 } | 
|   | 
|                 apiData.setXxdz(sysData.getUserAddress()); | 
|   | 
|                 //运输工具,若为空,则默认给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_LSXZ, sysData.getFoodType()); | 
|                 apiData.setLsxzdm(mappingCode); | 
|   | 
|                 apiData.setShnd(StringUtils.isEmpty(sysData.getFoodYear()) ? DateFormatUtils.format(new Date(), "yyyy") : sysData.getFoodYear()); | 
|   | 
|                 //产地代码 | 
|                 String cddm = commonService.getFoodLocationIdFromCache(sysData.getFoodLocation()); | 
|                 apiData.setCddm(cddm); | 
|   | 
|                 //检斤类型,默认0-称重入库 | 
|                 apiData.setJjlx("0"); | 
|   | 
|                 //毛重信息 | 
|                 apiData.setMz(sysData.getFullWeight()); | 
|                 if (!sysData.getFullWeightTime().after(sysData.getRegisterTime())) { | 
|                     sysData.setFullWeightTime(DateUtils.addMinutes(sysData.getRegisterTime(), 25)); | 
|                 } | 
|                 apiData.setMzjlsj(sysData.getFullWeightTime()); | 
|                 apiData.setMzjby(sysData.getFullWeightUser()); | 
|                 apiData.setMzjly(sysData.getFullWeightUser()); | 
|   | 
|                 apiData.setZcy(null == sysData.getHandleUser() ? sysData.getFullWeightUser() : sysData.getHandleUser()); | 
|   | 
|                 //皮重信息 | 
|                 apiData.setPz(sysData.getEmptyWeight()); | 
|                 if (!sysData.getEmptyWeightTime().after(sysData.getFullWeightTime())) { | 
|                     sysData.setEmptyWeightTime(DateUtils.addMinutes(sysData.getFullWeightTime(), 60)); | 
|                 } | 
|                 apiData.setPzjlsj(sysData.getEmptyWeightTime()); | 
|                 apiData.setPzjby(sysData.getEmptyWeightUser()); | 
|                 apiData.setPzjly(sysData.getEmptyWeightUser()); | 
|   | 
|                 //扣重 化验总扣重 | 
|                 apiData.setZjklxj(0 - (sysData.getDeImpurity() + sysData.getDeWet())); | 
|   | 
|                 apiData.setQzsfzkl(0 - sysData.getDeWet()); | 
|                 apiData.setQzzzzkl(0 - sysData.getDeImpurity()); | 
|                 //其它 | 
|                 if (null == sysData.getDeOther()) { | 
|                     sysData.setDeOther(0.0); | 
|                 } | 
|                 apiData.setQtkl(0 - sysData.getDeOther()); | 
|                 //值仓 现场扣重 | 
|                 apiData.setXckl(0 - sysData.getDeHandle()); | 
|   | 
|                 apiData.setJz(sysData.getRecordWeight()); | 
|                 if (!sysData.getCompleteTime().after(sysData.getEmptyWeightTime())) { | 
|                     sysData.setCompleteTime(DateUtils.addMinutes(sysData.getEmptyWeightTime(), 10)); | 
|                 } | 
|                 apiData.setCmsj(sysData.getCompleteTime()); | 
|   | 
|                 //入库结算单号,默认统一结算,不设置结算单号 | 
|                 //apiData.setRkjsdh(kqdm + sysData.getId().substring(2)); | 
|   | 
|                 //操作标志及最后更新时间 | 
|                 apiData.setZhgxsj(sysData.getCompleteTime()); | 
|   | 
|                 //业务id、库区编码、同步时间 | 
|                 apiData.setBizId(sysData.getId()); | 
|                 apiData.setKqdm(kqdm); | 
|                 apiData.setSyncTime(new Date()); | 
|                 api1202List = api1202Rep.getDataById(apiData.getRkywdh()); | 
|                 if (null == api1202List || api1202List.isEmpty()) { | 
|                     apiData.setCzbz(Constant.CZBZ_I); | 
|                 } else { | 
|                     apiData.setCzbz(api1202List.get(0).getCzbz()); | 
|                 } | 
|                 //保存数据 | 
|                 api1202Rep.save(apiData); | 
|                 log.info("1202---同步数据:{}", apiData.toString()); | 
|             } | 
|         } catch (Exception e) { | 
|             log.error("---同步失败----{}", e); | 
|             apiLog.setResult("同步失败:" + e.getMessage()); | 
|             apiLogRep.save(apiLog); | 
|         } | 
|     } | 
| } |