|  |  | 
 |  |  | import com.core.exception.CoolException; | 
 |  |  | import com.zy.asrs.entity.*; | 
 |  |  | import com.zy.asrs.entity.param.*; | 
 |  |  | import com.zy.asrs.enums.CommonEnum; | 
 |  |  | import com.zy.asrs.enums.LocStsType; | 
 |  |  | import com.zy.asrs.mapper.LocMastMapper; | 
 |  |  | import com.zy.asrs.mapper.ManLocDetlMapper; | 
 |  |  | import com.zy.asrs.service.*; | 
 |  |  | import com.zy.asrs.utils.MatUtils; | 
 |  |  | import com.zy.asrs.utils.OrderInAndOutUtil; | 
 |  |  | import com.zy.common.constant.MesConstant; | 
 |  |  | import com.zy.common.entity.Parameter; | 
 |  |  | import com.zy.common.model.DetlDto; | 
 |  |  | 
 |  |  |     private MatService matService; | 
 |  |  |     @Autowired | 
 |  |  |     private WaitPakinService waitPakinService; | 
 |  |  |     @Autowired | 
 |  |  |     private OrderService orderService; | 
 |  |  |     @Autowired | 
 |  |  |     private OrderDetlService orderDetlService; | 
 |  |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private BasDevpService basDevpService; | 
 |  |  |     @Autowired | 
 |  |  | 
 |  |  |                     continue; | 
 |  |  |                 } | 
 |  |  |                 if (orderPakout.getSettle() == 1) { | 
 |  |  |                     OrderInAndOutUtil.updateOrder(false, orderPakout.getId(), 2L, 9527L); | 
 |  |  |                     orderPakoutService.updateSettle(orderPakout.getId(), 2L, 9527L); | 
 |  |  |                 } | 
 |  |  |                 OrderDetlPakout orderDetlPakout = orderDetlPakoutService.selectItem(orderPakout.getId(), combMat.getMatnr(), combMat.getBatch(), | 
 |  |  |                         combMat.getBrand(), combMat.getStandby1(), combMat.getStandby2(), combMat.getStandby3(), combMat.getBoxType1(), combMat.getBoxType2(), combMat.getBoxType3()); | 
 |  |  | 
 |  |  |             typeList.add(docType.getDocId()); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         Wrapper<Order> wrapper = new EntityWrapper<>(); | 
 |  |  |         Wrapper<OrderPakin> wrapper = new EntityWrapper<>(); | 
 |  |  |         wrapper.eq("status", 1); | 
 |  |  |         wrapper.in("doc_type", typeList); | 
 |  |  |         List<Order> orders = orderService.selectList(wrapper); | 
 |  |  |         List<OrderPakin> orders = orderPakinService.selectList(wrapper); | 
 |  |  |  | 
 |  |  |         ArrayList<Long> orderIds = new ArrayList<>(); | 
 |  |  |         for (Order order : orders) { | 
 |  |  |         for (OrderPakin order : orders) { | 
 |  |  |             orderIds.add(order.getId()); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         //搜索明细 | 
 |  |  |         Wrapper<OrderDetl> wrapper1 = new EntityWrapper<>(); | 
 |  |  |         Wrapper<OrderDetlPakin> wrapper1 = new EntityWrapper<>(); | 
 |  |  |         wrapper1.eq("status", 1); | 
 |  |  |         wrapper1.in("order_id", orderIds); | 
 |  |  |         wrapper1.orderBy("create_time", false); | 
 |  |  | 
 |  |  |         if (!Cools.isEmpty(orderNo)) { | 
 |  |  |             wrapper1.like("order_no", orderNo); | 
 |  |  |         } | 
 |  |  |         List<OrderDetl> list = orderDetlService.selectList(wrapper1); | 
 |  |  |         List<OrderDetlPakin> list = orderDetlPakinService.selectList(wrapper1); | 
 |  |  |  | 
 |  |  |         ArrayList<PickMatParam> maps = new ArrayList<>(); | 
 |  |  |         for (OrderDetl orderDetl : list) { | 
 |  |  |         for (OrderDetlPakin orderDetl : list) { | 
 |  |  |             //剩余可用数量 | 
 |  |  |             double count = orderDetl.getAnfme() - orderDetl.getWorkQty(); | 
 |  |  |             if (count <= 0) { | 
 |  |  | 
 |  |  |             } | 
 |  |  |             // 关联组托 | 
 |  |  |         } else { | 
 |  |  | //            Order order = orderService.selectByNo(param.getOrderNo()); | 
 |  |  |             // 生成入库通知档 | 
 |  |  |             List<DetlDto> detlDtos = new ArrayList<>(); | 
 |  |  |             param.getCombMats().forEach(elem -> { | 
 |  |  |                 Order order = OrderInAndOutUtil.selectByNo(Boolean.TRUE, elem.getOrderNo()); | 
 |  |  |                 OrderPakin order = orderPakinService.selectByNo(elem.getOrderNo()); | 
 |  |  |                 if (Cools.isEmpty(order) || order.getSettle() > 2) { | 
 |  |  |                     throw new CoolException("单据编号已过期"); | 
 |  |  |                 } | 
 |  |  |                 // 订单明细数量校验 | 
 |  |  | //                OrderDetl orderDetl = OrderInAndOutUtil.selectItem(Boolean.TRUE, order.getId(), elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(), | 
 |  |  | //                        elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3()); | 
 |  |  |                 OrderDetlPakin detls = orderDetlPakinService.selectOne(new EntityWrapper<OrderDetlPakin>() | 
 |  |  |                         .eq("order_id", order.getId()) | 
 |  |  |                         .eq("matnr", elem.getMatnr())); | 
 |  |  | 
 |  |  |                 if (elem.getAnfme() > detls.getEnableQty()) { | 
 |  |  |                     throw new CoolException(detls.getMatnr() + "入库数量不合法"); | 
 |  |  |                 } | 
 |  |  |                 OrderInAndOutUtil.increaseWorkQty(Boolean.TRUE, order.getId(), elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(), | 
 |  |  |                 orderDetlPakinService.increaseWorkQty(order.getId(), elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(), | 
 |  |  |                         elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme()); | 
 |  |  |                 DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getBrand(), elem.getStandby1(), elem.getStandby2(), elem.getStandby3(), | 
 |  |  |                         elem.getBoxType1(), elem.getBoxType2(), elem.getBoxType3(), elem.getAnfme()); | 
 |  |  | 
 |  |  |  | 
 |  |  |             Set<String> stringSet = param.getCombMats().stream().map(CombParam.CombMat::getOrderNo).collect(Collectors.toSet()); | 
 |  |  |             stringSet.forEach(orderNo -> { | 
 |  |  |                 Order order = OrderInAndOutUtil.selectByNo(Boolean.TRUE, orderNo); | 
 |  |  |                 OrderInAndOutUtil.updateOrder(Boolean.TRUE, order.getId(), 2L, userId); | 
 |  |  |                 OrderPakin order = orderPakinService.selectByNo(orderNo); | 
 |  |  |                 orderPakinService.updateSettle(order.getId(), 2L, userId); | 
 |  |  |             }); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  | 
 |  |  |             openParam.setOrderType("打包入库单"); | 
 |  |  |             openParam.setOrderDetails(detlDtos); | 
 |  |  |             openService.pakinOrderCreate(openParam); | 
 |  |  | //            Order order = orderService.selectByNo(orderNo); | 
 |  |  |             Order order = OrderInAndOutUtil.selectByNo(Boolean.TRUE, param.getOrderNo()); | 
 |  |  |             OrderPakin order = orderPakinService.selectByNo(param.getOrderNo()); | 
 |  |  |  | 
 |  |  |             if (null == order) { | 
 |  |  |                 throw new CoolException("生成单据失败"); | 
 |  |  |             } | 
 |  |  | //            if (!orderService.updateSettle(order.getId(), 2L, userId)) { | 
 |  |  | //                throw new CoolException("修改单据状态失败"); | 
 |  |  | //            } | 
 |  |  |             OrderInAndOutUtil.updateOrder(Boolean.TRUE, order.getId(), 2L, userId); | 
 |  |  |  | 
 |  |  |             if (!orderPakinService.updateSettle(order.getId(), 2L, userId)) { | 
 |  |  |                 throw new CoolException("修改单据状态失败"); | 
 |  |  |             } | 
 |  |  |             // 生成入库通知档 | 
 |  |  |             for (DetlDto detlDto : detlDtos) { | 
 |  |  |  | 
 |  |  |                 // 修改作业数量 ---------------------------------------- | 
 |  |  |                 // 订单明细数量校验 | 
 |  |  | //                OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), detlDto.getMatnr(), detlDto.getBatch()); | 
 |  |  |                 OrderDetl orderDetl = OrderInAndOutUtil.selectItem(Boolean.TRUE, order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getBrand(), detlDto.getStandby1(), detlDto.getStandby2(), detlDto.getStandby3() | 
 |  |  |                 OrderDetlPakin orderDetlPakin = orderDetlPakinService.selectItem(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getBrand(), detlDto.getStandby1(), detlDto.getStandby2(), detlDto.getStandby3() | 
 |  |  |                         , detlDto.getBoxType1(), detlDto.getBoxType2(), detlDto.getBoxType3()); | 
 |  |  |                 if (detlDto.getAnfme() > orderDetl.getEnableQty()) { | 
 |  |  |                     throw new CoolException(orderDetl.getMatnr() + "入库数量不合法"); | 
 |  |  |                 if (detlDto.getAnfme() > orderDetlPakin.getEnableQty()) { | 
 |  |  |                     throw new CoolException(orderDetlPakin.getMatnr() + "入库数量不合法"); | 
 |  |  |                 } | 
 |  |  |                 // 修改订单作业数量 | 
 |  |  | //                if (!orderDetlService.increaseWorkQty(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getAnfme())) { | 
 |  |  | //                    throw new CoolException("修改单据作业数量失败"); | 
 |  |  | //                } | 
 |  |  |                 OrderInAndOutUtil.increaseWorkQty(Boolean.TRUE, order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getBrand(), detlDto.getStandby1(), detlDto.getStandby2(), detlDto.getStandby3() | 
 |  |  |                         , detlDto.getBoxType1(), detlDto.getBoxType2(), detlDto.getBoxType3(), detlDto.getAnfme()); | 
 |  |  |                 if (!orderDetlPakinService.increaseWorkQty(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getBrand(), detlDto.getStandby1(), detlDto.getStandby2(), detlDto.getStandby3() | 
 |  |  |                         , detlDto.getBoxType1(), detlDto.getBoxType2(), detlDto.getBoxType3(), detlDto.getAnfme())) { | 
 |  |  |                     throw new CoolException("修改单据作业数量失败"); | 
 |  |  |                 } | 
 |  |  |                 // 保存入库通知档 | 
 |  |  |                 Mat mat = matService.selectByMatnr(detlDto.getMatnr()); | 
 |  |  |                 if (Cools.isEmpty(mat)) { | 
 |  |  | 
 |  |  |  | 
 |  |  |         BasDevp sta = basDevpService.checkSiteStatus(staNo); | 
 |  |  |         //根据订单号生成出库任务工作档 | 
 |  |  |         Order order = OrderInAndOutUtil.selectByNo(Boolean.FALSE, orderNo); | 
 |  |  | //        Order order = orderService.selectOne(new EntityWrapper<Order>().eq("order_no", orderNo)); | 
 |  |  |         OrderPakout order = orderPakoutService.selectOne(new EntityWrapper<OrderPakout>().eq("order_no", orderNo)); | 
 |  |  |         if (order.getSettle() != 1 && order.getSettle() != 2) { | 
 |  |  |             throw new CoolException("该订单已处理"); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  | //        List<OrderDetl> orderDetls = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", orderNo)); | 
 |  |  |         List<OrderDetl> orderDetls = OrderInAndOutUtil.selectByOrderId(Boolean.FALSE, order.getId()); | 
 |  |  |         List<OrderDetlPakout> orderDetls = orderDetlPakoutService.selectByOrderId(order.getId()); | 
 |  |  |  | 
 |  |  |         Date now = new Date(); | 
 |  |  |         for (OrderDetl orderDetl : orderDetls) { | 
 |  |  |         for (OrderDetlPakout orderDetl : orderDetls) { | 
 |  |  |             //查询所有库位状态为F的库位信息 | 
 |  |  |             List<LocDetl> locDetls = locDetlService.queryStock(orderDetl.getMatnr(), orderDetl.getBatch(), null, null); | 
 |  |  |             if (locDetls.size() == 0) { | 
 |  |  | 
 |  |  |                 order.setSettle(2L); | 
 |  |  |                 order.setUpdateBy(userId); | 
 |  |  |                 order.setUpdateTime(now); | 
 |  |  | //                if(!orderService.update(order, new EntityWrapper<Order>().eq("order_no", orderNo))){ | 
 |  |  | //                    throw new CoolException("更新订单状态失败"); | 
 |  |  | //                } | 
 |  |  |                 OrderInAndOutUtil.updateOrder(order.getPakinPakoutStatus$(), order.getId(), 2L, userId); | 
 |  |  |                 if (!orderPakoutService.update(order, new EntityWrapper<OrderPakout>().eq("order_no", orderNo))) { | 
 |  |  |                     throw new CoolException("更新订单状态失败"); | 
 |  |  |                 } | 
 |  |  |                 orderDetl.setWorkQty(orderDetl.getWorkQty() + curOutQty); | 
 |  |  |                 orderDetl.setUpdateBy(userId); | 
 |  |  |                 orderDetl.setUpdateTime(now); | 
 |  |  | 
 |  |  |                 if (!Cools.isEmpty(orderDetl.getBatch())) { | 
 |  |  |                     wrapper.eq("batch", orderDetl.getBatch()); | 
 |  |  |                 } | 
 |  |  | //                if(!orderDetlService.update(orderDetl, wrapper)){ | 
 |  |  | //                    throw new CoolException("更新订单明细失败"); | 
 |  |  | //                } | 
 |  |  |                 OrderInAndOutUtil.updateOrderDetl(order.getPakinPakoutStatus$(), order, orderDetl); | 
 |  |  |                 if (!orderDetlPakoutService.update(orderDetl, wrapper)) { | 
 |  |  |                     throw new CoolException("更新订单明细失败"); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |             } | 
 |  |  |  | 
 |  |  | 
 |  |  |  | 
 |  |  |     @Override | 
 |  |  |     @Transactional | 
 |  |  |     public void stockOut(OrderDetl orderDetl, BasDevp staNo, LocDetl locDetl, | 
 |  |  |     public void stockOut(OrderDetlPakout orderDetl, BasDevp staNo, LocDetl locDetl, | 
 |  |  |                          Double curOutQty, Integer ioType, Long userId, Date now) { | 
 |  |  |         // 获取库位 | 
 |  |  |         LocMast locMast = locMastService.selectById(locDetl.getLocNo()); |