package com.zy.core.operation.handler;
|
|
import com.core.common.Cools;
|
import com.zy.asrs.controller.vo.ApplyInDto;
|
import com.zy.asrs.controller.vo.ApplyInRepsonseDto;
|
import com.zy.asrs.entity.Job;
|
import com.zy.asrs.service.JobService;
|
import com.zy.asrs.service.WmsMainService;
|
import com.zy.asrs.service.WrkLastnoService;
|
import com.zy.core.cache.SlaveConnection;
|
import com.zy.core.enums.ConveyorStateType;
|
import com.zy.core.enums.SlaveType;
|
import com.zy.core.model.DevpSlave;
|
import com.zy.core.model.protocol.StaProtocol;
|
import com.zy.core.operation.OperationHandler;
|
import com.zy.core.properties.CtuOperationConfig;
|
import com.zy.core.properties.SlaveProperties;
|
import com.zy.core.thread.BarcodeThread;
|
import com.zy.core.thread.SiemensDevpThread;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Component;
|
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.interceptor.TransactionAspectSupport;
|
|
import java.util.Date;
|
|
/**
|
* 入库
|
*/
|
@Slf4j
|
@Component
|
public class AppleLocOperationHandler implements OperationHandler {
|
|
@Autowired
|
private SlaveProperties slaveProperties;
|
|
|
@Autowired
|
private WrkLastnoService wrkLastnoService;
|
|
@Autowired
|
private WmsMainService wmsMainService;
|
|
@Autowired
|
private JobService jobService;
|
|
|
@Override
|
public ConveyorStateType getType() {
|
return ConveyorStateType.APPLYLOC;
|
}
|
|
@Override
|
@Transactional(rollbackFor = Exception.class)
|
public synchronized void execute(CtuOperationConfig config) {
|
try {
|
// 根据输送线plc遍历
|
for (DevpSlave devp : slaveProperties.getDevp()) {
|
// 遍历入库口
|
for (DevpSlave.Sta inSta : devp.getInSta()) {
|
// 根据输送线plc遍历
|
SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId());
|
StaProtocol staProtocol = devpThread.getStation().get(inSta.getStaNo());
|
BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, devp.getId());
|
if (staProtocol == null) {
|
return;
|
} else {
|
staProtocol = staProtocol.clone();
|
}
|
// 判断是否满足条件
|
if (!staProtocol.isLoading()) {
|
return;
|
}
|
if (staProtocol.getWorkNo() > 0 && staProtocol.isAutoing()) {
|
Job job = jobService.getJobByJobNoAndJobSts(staProtocol.getWorkNo(), 2);
|
if (job != null) {
|
String barcode = barcodeThread.getBarcode();
|
if (Cools.isEmpty(barcode)) {
|
log.info("未扫到码值:{}",barcode);
|
return;
|
}
|
ApplyInDto applyInDto = new ApplyInDto();
|
applyInDto.setStaNo(inSta.getStaNo() + "");
|
applyInDto.setBarcode(barcode);
|
ApplyInRepsonseDto locOfWms = wmsMainService.getLocOfWms(applyInDto);
|
if (locOfWms != null) {
|
job.setLoc(locOfWms.getLocNo());
|
job.setInTaskNo(locOfWms.getTaskNo());
|
job.setBatchNo(locOfWms.getBatchNo());
|
job.setStaNo(inSta.getTargetSta() + "");
|
job.setJobSts(4);
|
job.setWmsTime(new Date());
|
jobService.updateById(job);
|
} else {
|
log.info("WMS未返回库位信息,{}", applyInDto);
|
}
|
}
|
}
|
}
|
}
|
} catch (Exception e) {
|
e.printStackTrace();
|
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
|
}
|
}
|
}
|