| | |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import zy.cloud.wms.common.config.CodeCoolException; |
| | | import zy.cloud.wms.common.model.MatnrDto; |
| | | import zy.cloud.wms.common.model.OrderStoDto; |
| | | import zy.cloud.wms.common.service.asrs.AsrsService; |
| | | import zy.cloud.wms.common.service.asrs.entity.Result; |
| | | import zy.cloud.wms.common.service.asrs.entity.Result1; |
| | | import zy.cloud.wms.common.utils.VersionUtils; |
| | | import zy.cloud.wms.manager.entity.*; |
| | | import zy.cloud.wms.manager.service.CustOrderService; |
| | | import zy.cloud.wms.manager.entity.param.StockTransferParam; |
| | | import zy.cloud.wms.manager.entity.result.PakoutVo; |
| | | import zy.cloud.wms.manager.service.LocDetlService; |
| | | import zy.cloud.wms.manager.service.MatService; |
| | | import zy.cloud.wms.manager.service.OrderService; |
| | | import zy.cloud.wms.manager.service.PakoutService; |
| | | |
| | | import java.util.*; |
| | |
| | | @Autowired |
| | | private PakoutService pakoutService; |
| | | @Autowired |
| | | private CustOrderService custOrderService; |
| | | @Autowired |
| | | private SnowflakeIdWorker snowflakeIdWorker; |
| | | @Autowired |
| | | private OrderService orderService; |
| | | @Autowired |
| | | private AsrsService asrsService; |
| | | |
| | | @Transactional |
| | | public List<StoPreTab> stockOutPreview(OrderStoDto dto) { |
| | | if (Cools.isEmpty(dto) || Cools.isEmpty(dto.getCustOrders())) { |
| | | public List<StoPreTab> stockOutPreview(OrderStoDto orderStoDto) { |
| | | if (Cools.isEmpty(orderStoDto) || Cools.isEmpty(orderStoDto.getDtos())) { |
| | | throw new CoolException("数据异常,请联系管理员"); |
| | | } |
| | | List<StoPreTab> res = new ArrayList<>(); |
| | | // 检查库存是否足够 |
| | | locDetlService.checkLocDetlCount(dto.getNumber()); |
| | | List<StockTransferParam> transferParams = locDetlService.checkLocDetlCountOfRes(orderStoDto.getDtos()); |
| | | if (!Cools.isEmpty(transferParams)) { |
| | | // 查看立库库存 |
| | | Result result = asrsService.stockTransferPrew(transferParams); |
| | | if (result.getCode() == 500) { |
| | | throw new CodeCoolException("20001-" + String.valueOf(result.getMsg())); |
| | | } |
| | | if (result.getCode() == 200) { |
| | | res = (List<StoPreTab>) result.getData(); |
| | | } |
| | | } |
| | | |
| | | for (CustOrder custOrder : dto.getCustOrders()) { |
| | | for (MatnrDto matnrDto : orderStoDto.getDtos()) { |
| | | // 判断物料是否存在 |
| | | Mat mat = matService.selectByMatnr(custOrder.getUserCode()); |
| | | Mat mat = matService.selectByMatnr(matnrDto.getMatnr()); |
| | | if (null == mat) { |
| | | throw new CoolException(custOrder.getUserCode() + "物料尚未更新。" + custOrder.getNumber() +"单据因此中断!"); |
| | | throw new CoolException(matnrDto.getMatnr() + "物料尚未更新。" + orderStoDto.getOrderNo() +"单据因此中断!"); |
| | | } |
| | | // 查询存有当前物料的货位 |
| | | List<LocDetl> locDetls = locDetlService.findOfSort(mat.getMatnr()); |
| | | double issued = Optional.ofNullable(custOrder.getQty()).orElse(0.0D) ; |
| | | double issued = Optional.ofNullable(matnrDto.getCount()).orElse(0.0D) ; |
| | | double anfme = issued; |
| | | for (LocDetl locDetl : locDetls) { |
| | | if (issued > 0) { |
| | |
| | | } |
| | | |
| | | @Transactional |
| | | public void stockOutProcess(OrderStoDto dto) { |
| | | if (Cools.isEmpty(dto) || Cools.isEmpty(dto.getCustOrders())) { |
| | | public void stockOutProcess(OrderStoDto orderStoDto) { |
| | | if (Cools.isEmpty(orderStoDto) || Cools.isEmpty(orderStoDto.getDtos())) { |
| | | return; |
| | | } |
| | | Order order = orderService.selectByOrderNo(orderStoDto.getOrderNo()); |
| | | if (order == null) { |
| | | throw new CoolException(orderStoDto.getOrderNo() + "单据不存在"); |
| | | } |
| | | Date now = new Date(); |
| | | |
| | | /******************************* 立库拣货单 ********************************/ |
| | | // 检查库存是否足够 |
| | | locDetlService.checkLocDetlCount(dto.getNumber()); |
| | | List<StockTransferParam> transferParams = locDetlService.checkLocDetlCountOfRes(orderStoDto.getDtos()); |
| | | if (!Cools.isEmpty(transferParams)) { |
| | | // 查看立库库存 |
| | | Result1 result = asrsService.stockTransfer(transferParams); |
| | | if (result.getCode() == 500) { |
| | | if (Cools.isEmpty(result.getData())) { |
| | | throw new CoolException(result.getMsg()); |
| | | } else { |
| | | throw new CodeCoolException("20001-" + result.getData()); |
| | | } |
| | | } |
| | | if (result.getCode() == 200) { |
| | | for (PakoutVo vo : result.getData()) { |
| | | // 判断物料是否存在 |
| | | Mat mat = matService.selectByMatnr(vo.getMatnr()); |
| | | if (null == mat) { |
| | | throw new CoolException(vo.getMatnr() + "物料尚未更新。" + orderStoDto.getOrderNo() +"单据因此中断!"); |
| | | } |
| | | Pakout pakout = new Pakout(); |
| | | pakout.setWrkSts(1L); |
| | | pakout.setAnfme(vo.getAnfme()); |
| | | pakout.setZpallet(vo.getZpallet()); |
| | | pakout.setLocNo(vo.getLocNo()); |
| | | pakout.setNodeId(-1L); |
| | | pakout.setWrkNo(String.valueOf(snowflakeIdWorker.nextId())); |
| | | VersionUtils.setPakout(pakout, mat); |
| | | pakout.setDocId(order.getDocType()); // 单据类型 |
| | | pakout.setDocNum(order.getOrderNo()); // 单据编号 |
| | | pakout.setCreateTime(now); |
| | | pakout.setUpdateTime(now); |
| | | pakout.setStatus(1); |
| | | if (!pakoutService.insert(pakout)) { |
| | | throw new CoolException("保存出库通知单失败"); |
| | | } |
| | | } |
| | | |
| | | /******************************* 平仓拣货单 ********************************/ |
| | | for (CustOrder custOrder : dto.getCustOrders()) { |
| | | } |
| | | } |
| | | |
| | | for (MatnrDto matnrDto : orderStoDto.getDtos()) { |
| | | // 判断物料是否存在 |
| | | Mat mat = matService.selectByMatnr(custOrder.getUserCode()); |
| | | Mat mat = matService.selectByMatnr(matnrDto.getMatnr()); |
| | | if (null == mat) { |
| | | throw new CoolException(custOrder.getUserCode() + "物料尚未更新。" + custOrder.getNumber() +"单据因此中断!"); |
| | | throw new CoolException(matnrDto.getMatnr() + "物料尚未更新。" + matnrDto.getCount() +"单据因此中断!"); |
| | | } |
| | | // 查询存有当前物料的货位 |
| | | List<LocDetl> locDetls = locDetlService.findOfSort(mat.getMatnr()); |
| | | double issued = Optional.ofNullable(custOrder.getQty()).orElse(0.0D) ; |
| | | double issued = Optional.ofNullable(matnrDto.getCount()).orElse(0.0D) ; |
| | | for (LocDetl locDetl : locDetls) { |
| | | if (issued > 0) { |
| | | // 保存出库通知单 |
| | |
| | | pakout.setNodeId(locDetl.getNodeId()); |
| | | pakout.setWrkNo(String.valueOf(snowflakeIdWorker.nextId())); |
| | | VersionUtils.setPakout(pakout, mat); |
| | | pakout.setDocId(getDocId(dto.getNumber())); // 单据类型 |
| | | pakout.setDocNum(custOrder.getNumber()); // 单据编号 |
| | | pakout.setDocId(order.getDocType()); // 单据类型 |
| | | pakout.setDocNum(order.getOrderNo()); // 单据编号 |
| | | pakout.setCreateTime(now); |
| | | pakout.setUpdateTime(now); |
| | | pakout.setStatus(1); |
| | |
| | | } |
| | | } |
| | | // 修改单据状态 |
| | | if (!custOrderService.updateStatus(custOrder.getNumber(), 2)) { |
| | | if (!orderService.updateSettle(orderStoDto.getOrderNo(), 2L)) { |
| | | throw new CoolException("修改单据状态失败"); |
| | | } |
| | | } |
| | | } |
| | | |
| | | private Long getDocId(String number) { |
| | | if (number.startsWith("PR")) { |
| | | return 6L; |
| | | } |
| | | return 11L; |
| | | } |
| | | |
| | | } |