| 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<InoutRecord> list = fzzySync1202Rep.listInoutRecord(deptId, INOUT_TYPE_IN, start, end); | 
|   | 
|             if (null == list || list.isEmpty()) { | 
|                 log.info("-------------没有获取到粮食入库信息------------------"); | 
|                 return; | 
|             } | 
|   | 
|             Api1202 apiData; | 
|             Api1105 api1105; | 
|             List<GbArea> 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); | 
|         } | 
|     } | 
| } |