|
|
|
@ -8,6 +8,7 @@ import com.gaotao.modules.productionInbound.dao.ProductionInboundMapper; |
|
|
|
import com.gaotao.modules.productionInbound.service.ProductionInboundService; |
|
|
|
import com.gaotao.modules.productionReturn.dao.ProductionReturnMapper; |
|
|
|
import com.gaotao.modules.productionReturn.service.ProductionReturnService; |
|
|
|
import com.gaotao.modules.schedule.mapper.ProcedureMapper; |
|
|
|
import com.gaotao.modules.sys.entity.SysUserEntity; |
|
|
|
import com.gaotao.modules.trans.entity.TransDetail; |
|
|
|
import com.gaotao.modules.trans.entity.TransDetailDto; |
|
|
|
@ -50,6 +51,9 @@ public class ProductionReturnServiceImpl implements ProductionReturnService { |
|
|
|
@Autowired |
|
|
|
private TransDetailSubService transDetailSubService; |
|
|
|
|
|
|
|
@Autowired |
|
|
|
private ProcedureMapper procedureMapper; |
|
|
|
|
|
|
|
@Override |
|
|
|
public List<Map<String, Object>> getQualifiedInboundList(String site, String warehouseId, String searchCode, String status) { |
|
|
|
SysUserEntity sysUserEntity = (SysUserEntity) SecurityUtils.getSubject().getPrincipal(); |
|
|
|
@ -64,60 +68,81 @@ public class ProductionReturnServiceImpl implements ProductionReturnService { |
|
|
|
} |
|
|
|
|
|
|
|
@Override |
|
|
|
public Map<String, Object> validateLabelWithInbound(String labelCode, String inboundNo, String partNo, String site, String buNo) { |
|
|
|
// 从SFDC_ROLLS表验证标签信息 |
|
|
|
Map<String, Object> result = productionReturnMapper.validateLabelWithInbound(labelCode, inboundNo, partNo, site, buNo); |
|
|
|
|
|
|
|
if (result == null || result.isEmpty()) { |
|
|
|
throw new RuntimeException("该标签与入库单不符,请检查"); |
|
|
|
public Map<String, Object> validateLabelWithInbound(String site, String buNo, String orderNo, String labelCode, String operationType, String userName) { |
|
|
|
logger.info("开始验证标签,标签条码: {}, 生产订单号: {}, 操作类型: {}", labelCode, orderNo, operationType); |
|
|
|
|
|
|
|
// 调用存储过程 GetScanLabelVerification |
|
|
|
List<Object> params = new ArrayList<>(); |
|
|
|
params.add(site); // 参数1: site |
|
|
|
params.add(buNo); // 参数2: buNo |
|
|
|
params.add(""); // 参数3: 空字符串 |
|
|
|
params.add(orderNo); // 参数4: 生产订单号 |
|
|
|
params.add(""); // 参数5: 空字符串 |
|
|
|
params.add(""); // 参数6: 空字符串 |
|
|
|
params.add(""); // 参数7: 空字符串 |
|
|
|
params.add(labelCode); // 参数8: 扫描的标签条码 |
|
|
|
params.add(""); // 参数9: 空字符串 |
|
|
|
params.add("生产退仓"); // 参数10: 生产退仓 |
|
|
|
params.add(operationType); // 参数11: I-添加 D-移除 |
|
|
|
params.add(userName); // 参数12: 当前登陆人 |
|
|
|
|
|
|
|
List<Map<String, Object>> resultList = procedureMapper.getProcedureData("GetScanLabelVerification", params); |
|
|
|
|
|
|
|
// 判断返回结果 |
|
|
|
if (resultList == null || resultList.isEmpty()) { |
|
|
|
throw new RuntimeException("存储过程调用失败"); |
|
|
|
} |
|
|
|
|
|
|
|
Map<String, Object> result = resultList.get(0); |
|
|
|
String code = String.valueOf(result.get("code")); |
|
|
|
|
|
|
|
if (!"200".equals(code)) { |
|
|
|
String msg = String.valueOf(result.get("message")); |
|
|
|
throw new RuntimeException(msg); |
|
|
|
} |
|
|
|
|
|
|
|
logger.info("标签验证成功,标签条码: {}", labelCode); |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
@Override |
|
|
|
@Transactional(rollbackFor = Exception.class) |
|
|
|
public boolean confirmInboundStorage(String orderNo, String locationCode, List<Map<String, Object>> labels, String site, String buNo) { |
|
|
|
logger.info("开始确认生产入库上架,入库单号: {}, 库位号: {}, 标签数量: {}", orderNo, locationCode, labels.size()); |
|
|
|
public boolean confirmInboundStorage(String site, String buNo, String orderNo, String locationCode, String userName) { |
|
|
|
logger.info("开始确认生产退仓上架,生产订单号: {}, 库位号: {}", orderNo, locationCode); |
|
|
|
|
|
|
|
try { |
|
|
|
// 1. 验证库位是否存在且可用 |
|
|
|
Map<String, Object> locationInfo = productionReturnMapper.validateLocation(locationCode, site); |
|
|
|
if (locationInfo == null || locationInfo.isEmpty()) { |
|
|
|
throw new RuntimeException("该库位不存在,请检查"); |
|
|
|
} |
|
|
|
String locationStatus = (String) locationInfo.get("status"); |
|
|
|
if (!"Y".equals(locationStatus)) { |
|
|
|
throw new RuntimeException("该库位已停用,请检查"); |
|
|
|
// 调用存储过程 GetSaveLabelVerification |
|
|
|
List<Object> params = new ArrayList<>(); |
|
|
|
params.add(site); // 参数1: site |
|
|
|
params.add(buNo); // 参数2: buNo |
|
|
|
params.add(""); // 参数3: 空字符串 |
|
|
|
params.add(orderNo); // 参数4: 生产订单号 |
|
|
|
params.add(""); // 参数5: 空字符串 |
|
|
|
params.add(""); // 参数6: 空字符串 |
|
|
|
params.add(""); // 参数7: 空字符串 |
|
|
|
params.add(locationCode); // 参数8: 库位 |
|
|
|
params.add("生产退仓"); // 参数9: 生产退仓 |
|
|
|
params.add(userName); // 参数10: 当前登陆人 |
|
|
|
|
|
|
|
List<Map<String, Object>> resultList = procedureMapper.getProcedureData("GetSaveLabelVerification", params); |
|
|
|
|
|
|
|
// 判断返回结果 |
|
|
|
if (resultList == null || resultList.isEmpty()) { |
|
|
|
throw new RuntimeException("存储过程调用失败"); |
|
|
|
} |
|
|
|
// 根据库位获取实际的仓库ID |
|
|
|
String warehouseId = (String) locationInfo.get("warehouseId"); |
|
|
|
if (warehouseId == null && warehouseId.trim().isEmpty()) { |
|
|
|
throw new RuntimeException("该库位未绑定仓库,请检查"); |
|
|
|
|
|
|
|
Map<String, Object> result = resultList.get(0); |
|
|
|
String code = String.valueOf(result.get("code")); |
|
|
|
|
|
|
|
if (!"200".equals(code)) { |
|
|
|
String msg = String.valueOf(result.get("message")); |
|
|
|
throw new RuntimeException(msg); |
|
|
|
} |
|
|
|
|
|
|
|
// 2. 提取标签条码列表 |
|
|
|
List<String> labelCodes = labels.stream() |
|
|
|
.map(label -> (String) label.get("labelCode")) |
|
|
|
.collect(Collectors.toList()); |
|
|
|
|
|
|
|
// // 3. 更新SFDC_ROLLS表中标签状态为"已入库" |
|
|
|
// int updatedLabels = productionReturnMapper.updateSfdcRollsStatus(labelCodes, "已入库", site, buNo); |
|
|
|
// if (updatedLabels != labelCodes.size()) { |
|
|
|
// throw new RuntimeException("部分标签状态更新失败"); |
|
|
|
// } |
|
|
|
|
|
|
|
// 5. 插入库存数据 |
|
|
|
insertInventoryStock(orderNo, warehouseId, locationCode, labels, site, buNo); |
|
|
|
|
|
|
|
// 6. 生成入库事务记录 |
|
|
|
generateInboundTransaction(orderNo, warehouseId, locationCode, labels, site, buNo); |
|
|
|
|
|
|
|
// 7. 异步调用ERP接口(这里可以发送消息到队列) |
|
|
|
//asyncCallErpInterface(orderNo, partNo, labels); |
|
|
|
|
|
|
|
logger.info("生产入库上架确认完成,入库单号: {}", orderNo); |
|
|
|
|
|
|
|
logger.info("生产退仓上架成功,生产订单号: {}", orderNo); |
|
|
|
return true; |
|
|
|
} catch (Exception e) { |
|
|
|
logger.error("生产入库确认失败,入库单号: {}, 错误信息: {}", orderNo, e.getMessage(), e); |
|
|
|
logger.error("生产退仓上架失败,生产订单号: {}, 错误信息: {}", orderNo, e.getMessage(), e); |
|
|
|
throw new RuntimeException("入库确认失败: " + e.getMessage(), e); |
|
|
|
} |
|
|
|
} |
|
|
|
@ -308,6 +333,28 @@ public class ProductionReturnServiceImpl implements ProductionReturnService { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
@Override |
|
|
|
public List<Map<String, Object>> getScannedLabelList(String site, String buNo, String orderNo) { |
|
|
|
logger.info("获取已扫描标签列表,站点: {}, 业务单元: {}, 生产订单号: {}", site, buNo, orderNo); |
|
|
|
|
|
|
|
try { |
|
|
|
List<Map<String, Object>> scannedList = productionReturnMapper.getScannedLabelList(site, buNo, orderNo); |
|
|
|
|
|
|
|
if (scannedList == null) { |
|
|
|
scannedList = new ArrayList<>(); |
|
|
|
} |
|
|
|
|
|
|
|
logger.info("获取已扫描标签列表成功,站点: {}, 业务单元: {}, 生产订单号: {}, 记录数: {}", |
|
|
|
site, buNo, orderNo, scannedList.size()); |
|
|
|
|
|
|
|
return scannedList; |
|
|
|
} catch (Exception e) { |
|
|
|
logger.error("获取已扫描标签列表失败,站点: {}, 业务单元: {}, 生产订单号: {}, 错误信息: {}", |
|
|
|
site, buNo, orderNo, e.getMessage(), e); |
|
|
|
throw new RuntimeException("获取已扫描标签列表失败: " + e.getMessage(), e); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
|
|
* 生成事务明细记录 |
|
|
|
*/ |
|
|
|
|