| package com.fzzy.async.fzzy30.impl; | 
|   | 
| import com.fzzy.api.Constant; | 
| import com.fzzy.api.entity.Api1105; | 
| import com.fzzy.api.entity.Api1203; | 
| import com.fzzy.api.entity.ApiLog; | 
| import com.fzzy.api.entity.GbCheckItem; | 
| import com.fzzy.api.service.ApiCommonService; | 
| import com.fzzy.api.service.ApiTriggerService; | 
| import com.fzzy.api.utils.ContextUtil; | 
| import com.fzzy.api.view.repository.Api1203Rep; | 
| import com.fzzy.api.view.repository.ApiLogRep; | 
| import com.fzzy.api.view.repository.GbCheckItemRep; | 
| import com.fzzy.async.fzzy30.entity.InoutCheckItem; | 
| import com.fzzy.async.fzzy30.entity.InoutRecord; | 
| import com.fzzy.async.fzzy30.repository.FzzySync1202Rep; | 
| import com.fzzy.async.fzzy30.repository.FzzySync1203Rep; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.stereotype.Component; | 
|   | 
| import java.util.Date; | 
| import java.util.List; | 
|   | 
| /** | 
|  * 粮食入库检验信息 | 
|  */ | 
| @Slf4j | 
| @Component | 
| public class Fzzy30Sync1203 { | 
|   | 
|     /** | 
|      * 入库类型 | 
|      */ | 
|     private final static String INOUT_TYPE_IN = "IN"; | 
|   | 
|     @Autowired | 
|     private FzzySync1202Rep fzzySync1202Rep; | 
|     @Autowired | 
|     private FzzySync1203Rep fzzySync1203Rep; | 
|     @Autowired | 
|     private ApiTriggerService apiTriggerService; | 
|     @Autowired | 
|     private Api1203Rep api1203Rep; | 
|     @Autowired | 
|     private GbCheckItemRep gbCheckItemRep; | 
|     @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("-------------1203接口数据开始同步------------------"); | 
|         //同步数据,只记录失败的信息 | 
|         ApiLog apiLog = new ApiLog(); | 
|         apiLog.setType(ApiLog.TYPE_SYNC); | 
|         apiLog.setKqdm(deptId); | 
|         apiLog.setUploadTime(new Date()); | 
|         apiLog.setInteId(Constant.API_CODE_1203); | 
|         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; | 
|             } | 
|   | 
|             Api1203 apiData; | 
|             Api1105 api1105; | 
|             List<InoutCheckItem> checkItems; | 
|             List<GbCheckItem> gbCheckList; | 
|             String jyxm; | 
|             String jyz; | 
|             String zkj; | 
|             String zkl; | 
|             for (InoutRecord sysData : list) { | 
|   | 
|                 //获取入库质检信息 | 
|                 checkItems = fzzySync1203Rep.listInoutCheckItem(sysData.getCheckId()); | 
|                 if (null == checkItems || checkItems.isEmpty()) { | 
|                     log.info("-------------没有获取到当前入库质检信息--------------"); | 
|                     continue; | 
|                 } | 
|   | 
|                 //获取货位信息 | 
|                 api1105 = commonService.getApi1105Cache(sysData.getDepotId()); | 
|                 if (null == api1105) { | 
|                     continue; | 
|                 } | 
|   | 
|                 apiData = new Api1203(); | 
|   | 
|                 //入库业务单号:14+yyMMdd+4为顺序号 | 
|                 apiData.setRkjydh(Constant.INOUT_TYPE_14 + sysData.getId().substring(4)); | 
|   | 
|                 //货位代码 | 
|                 apiData.setHwdm(api1105.getHwdm()); | 
|                 apiData.setRkywdh(apiData.getRkjydh()); | 
|                 apiData.setQysj(sysData.getFullWeightTime()); | 
|                 apiData.setQyrxm(sysData.getCheckUser()); | 
|                 //扦样方式 2-智能随机 | 
|                 apiData.setQyfs("2"); | 
|   | 
|                 //检测项,检测值,增扣价及增扣量 | 
|                 jyxm = ""; | 
|                 jyz = ""; | 
|                 zkj = ""; | 
|                 zkl = ""; | 
|                 for (InoutCheckItem checkItem : checkItems) { | 
|                     gbCheckList = gbCheckItemRep.findByBizCode(checkItem.getStandardId()); | 
|                     if (gbCheckList == null || gbCheckList.isEmpty()) { | 
|                         continue; | 
|                     } | 
|                     jyxm += gbCheckList.get(0).getCode() + ","; | 
|                     jyz += checkItem.getValue() + ","; | 
|                     zkj += "0,"; | 
|                     zkl += "0,"; | 
|                 } | 
|   | 
|                 apiData.setJyxm(jyxm); | 
|                 apiData.setJyz(jyz); | 
|                 apiData.setZkj(zkj); | 
|                 apiData.setZkl(zkl); | 
|                 apiData.setJyjg("1"); | 
|                 apiData.setJyrxm(sysData.getCheckUser()); | 
|                 apiData.setJysj(sysData.getFullWeightTime()); | 
|                 //apiData.setJyjg(""); | 
|   | 
|                 //粮食品种 | 
|                 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety()); | 
|                 apiData.setLspzdm(mappingCode); | 
|   | 
|                 //粮食等级 | 
|                 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSDJ, sysData.getFoodLevel()); | 
|                 apiData.setLsdd(mappingCode); | 
|   | 
|                 //操作标志及最后更新时间 | 
|                 apiData.setCzbz(Constant.CZBZ_I); | 
|                 apiData.setZhgxsj(sysData.getCompleteTime()); | 
|   | 
|                 //业务id、库区编码、同步时间 | 
|                 apiData.setBizId(sysData.getId()); | 
|                 apiData.setKqdm(kqdm); | 
|                 apiData.setSyncTime(new Date()); | 
|   | 
|                 //保存数据 | 
|                 api1203Rep.save(apiData); | 
|                 log.info("1203---同步数据:{}", apiData.toString()); | 
|             } | 
|         } catch (Exception e) { | 
|             log.error("---同步失败----{}", e); | 
|             apiLog.setResult("同步失败:" + e.getMessage()); | 
|             apiLogRep.save(apiLog); | 
|         } | 
|     } | 
| } |