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.R; import com.core.common.SnowflakeIdWorker; import com.core.exception.CoolException; import com.zy.asrs.entity.*; import com.zy.asrs.entity.param.ExamineParam; 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.Date; import java.util.List; @Slf4j @Service("orderCheckService") public class OrderCheckServiceImpl extends ServiceImpl 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; @Autowired private ManLocDetlService manLocDetlService; @Autowired private NodeService nodeService; @Autowired private OrderCheckService orderCheckService; @Override public OrderCheck selectByNo(String orderNo) { List orderList = this.selectList(new EntityWrapper().eq("order_no", orderNo)); if (Cools.isEmpty(orderList)) { return null; } return orderList.get(0); } @Override public List 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 orderDetls = orderDetlMapper.selectList(new EntityWrapper().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 wrkDetls) { try { List 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 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 selectToBeHistoryOrder() { return this.baseMapper.selectToBeHistoryOrder(); } @Override public void remove(String orderNo) { if (!this.delete(new EntityWrapper().eq("order_no",orderNo))) { throw new CoolException("删除单据失败"); } locCheckService.delete(new EntityWrapper().eq("order_no", orderNo)); } @Override public R examine(ExamineParam param) { for (ExamineParam.data list:param.getList()){ EntityWrapper wrapper = new EntityWrapper<>(); wrapper.eq("matnr", list.getMatnr()) .eq("loc_no", list.getLocNo()) .eq("batch", list.getBatch()); ManLocDetl manLocDetl = manLocDetlService.selectOne(wrapper); if (manLocDetl == null){ Date now = new Date(); Node node = nodeService.selectOne(new EntityWrapper().eq("name", list.getLocNo())); ManLocDetl manLocDetl1 = new ManLocDetl(); manLocDetl1.setLocNo(list.getLocNo()); manLocDetl1.setNodeId(node.getId()); manLocDetl1.setAnfme(list.getRealAnfme()); manLocDetl1.setMatnr(list.getMatnr()); manLocDetl1.setMaktx(list.getMaktx()); manLocDetl1.setStatus(1); manLocDetl1.setCreateTime(now); manLocDetl1.setModiTime(now); manLocDetl1.setOrderNo(list.getOrderNo()); manLocDetl1.setStockFreeze(1); manLocDetl1.setBatch(list.getBatch()); if (!manLocDetlService.insert(manLocDetl1)){ return R.error("插入数据失败"); } }else { if (list.getRealAnfme() == 0){ if (!manLocDetlService.delete(wrapper)){ return R.error("删除数据失败!"); } }else { manLocDetl.setAnfme(list.getRealAnfme()); if (!manLocDetlService.update(manLocDetl,wrapper)){ return R.error("更新库存数量失败!"); } } } EntityWrapper wrapper2 = new EntityWrapper<>(); wrapper2.eq("order_no", list.getOrderNo()) .eq("matnr", list.getMatnr()) .eq("loc_no", list.getLocNo()); LocCheck checkDetl = locCheckService.selectOne(wrapper2); checkDetl.setType(2); if (!locCheckService.update(checkDetl,wrapper2)){ return R.error("更新盘点明细失败!"); } } OrderCheck orderCheck = orderCheckService.selectOne(new EntityWrapper().eq("order_no", param.getOrderNo())); orderCheck.setSettle(4L); if (!orderCheckService.update(orderCheck,new EntityWrapper().eq("order_no", param.getOrderNo()))){ return R.error("更新盘点单状态失败!"); } return R.ok(); } }