package com.ld.igds.sh.service; import com.alibaba.fastjson.JSONObject; import com.ld.igds.constant.CheckType; import com.ld.igds.inout.InoutConstant; import com.ld.igds.log.service.InteStatusLogService; import com.ld.igds.models.CheckItem; import com.ld.igds.models.InoutRecord; import com.ld.igds.models.InteStatusLog; import com.ld.igds.sh.dto.ApiResponse; import com.ld.igds.sh.dto.Dto1303; import com.ld.igds.sh.param.ApiRequest; import com.ld.igds.sh.param.BaseParam; import com.ld.igds.sh.service.impl.HApiShServiceImpl; import com.ld.igds.sh.util.ApiShConst; import com.ld.igds.sh.util.ApiShUtil; import com.ld.igds.sh.util.RespCodeEnum; import com.ld.igds.sh.util.RespUtil; import com.ld.igds.util.ContextUtil; import com.ld.igds.util.RedisUtil; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.time.DateFormatUtils; import org.apache.commons.lang3.time.DateUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * 粮食入库检验信息数据接口 * * @author chen */ @Slf4j @Service public class ApiShServiceImpl1303 implements ApiShService { @Autowired private HApiShServiceImpl hApiShServiceImpl; @Autowired private InteStatusLogService inteStatusLogService; @Autowired private RedisUtil redisUtil; @Override public String getInterfaceId() { return ApiShConst.API_SH_1303; } @SuppressWarnings("unchecked") @Override public ApiResponse execute(ApiRequest request){ //获取参数信息 String deptId = request.getDeptId(); BaseParam param = JSONObject.parseObject(JSONObject.toJSONString(request.getData()), BaseParam.class); String companyId = ContextUtil.getDefaultCompanyId(); // String key = RedisConst.buildKey(companyId, ApiShConst.API_SH_1112); // Date startTime = (Date) redisUtil.get(key); // if(null == startTime){ // startTime = DateUtils.addDays(param.getEndTime(), -30); // } // redisUtil.set(key, param.getEndTime()); if(null == param.getStartTime()){ param.setStartTime(DateUtils.addDays(param.getEndTime(), -1)); } //查询入库数据 List inoutRecords = hApiShServiceImpl.listInoutRecord(companyId, param.getDepotId(), param.getStartTime(), param.getEndTime(), InoutConstant.TYPE_IN); //响应数据为空则直接返回响应码2000 if (inoutRecords == null || inoutRecords.isEmpty()) { return RespUtil.error(RespCodeEnum.CODE_2000.getCode(), request); } List checkItems; List list = new ArrayList<>(); Dto1303 dto; InteStatusLog log; InteStatusLog addLog; for (InoutRecord inoutRecord : inoutRecords) { dto = new Dto1303(); dto.setQydbh("14" + inoutRecord.getCheckId().substring(2)); dto.setHwbm(ApiShUtil.getGbDepotId(inoutRecord.getDepotId()) + "01"); dto.setYpbm("14" + inoutRecord.getCheckId().substring(2)); dto.setQysj(DateFormatUtils.format(inoutRecord.getEmptyWeightTime(),"yyyy-MM-dd HH:mm:ss")); dto.setQyrxm(StringUtils.isEmpty(inoutRecord.getCheckUser())?"0":inoutRecord.getCheckUser()); checkItems = hApiShServiceImpl.listInoutChecks(companyId, inoutRecord.getCheckId()); if(checkItems != null && checkItems.size()>0){ String str1 = ""; String str2 = ""; String str3 = ""; String str4 = ""; for (CheckItem item : checkItems) { str1 += "," + CheckType.getRemark(item.getStandardId()); str2 += ","+ (StringUtils.isEmpty(item.getRemarks())?"0":item.getRemarks()); str3 += ",0"; str4 += ",0"; } dto.setJyxm(str1.substring(1)); dto.setJyjg(str2.substring(1)); dto.setZkj(str3.substring(1)); dto.setZkl(str4.substring(1)); }else { dto.setJyxm("0"); dto.setJyjg("0"); dto.setZkj("0"); dto.setZkl("0"); } dto.setJyrxm(StringUtils.isEmpty(inoutRecord.getCheckUser())?"0":inoutRecord.getCheckUser()); dto.setJysj(DateFormatUtils.format(inoutRecord.getEmptyWeightTime(),"yyyy-MM-dd HH:mm:ss")); if("PASS".equals(inoutRecord.getCheckStatus())){ dto.setJyjl("1"); }else { dto.setJyjl("0"); } dto.setPzbm(StringUtils.isEmpty(inoutRecord.getFoodVariety())?"0":inoutRecord.getFoodVariety()); dto.setLsdd(StringUtils.isEmpty(inoutRecord.getFoodLevel())?"0":inoutRecord.getFoodLevel()); dto.setZhgxsj(DateFormatUtils.format(new Date(), "yyyy-MM-dd HH:mm:ss")); //查询日志状态表,设置操作标志 log = inteStatusLogService.getLogByBizId(companyId, ApiShConst.API_SH_1303 + "_" + inoutRecord.getId()); if(null == log){ addLog = new InteStatusLog(); addLog.setBizId(ApiShConst.API_SH_1303 + "_" + inoutRecord.getId()); addLog.setCompanyId(companyId); addLog.setBizType(ApiShConst.API_SH_TYPE_INOUT); addLog.setInterfaceId(ApiShConst.API_SH_1303); addLog.setInterfaceType(ApiShConst.API_SH_TYPE_INOUT); addLog.setStatus(ApiShConst.API_SH_STATUS_SUCCESS); inteStatusLogService.addInteStatusLog(addLog); }else { dto.setCzbz(ApiShConst.API_SH_U); } list.add(dto); } //响应数据为空则直接返回响应码2000 if (list.isEmpty()) { return RespUtil.error(RespCodeEnum.CODE_2000.getCode(), request); } return RespUtil.success(list, request); } }