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<Object> execute(ApiRequest<Object> 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<InoutRecord> 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<CheckItem> checkItems;
|
List<Dto1303> 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);
|
}
|
}
|