| package com.zy.asrs.service.impl; | 
|   | 
| import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
| import com.baomidou.mybatisplus.service.impl.ServiceImpl; | 
| import com.core.common.Cools; | 
| import com.core.common.DateUtils; | 
| import com.core.common.SnowflakeIdWorker; | 
| import com.core.exception.CoolException; | 
| import com.zy.asrs.entity.*; | 
| import com.zy.asrs.entity.param.OpenOrderPakinParam; | 
| import com.zy.asrs.entity.param.OpenOrderPakoutParam; | 
| import com.zy.asrs.mapper.OrderCheckMapper; | 
| import com.zy.asrs.mapper.OrderDetlMapper; | 
| import com.zy.asrs.mapper.OrderMapper; | 
| import com.zy.asrs.service.*; | 
| import com.zy.common.model.DetlDto; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.stereotype.Service; | 
|   | 
| import java.util.ArrayList; | 
| import java.util.List; | 
|   | 
| @Slf4j | 
| @Service("orderCheckService") | 
| public class OrderCheckServiceImpl extends ServiceImpl<OrderCheckMapper, OrderCheck> implements OrderCheckService { | 
|   | 
|     @Autowired | 
|     private OrderDetlMapper orderDetlMapper; | 
|     @Autowired | 
|     private OpenService openService; | 
|     @Autowired | 
|     private SnowflakeIdWorker snowflakeIdWorker; | 
|     @Autowired | 
|     private OrderDetlService orderDetlService; | 
|     @Autowired | 
|     private DocTypeService docTypeService; | 
|     @Autowired | 
|     private WrkDetlService wrkDetlService; | 
|   | 
|     @Autowired | 
|     private LocCheckService locCheckService; | 
|   | 
|     @Override | 
|     public OrderCheck selectByNo(String orderNo) { | 
|         List<OrderCheck> orderList = this.selectList(new EntityWrapper<OrderCheck>().eq("order_no", orderNo)); | 
|         if (Cools.isEmpty(orderList)) { | 
|             return null; | 
|         } | 
|         return orderList.get(0); | 
|     } | 
|   | 
|     @Override | 
|     public List<OrderDetl> selectWorkingDetls(Long orderId) { | 
|         return orderDetlMapper.selectWorkingDetls(orderId); | 
|     } | 
|   | 
|     @Override | 
|     public boolean updateSettle(Long orderId, Long settle, Long userId) { | 
|         return this.baseMapper.updateSettle(orderId, settle, userId) > 0; | 
|     } | 
|   | 
|     @Override | 
|     public void checkComplete(String orderNo) { | 
|         OrderCheck order = this.selectByNo(orderNo); | 
|         if (Cools.isEmpty(order) || order.getSettle() >= 4L) { | 
|             return; | 
|         } | 
|         List<OrderDetl> orderDetls = orderDetlMapper.selectList(new EntityWrapper<OrderDetl>().eq("order_id", order.getId())); | 
|         boolean complete = true; | 
|         for (OrderDetl orderDetl : orderDetls) { | 
|             if (orderDetl.getAnfme() > orderDetl.getQty()) { | 
|                 complete = false; | 
|                 break; | 
|             } | 
|         } | 
|         if (complete) { | 
|             for (OrderDetl orderDetl : orderDetls) { | 
|                 if (Cools.isEmpty(orderDetl.getBatch())){ | 
|                     orderDetlService.updateById(orderDetl); | 
|                 }else if (orderDetl.getBatch().equals("")){//生成单据和入库通知档时,给batch为空的明细赋了一个 ="", 现在改为null,回传用 | 
|                     orderDetl.setBatch(null); | 
|                     orderDetlService.updateById(orderDetl); | 
|                 } | 
|             } | 
|             if (!this.updateSettle(order.getId(), 4L, null)) { | 
|                 throw new CoolException("修改订单【orderNo = " + order.getOrderNo() + "】状态为已完成失败"); | 
|             } | 
|         } | 
|   | 
|     } | 
|   | 
|     @Override | 
|     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(); | 
|             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); | 
|             } | 
|   | 
|             OrderCheck 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("saveHandlerOrder===>>", e); | 
|             return false; | 
|         } | 
|         return true; | 
|     } | 
|   | 
|   | 
|   | 
|     @Override | 
|     public List<OrderCheck> selectComplete() { | 
|         return this.baseMapper.selectComplete(); | 
|     } | 
|   | 
|     @Override | 
|     public boolean addToLogTable(OrderCheck 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<OrderCheck> selectToBeHistoryOrder() { | 
|         return this.baseMapper.selectToBeHistoryOrder(); | 
|     } | 
|   | 
|     @Override | 
|     public void remove(String orderNo) { | 
|         if (!this.delete(new EntityWrapper<OrderCheck>().eq("order_no",orderNo))) { | 
|             throw new CoolException("删除单据失败"); | 
|         } | 
|         locCheckService.delete(new EntityWrapper<LocCheck>().eq("order_no", orderNo)); | 
|     } | 
|   | 
| } |