|
|
@ -11,6 +11,7 @@ import com.gaotao.modules.trans.entity.TransHeader; |
|
|
import com.gaotao.modules.trans.service.TransDetailService; |
|
|
import com.gaotao.modules.trans.service.TransDetailService; |
|
|
import com.gaotao.modules.trans.service.TransDetailSubService; |
|
|
import com.gaotao.modules.trans.service.TransDetailSubService; |
|
|
import com.gaotao.modules.trans.service.TransHeaderService; |
|
|
import com.gaotao.modules.trans.service.TransHeaderService; |
|
|
|
|
|
import com.gaotao.modules.schedule.mapper.ProcedureMapper; |
|
|
import org.apache.shiro.SecurityUtils; |
|
|
import org.apache.shiro.SecurityUtils; |
|
|
import org.slf4j.Logger; |
|
|
import org.slf4j.Logger; |
|
|
import org.slf4j.LoggerFactory; |
|
|
import org.slf4j.LoggerFactory; |
|
|
@ -42,6 +43,9 @@ public class SalesOutboundServiceImpl implements SalesOutboundService { |
|
|
@Autowired |
|
|
@Autowired |
|
|
private TransDetailSubService transDetailSubService; |
|
|
private TransDetailSubService transDetailSubService; |
|
|
|
|
|
|
|
|
|
|
|
@Autowired |
|
|
|
|
|
private ProcedureMapper procedureMapper; |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public List<Map<String, Object>> getOutboundList(String site, String warehouseId, String searchCode, String status) { |
|
|
public List<Map<String, Object>> getOutboundList(String site, String warehouseId, String searchCode, String status) { |
|
|
SysUserEntity sysUserEntity = (SysUserEntity) SecurityUtils.getSubject().getPrincipal(); |
|
|
SysUserEntity sysUserEntity = (SysUserEntity) SecurityUtils.getSubject().getPrincipal(); |
|
|
@ -56,48 +60,95 @@ public class SalesOutboundServiceImpl implements SalesOutboundService { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
public List<Map<String, Object>> validateLabelWithOutbound(String labelCode, String outboundNo, String warehouseId, String site, String buNo) { |
|
|
|
|
|
// 从库存表验证标签信息,并检查是否与出库单匹配 |
|
|
|
|
|
List<Map<String, Object>> result = salesOutboundMapper.validateLabelWithOutbound(labelCode, outboundNo, warehouseId, site, buNo); |
|
|
|
|
|
if (result == null || result.isEmpty()) { |
|
|
|
|
|
throw new RuntimeException("该标签与出库单不符,请检查"); |
|
|
|
|
|
|
|
|
public Map<String, Object> validateLabelWithOutbound(String site, String buNo, String outboundNo, |
|
|
|
|
|
String relatedNo, String relatedLineNo, |
|
|
|
|
|
String labelCode, String operationType, |
|
|
|
|
|
String userName, String warehouseId) { |
|
|
|
|
|
logger.info("验证销售出库标签,site: {}, buNo: {}, 出库单号: {}, 关联单号: {}, 关联行号: {}, 标签: {}, 操作类型: {}, 仓库: {}", |
|
|
|
|
|
site, buNo, outboundNo, relatedNo, relatedLineNo, labelCode, operationType, warehouseId); |
|
|
|
|
|
|
|
|
|
|
|
try { |
|
|
|
|
|
// 调用存储过程 GetScanLabelVerification |
|
|
|
|
|
List<Object> params = new ArrayList<>(); |
|
|
|
|
|
params.add(site); // 参数1: site |
|
|
|
|
|
params.add(buNo); // 参数2: buNo |
|
|
|
|
|
params.add(outboundNo); // 参数3: 出库单号 |
|
|
|
|
|
params.add(relatedNo); // 参数4: 关联单号 |
|
|
|
|
|
params.add(relatedLineNo); // 参数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: 当前登陆人 |
|
|
|
|
|
params.add(warehouseId != null ? warehouseId : ""); // 参数13: 仓库ID |
|
|
|
|
|
|
|
|
|
|
|
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, operationType); |
|
|
return result; |
|
|
return result; |
|
|
|
|
|
} catch (Exception e) { |
|
|
|
|
|
logger.error("标签验证失败,标签: {}, 错误: {}", labelCode, e.getMessage(), e); |
|
|
|
|
|
throw new RuntimeException(e.getMessage(), e); |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Override |
|
|
@Override |
|
|
@Transactional(rollbackFor = Exception.class) |
|
|
@Transactional(rollbackFor = Exception.class) |
|
|
public boolean confirmSalesOutbound(String site, String buNo, String outboundNo, String warehouseId, List<Map<String, Object>> labels) { |
|
|
|
|
|
logger.info("开始确认销售出库,出库单号: {}, 仓库ID: {}, 标签数量: {}", outboundNo, warehouseId, labels.size()); |
|
|
|
|
|
|
|
|
public boolean confirmSalesOutbound(String site, String buNo, String outboundNo, |
|
|
|
|
|
String relatedNo, String relatedLineNo, |
|
|
|
|
|
String locationCode, String userName) { |
|
|
|
|
|
logger.info("开始确认销售出库,site: {}, buNo: {}, 出库单号: {}, 关联单号: {}, 关联行号: {}, 库位: {}", |
|
|
|
|
|
site, buNo, outboundNo, relatedNo, relatedLineNo, locationCode); |
|
|
|
|
|
|
|
|
try { |
|
|
try { |
|
|
// 1. 提取标签条码列表 |
|
|
|
|
|
List<String> labelCodes = labels.stream() |
|
|
|
|
|
.map(label -> (String) label.get("labelCode")) |
|
|
|
|
|
.collect(Collectors.toList()); |
|
|
|
|
|
|
|
|
|
|
|
// 2. 更新库存表中标签状态为"出库" |
|
|
|
|
|
int updatedLabels = salesOutboundMapper.updateInventoryStatus(labelCodes, "出库", site, buNo); |
|
|
|
|
|
if (updatedLabels != labelCodes.size()) { |
|
|
|
|
|
throw new RuntimeException("部分标签状态更新失败"); |
|
|
|
|
|
|
|
|
// 调用存储过程 GetSaveLabelVerification |
|
|
|
|
|
List<Object> params = new ArrayList<>(); |
|
|
|
|
|
params.add(site); // 参数1: site |
|
|
|
|
|
params.add(buNo); // 参数2: buNo |
|
|
|
|
|
params.add(outboundNo); // 参数3: 出库单号 |
|
|
|
|
|
params.add(relatedNo); // 参数4: 关联单号 |
|
|
|
|
|
params.add(relatedLineNo); // 参数5: 关联单行号 |
|
|
|
|
|
params.add(""); // 参数6: 空字符串 |
|
|
|
|
|
params.add(""); // 参数7: 空字符串 |
|
|
|
|
|
params.add(locationCode != null ? 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("存储过程调用失败"); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// // 3. 更新outbound_notification_head表状态为"已出库" |
|
|
|
|
|
// int updatedHead = salesOutboundMapper.updateOutboundNotificationStatus(outboundNo, "已出库", site, buNo); |
|
|
|
|
|
// if (updatedHead == 0) { |
|
|
|
|
|
// throw new RuntimeException("出库单状态更新失败"); |
|
|
|
|
|
// } |
|
|
|
|
|
|
|
|
|
|
|
// 4. 生成出库事务记录 |
|
|
|
|
|
generateOutboundTransaction(outboundNo, warehouseId, labels, site, buNo); |
|
|
|
|
|
|
|
|
Map<String, Object> result = resultList.get(0); |
|
|
|
|
|
String code = String.valueOf(result.get("code")); |
|
|
|
|
|
|
|
|
// 5. 异步调用ERP接口(这里可以发送消息到队列) |
|
|
|
|
|
//asyncCallErpInterface(outboundNo, labels); |
|
|
|
|
|
|
|
|
if (!"200".equals(code)) { |
|
|
|
|
|
String msg = String.valueOf(result.get("message")); |
|
|
|
|
|
throw new RuntimeException(msg); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
logger.info("销售出库确认完成,出库单号: {}", outboundNo); |
|
|
logger.info("销售出库确认完成,出库单号: {}", outboundNo); |
|
|
return true; |
|
|
return true; |
|
|
} catch (Exception e) { |
|
|
} catch (Exception e) { |
|
|
logger.error("销售出库确认失败,出库单号: {}, 错误信息: {}", outboundNo, e.getMessage(), e); |
|
|
|
|
|
throw new RuntimeException("出库确认失败: " + e.getMessage(), e); |
|
|
|
|
|
|
|
|
logger.error("销售出库确认失败,出库单号: {}, 错误: {}", outboundNo, e.getMessage(), e); |
|
|
|
|
|
throw new RuntimeException(e.getMessage(), e); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@ -154,6 +205,20 @@ public class SalesOutboundServiceImpl implements SalesOutboundService { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
public List<Map<String, Object>> getScannedLabelList(String site, String buNo, String outboundNo, |
|
|
|
|
|
String relatedNo, String relatedLineNo) { |
|
|
|
|
|
logger.info("获取已扫描标签列表,site: {}, buNo: {}, 出库单号: {}, 关联单号: {}, 关联行号: {}", |
|
|
|
|
|
site, buNo, outboundNo, relatedNo, relatedLineNo); |
|
|
|
|
|
|
|
|
|
|
|
try { |
|
|
|
|
|
return salesOutboundMapper.getScannedLabelList(site, buNo, outboundNo, relatedNo, relatedLineNo); |
|
|
|
|
|
} catch (Exception e) { |
|
|
|
|
|
logger.error("获取已扫描标签列表失败,错误: {}", e.getMessage(), e); |
|
|
|
|
|
return new ArrayList<>(); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
/** |
|
|
/** |
|
|
* 生成事务明细记录 |
|
|
* 生成事务明细记录 |
|
|
*/ |
|
|
*/ |
|
|
|