| | |
| | | import com.core.common.DateUtils; |
| | | import com.core.common.SnowflakeIdWorker; |
| | | import com.core.exception.CoolException; |
| | | import com.zy.asrs.entity.OrderDetl; |
| | | import com.zy.asrs.entity.WrkDetl; |
| | | import com.zy.asrs.entity.WrkMast; |
| | | import com.zy.asrs.entity.*; |
| | | import com.zy.asrs.entity.param.OpenOrderPakinParam; |
| | | import com.zy.asrs.entity.param.OpenOrderPakoutParam; |
| | | import com.zy.asrs.mapper.OrderDetlMapper; |
| | | import com.zy.asrs.mapper.OrderMapper; |
| | | import com.zy.asrs.entity.Order; |
| | | import com.zy.asrs.service.OpenService; |
| | | import com.zy.asrs.service.OrderService; |
| | | import com.zy.asrs.service.*; |
| | | import com.baomidou.mybatisplus.service.impl.ServiceImpl; |
| | | import com.zy.common.model.DetlDto; |
| | | import lombok.extern.slf4j.Slf4j; |
| | |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.List; |
| | | import java.util.Objects; |
| | | |
| | | @Slf4j |
| | | @Service("orderService") |
| | |
| | | private OpenService openService; |
| | | @Autowired |
| | | private SnowflakeIdWorker snowflakeIdWorker; |
| | | @Autowired |
| | | private OrderDetlService orderDetlService; |
| | | @Autowired |
| | | private DocTypeService docTypeService; |
| | | @Autowired |
| | | private WrkDetlService wrkDetlService; |
| | | |
| | | @Override |
| | | public Order selectByNo(String orderNo) { |
| | |
| | | @Override |
| | | public void checkComplete(String orderNo) { |
| | | Order order = this.selectByNo(orderNo); |
| | | if (order.getSettle() >= 4L) { |
| | | if (Cools.isEmpty(order) || order.getSettle() >= 4L) { |
| | | return; |
| | | } |
| | | List<OrderDetl> orderDetls = orderDetlMapper.selectList(new EntityWrapper<OrderDetl>().eq("order_id", order.getId())); |
| | |
| | | } |
| | | } |
| | | if (complete) { |
| | | for (OrderDetl orderDetl : orderDetls) { |
| | | //生成单据和入库通知档时,给batch为空的明细赋了一个 ="", 现在改为null,回传用 |
| | | if (orderDetl.getBatch().equals("")){ |
| | | orderDetl.setBatch(null); |
| | | orderDetlService.updateById(orderDetl); |
| | | } |
| | | } |
| | | if (!this.updateSettle(order.getId(), 4L, null)) { |
| | | throw new CoolException("修改订单【orderNo = " + order.getOrderNo() + "】状态为已完成失败"); |
| | | } |
| | |
| | | } |
| | | |
| | | @Override |
| | | public boolean saveHandlerOrder(WrkMast wrkMast, List<WrkDetl> wrkDetls) { |
| | | public boolean saveHandlerOrder(Boolean pakin, WrkMast wrkMast, List<WrkDetl> wrkDetls) { |
| | | try { |
| | | List<DetlDto> detlDtos = new ArrayList<>(); |
| | | wrkDetls.forEach(wrkDetl -> { |
| | | detlDtos.add(new DetlDto(wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getAnfme())); |
| | | }); |
| | | // 生成入库单据 |
| | | String orderNo = "HAND" + snowflakeIdWorker.nextId(); |
| | | OpenOrderPakinParam openParam = new OpenOrderPakinParam(); |
| | | openParam.setOrderNo(orderNo); |
| | | openParam.setOrderTime(DateUtils.convert(wrkMast.getModiTime())); |
| | | openParam.setOrderType("手动入库单"); |
| | | openParam.setOrderDetails(detlDtos); |
| | | openService.pakinOrderCreate(openParam); |
| | | if (pakin) { |
| | | // 生成入库单据 |
| | | OpenOrderPakinParam openParam = new OpenOrderPakinParam(); |
| | | openParam.setOrderNo(orderNo); |
| | | openParam.setOrderTime(DateUtils.convert(wrkMast.getModiTime())); |
| | | openParam.setOrderType("手动入库单"); |
| | | openParam.setOrderDetails(detlDtos); |
| | | openService.pakinOrderCreate(openParam); |
| | | } else { |
| | | // 生成出库单据 |
| | | OpenOrderPakoutParam openParam = new OpenOrderPakoutParam(); |
| | | openParam.setOrderNo(orderNo); |
| | | openParam.setOrderTime(DateUtils.convert(wrkMast.getModiTime())); |
| | | openParam.setOrderType("手动出库单"); |
| | | openParam.setOrderDetails(detlDtos); |
| | | openService.pakoutOrderCreate(openParam); |
| | | } |
| | | |
| | | Order order = this.selectByNo(orderNo); |
| | | if (null == order) { |
| | | throw new CoolException("生成单据失败"); |
| | |
| | | if (!this.updateSettle(order.getId(), 4L, null)) { |
| | | throw new CoolException("修改单据状态失败"); |
| | | } |
| | | for (DetlDto detlDto : detlDtos) { |
| | | // 修改订单明细数量 |
| | | if (!orderDetlService.increase(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getAnfme())) { |
| | | throw new CoolException("修改单据明细数量失败"); |
| | | } |
| | | // 修改订单作业数量 |
| | | if (!orderDetlService.increaseWorkQty(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getAnfme())) { |
| | | throw new CoolException("修改单据作业数量失败"); |
| | | } |
| | | } |
| | | } catch (Exception e) { |
| | | log.error("", e); |
| | | log.error("saveHandlerOrder===>>", e); |
| | | return false; |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | @Override |
| | | public void remove(Long orderId) { |
| | | if (!this.deleteById(orderId)) { |
| | | throw new CoolException("删除单据失败"); |
| | | } |
| | | orderDetlService.delete(new EntityWrapper<OrderDetl>().eq("order_id", orderId)); |
| | | } |
| | | |
| | | @Override |
| | | public List<Order> selectComplete() { |
| | | return this.baseMapper.selectComplete(); |
| | | } |
| | | |
| | | @Override |
| | | public boolean addToLogTable(Order order) { |
| | | return this.baseMapper.addToLogTable(order) > 0; |
| | | } |
| | | |
| | | /** |
| | | * |
| | | * @param orderNo |
| | | * |
| | | */ |
| | | @Override |
| | | public void BackToInit(String orderNo) { |
| | | Integer count = this.baseMapper.checkDetlWorkQtyLess0(orderNo); |
| | | //如果所有明细的工作数量和完成量都小于等于0, 那么将主档更新为“待处理”状态 |
| | | if (count == 0 ){ |
| | | this.baseMapper.updateSettleTo1(orderNo); |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public List<Order> selectInOrOutOrders(boolean inOrders) { |
| | | if (inOrders) { |
| | | return this.baseMapper.selectInOrOutOrders(1); |
| | | |
| | | }else { |
| | | return this.baseMapper.selectInOrOutOrders(0); |
| | | |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public void checkSettleUpdate(Long orderId) { |
| | | long settle = 1; |
| | | Integer count = 0; |
| | | List<OrderDetl> orderNo1 = orderDetlService.selectList(new EntityWrapper<OrderDetl>() |
| | | .eq("order_id", orderId)); |
| | | for (int i = 0; i < orderNo1.size(); i++) { |
| | | OrderDetl orderDetl = orderNo1.get(i); |
| | | if (orderDetl.getQty() > 0){ |
| | | settle = 2; |
| | | |
| | | } |
| | | if (Objects.equals(orderDetl.getAnfme(), orderDetl.getQty())){ |
| | | count++; |
| | | } |
| | | |
| | | } |
| | | if (count == orderNo1.size()){ |
| | | settle = 4; |
| | | } |
| | | updateSettle(orderId,settle,1L); |
| | | } |
| | | |
| | | @Override |
| | | public List<Order> selectToBeHistoryOrder(boolean isERP) { |
| | | int settle = isERP ? 6 : 4; |
| | | return this.baseMapper.selectToBeHistoryOrder(settle); |
| | | } |
| | | |
| | | } |