| | |
| | | import com.core.common.SnowflakeIdWorker; |
| | | import com.core.exception.CoolException; |
| | | import com.zy.asrs.entity.*; |
| | | import com.zy.asrs.entity.param.CheckBom; |
| | | import com.zy.asrs.entity.param.CombParam; |
| | | import com.zy.asrs.entity.param.MobileAdjustParam; |
| | | import com.zy.asrs.entity.param.OffSaleParam; |
| | | import com.zy.asrs.entity.param.*; |
| | | import com.zy.asrs.mapper.ManLocDetlMapper; |
| | | import com.zy.asrs.service.*; |
| | | import com.zy.common.model.DetlDto; |
| | | import com.zy.common.model.LocDetlDto; |
| | | import com.zy.common.model.enums.IoWorkType; |
| | | import com.zy.common.service.CommonService; |
| | | import com.zy.common.utils.Synchro; |
| | | import lombok.extern.slf4j.Slf4j; |
| | |
| | | private MatV2Service matV2Service; |
| | | @Autowired |
| | | private BomMatService bomMatService; |
| | | @Autowired |
| | | private WorkService workService; |
| | | |
| | | @Override |
| | | @Transactional |
| | |
| | | |
| | | } |
| | | |
| | | |
| | | @Override |
| | | @Transactional |
| | | public void comb3(CombParam param, Long userId) { |
| | | |
| | | if (Cools.isEmpty(param.getBarcode(), param.getCombMats())) { |
| | | throw new CoolException(BaseRes.PARAM); |
| | | } |
| | | if(param.getCombMats().stream().anyMatch(obj -> obj.getAnfme() == null)){ |
| | | throw new CoolException("入库物料数量不能为空"); |
| | | } |
| | | // 判断是否有相同条码的数据 |
| | | if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>(). |
| | | eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) { |
| | | throw new CoolException(param.getBarcode() + "数据正在进行入库"); |
| | | } |
| | | |
| | | int countLoc = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet",param.getBarcode())); |
| | | WrkMast wrkMast = wrkMastService.selectByBarcode(param.getBarcode()); |
| | | if (wrkMast != null && wrkMast.getIoType() < 100){ |
| | | throw new CoolException("工作档/库存条码数据已存在===>>" + param.getBarcode()); |
| | | |
| | | } |
| | | if (countLoc > 0 ) { |
| | | throw new CoolException("工作档/库存条码数据已存在===>>" + param.getBarcode()); |
| | | } |
| | | |
| | | |
| | | //设置非null批号, |
| | | for (CombParam.CombMat combMat : param.getCombMats()) { |
| | | if (combMat.getBatch() == null){ |
| | | combMat.setBatch(""); |
| | | } |
| | | } |
| | | |
| | | |
| | | |
| | | |
| | | Date now = new Date(); |
| | | |
| | | // 无单组托 |
| | | if (Cools.isEmpty(param.getCombMats().get(0).getOrderNo())) { |
| | | |
| | | // 生成入库通知档 |
| | | List<DetlDto> detlDtos = new ArrayList<>(); |
| | | param.getCombMats().forEach(elem -> { |
| | | DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme()); |
| | | if (DetlDto.has(detlDtos, detlDto)) { |
| | | DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch()); |
| | | assert one != null; |
| | | one.setAnfme(one.getAnfme() + detlDto.getAnfme()); |
| | | } else { |
| | | detlDtos.add(detlDto); |
| | | } |
| | | }); |
| | | |
| | | |
| | | for (DetlDto detlDto : detlDtos) { |
| | | Mat mat = matService.selectByMatnr(detlDto.getMatnr()); |
| | | WaitPakin waitPakin = new WaitPakin(); |
| | | if (Cools.isEmpty(mat)) { |
| | | MatV2 matV2 = matV2Service.selectOne(new EntityWrapper<MatV2>().eq("matnr", detlDto.getMatnr())); |
| | | if(Cools.isEmpty(matV2)){ |
| | | throw new CoolException(detlDto.getMatnr() + "商品档案不存在"); |
| | | } |
| | | waitPakin.sync(matV2); |
| | | waitPakin.setBrand("组件"); |
| | | } else { |
| | | waitPakin.sync(mat); |
| | | } |
| | | // 校验是否为bom入库 bom入库的数量不能超过库存原有数量 |
| | | if (!Cools.isEmpty(param.getBomCode())) { |
| | | BomMat bomMat = bomMatService.selectOne(new EntityWrapper<BomMat>().eq("bom_num", param.getBomCode()).eq("element_num", detlDto.getMatnr())); |
| | | Double bomQyt = locDetlService.getBomQyt(param.getBomCode(), detlDto.getMatnr()); |
| | | if (!Cools.isEmpty(bomQyt)) { |
| | | bomMat.setZpalletAnfme(bomMat.getZpalletAnfme() - bomQyt); |
| | | } |
| | | Double bomQty = wrkDetlService.getBomQty(param.getBomCode(), detlDto.getMatnr()); |
| | | if (!Cools.isEmpty(bomQty)) { |
| | | bomMat.setZpalletAnfme(bomMat.getZpalletAnfme() - bomQty); |
| | | } |
| | | if (bomMat.getZpalletAnfme() == 0.0D) { |
| | | throw new CoolException(detlDto.getMatnr() + "当前物料已入最大数量"); |
| | | } else { |
| | | if (bomMat.getZpalletAnfme() < detlDto.getAnfme()) { |
| | | throw new CoolException(detlDto.getMatnr() + "当前物料最多可入" + bomMat.getZpalletAnfme() + "件"); |
| | | } |
| | | } |
| | | } |
| | | waitPakin.setBatch(detlDto.getBatch()); |
| | | waitPakin.setZpallet(param.getBarcode()); // 托盘码 |
| | | waitPakin.setIoStatus("N"); // 入出状态 |
| | | waitPakin.setAnfme(detlDto.getAnfme()); // 数量 |
| | | waitPakin.setStatus("Y"); // 状态 |
| | | waitPakin.setAppeUser(userId); |
| | | waitPakin.setBomCode(param.getBomCode()); |
| | | waitPakin.setAppeTime(now); |
| | | waitPakin.setModiUser(userId); |
| | | waitPakin.setModiTime(now); |
| | | if (!waitPakinService.insert(waitPakin)) { |
| | | throw new CoolException("保存入库通知档失败"); |
| | | } |
| | | } |
| | | // 关联组托 |
| | | } else { |
| | | for (CombParam.CombMat combMat : param.getCombMats()) { |
| | | // 生成入库通知档 |
| | | Order order = orderService.selectByNo(combMat.getOrderNo()); |
| | | |
| | | //判断订单类型是否是入库 |
| | | DocType docType=docTypeService.selectById(order.getDocType()); |
| | | if(docType.getPakin()!=1 || docType.getStatus()!=1){ |
| | | throw new CoolException("订单为出库订单,不能组托!"); |
| | | } |
| | | |
| | | if (order.getSettle() > 2) { |
| | | throw new CoolException("单据编号已过期"); |
| | | } |
| | | OrderDetl orderDetl = orderDetlService.selectItem(combMat.getOrderNo(), combMat.getMatnr(), combMat.getBatch(), combMat.getBomCode(), combMat.getThreeCode()); |
| | | if (orderDetl == null) { |
| | | throw new CoolException("找不到组托的单据明细"); |
| | | } |
| | | //订单数-工作中的数量-组托数量 |
| | | if ( orderDetl.getAnfme() - orderDetl.getWorkQty() - combMat.getAnfme()<0) { |
| | | throw new CoolException("组托数量已超出订单需求量,请检查是否有其他的组托已完成"); |
| | | } |
| | | // 修改订单作业数量 |
| | | if (!orderDetlService.increaseWorkQty(order.getId(), combMat.getMatnr(), combMat.getBatch(), combMat.getBomCode(),combMat.getThreeCode(), combMat.getAnfme())) { |
| | | throw new CoolException("修改单据作业数量失败"); |
| | | } |
| | | Mat mat = matService.selectByMatnr(combMat.getMatnr()); |
| | | if (Cools.isEmpty(mat)) { |
| | | throw new CoolException(combMat.getMatnr() + "商品档案不存在"); |
| | | } |
| | | WaitPakin waitPakin = new WaitPakin(); |
| | | waitPakin.sync(mat); |
| | | waitPakin.setOrderNo(order.getOrderNo()); // 单据编号 |
| | | waitPakin.setBomCode(combMat.getBomCode()); |
| | | waitPakin.setThreeCode(combMat.getThreeCode()); |
| | | waitPakin.setBatch(combMat.getBatch()); |
| | | waitPakin.setIsFull(param.getIsFull().equals("1") ? "Y" : "N"); // 序列码 |
| | | waitPakin.setZpallet(param.getBarcode()); // 托盘码 |
| | | waitPakin.setIoStatus("N"); // 入出状态 |
| | | waitPakin.setAnfme(combMat.getAnfme()); // 数量 |
| | | waitPakin.setStatus("Y"); // 状态 |
| | | waitPakin.setAppeUser(userId); |
| | | waitPakin.setAppeTime(now); |
| | | waitPakin.setModiUser(userId); |
| | | waitPakin.setModiTime(now); |
| | | if (!waitPakinService.insert(waitPakin)) { |
| | | throw new CoolException("保存入库通知档失败"); |
| | | } |
| | | |
| | | // DetlDto detlDto = new DetlDto(combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme()); |
| | | // if (DetlDto.has(detlDtos, detlDto)) { |
| | | // DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch()); |
| | | // assert one != null; |
| | | // one.setAnfme(one.getAnfme() + detlDto.getAnfme()); |
| | | // } else { |
| | | // } |
| | | orderService.updateSettle(order.getId(), 2L, userId); |
| | | } |
| | | |
| | | } |
| | | |
| | | } |
| | | |
| | | |
| | | @Override |
| | | @Transactional |
| | | public List<LocMast> checkFullplt(CombParam.CombMat param, Long userId) { |
| | | // 查询包含待组托物料在库存中是否存在 |
| | | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>() |
| | | .eq("three_code", param.getThreeCode()) |
| | | .eq("bom_code", param.getBomCode())); |
| | | if (Cools.isEmpty(locDetls)) { |
| | | throw new CoolException("库存中没有存在当前物料所使用的销售单号"); |
| | | } |
| | | ArrayList<LocMast> locMasts = new ArrayList<>(); |
| | | |
| | | locDetls.forEach(locDetl -> { |
| | | LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", locDetl.getLocNo())); |
| | | if (!Cools.isEmpty(locMast)) { |
| | | if (!locMasts.contains(locMast)) { |
| | | locMasts.add(locMast); |
| | | } |
| | | } |
| | | }); |
| | | return locMasts; |
| | | } |
| | | |
| | | |
| | | |
| | | @Override |
| | | @Transactional |
| | | public void mergeComb(CombParam param, Long userId) { |
| | |
| | | Date now = new Date(); |
| | | for (CombParam.CombMat combMat : param.getCombMats()) { |
| | | Mat mat = matService.selectByMatnr(combMat.getMatnr()); |
| | | |
| | | |
| | | LocDetl locDetl = new LocDetl(); |
| | | locDetl.sync(mat); |
| | | locDetl.setLocNo(wrkMast.getSourceLocNo()); |
| | |
| | | |
| | | |
| | | |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public void mergeComb2(CombParam param, Long userId) { |
| | | if (Cools.isEmpty(param.getBarcode(), param.getCombMats())) { |
| | | throw new CoolException(BaseRes.PARAM); |
| | | } |
| | | if(param.getCombMats().stream().anyMatch(obj -> obj.getAnfme() == null)){ |
| | | throw new CoolException("入库物料数量不能为空"); |
| | | } |
| | | // 判断是否有相同条码的数据 |
| | | if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>(). |
| | | eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) { |
| | | throw new CoolException(param.getBarcode() + "数据正在进行入库"); |
| | | } |
| | | |
| | | int countLoc = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet",param.getBarcode())); |
| | | WrkMast wrkMast = wrkMastService.selectByBarcode(param.getBarcode()); |
| | | if (wrkMast.getWrkSts() != 14L) { |
| | | throw new CoolException("当前托盘出库未完成!"); |
| | | } |
| | | LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("barcode", param.getBarcode())); |
| | | if (locMast.getFullPlt().equals("Y")) { |
| | | throw new CoolException("当前托盘已满!"); |
| | | } |
| | | |
| | | //设置非null批号, |
| | | for (CombParam.CombMat combMat : param.getCombMats()) { |
| | | if (combMat.getBatch() == null){ |
| | | combMat.setBatch(""); |
| | | } |
| | | } |
| | | if (param.getIsFull().equals("1")) { |
| | | wrkMast.setFullPlt("Y"); |
| | | wrkMastService.updateById(wrkMast); |
| | | locMast.setFullPlt("Y"); |
| | | locMastService.updateById(locMast); |
| | | } |
| | | |
| | | |
| | | Date now = new Date(); |
| | | for (CombParam.CombMat combMat : param.getCombMats()) { |
| | | Mat mat = matService.selectByMatnr(combMat.getMatnr()); |
| | | WrkDetl wrkDetl = new WrkDetl(); |
| | | wrkDetl.sync(mat); |
| | | wrkDetl.setWrkNo(wrkMast.getWrkNo()); |
| | | wrkDetl.setZpallet(param.getBarcode()); |
| | | wrkDetl.setOrderNo(combMat.getOrderNo()); |
| | | wrkDetl.setBatch(combMat.getBatch()); |
| | | wrkDetl.setBomCode(combMat.getBomCode()); |
| | | wrkDetl.setThreeCode(combMat.getThreeCode()); |
| | | wrkDetl.setAnfme(combMat.getAnfme()); |
| | | wrkDetl.setAppeTime(now); |
| | | wrkDetl.setAppeUser(userId); |
| | | wrkDetl.setModiTime(now); |
| | | wrkDetl.setModiUser(userId); |
| | | wrkDetl.setMemo("并板"); |
| | | wrkDetlService.insert(wrkDetl); |
| | | // 同步订单 |
| | | OrderDetl orderDetl = orderDetlService.selectItem(combMat.getOrderNo(), combMat.getMatnr(), combMat.getBatch(), combMat.getBomCode(), combMat.getThreeCode()); |
| | | orderDetl.setQty(orderDetl.getWorkQty() + combMat.getAnfme()); |
| | | orderDetlService.update(orderDetl,new EntityWrapper<OrderDetl>() |
| | | .eq("order_no", combMat.getOrderNo()) |
| | | .eq("matnr", combMat.getMatnr()) |
| | | .eq("batch", combMat.getBatch()) |
| | | .eq("bom_code", combMat.getBomCode()) |
| | | .eq("three_code", combMat.getThreeCode())); |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public void mergeOut(String locNo,String staNo, Long userId) { |
| | | LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", locNo)); |
| | | if (!locMast.getLocSts().equals("F")) { |
| | | throw new CoolException("当前库位状态不是在库状态不能出库"); |
| | | } |
| | | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", locNo)); |
| | | // 获取库位明细 |
| | | List<LocDetlDto> locDetlDtos = new ArrayList<>(); |
| | | for (LocDetl locDetl : locDetls) { |
| | | locDetlDtos.add(new LocDetlDto(locDetl, locDetl.getAnfme())); |
| | | |
| | | } |
| | | BasDevp basDevp = basDevpService.selectById(staNo); |
| | | workService.stockOut(basDevp, locDetlDtos, IoWorkType.MERGE_OUT, userId); |
| | | } |
| | | |
| | | @Override |
| | |
| | | return R.ok("下架完成"); |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public void adjustNew(MobileAdjustParam param, Boolean re, Long userId) { |
| | | Date now = new Date(); |
| | | WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>().eq("barcode", param.getBarcode())); |
| | | if (Cools.isEmpty(wrkMast)){ |
| | | throw new CoolException("托盘码:"+param.getBarcode()+" 无有效工作档"); |
| | | }else if (wrkMast.getIoType()!=103){ |
| | | throw new CoolException("托盘码:"+param.getBarcode()+" 所属工作档非拣料任务"); |
| | | }else if (wrkMast.getWrkSts()!=14.0){ |
| | | throw new CoolException("托盘码:"+param.getBarcode()+" 所属工作档工作状态不是出库完成"); |
| | | } |
| | | // List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("zpallet", param.getBarcode())); |
| | | |
| | | List<WrkDetl> wrkDetls = param.getWrkDetls(); |
| | | for (WrkDetl wrkDetl : wrkDetls) { |
| | | wrkDetl.setWrkNo(wrkMast.getWrkNo()); |
| | | wrkDetl.setZpallet(param.getBarcode()); |
| | | wrkDetl.setMatnr("B"+wrkDetl.getMatnr()); |
| | | wrkDetl.setAnfme(-wrkDetl.getAnfme()); |
| | | wrkDetl.setAppeTime(now); |
| | | wrkDetl.setAppeUser(userId); |
| | | wrkDetl.setModiTime(now); |
| | | wrkDetl.setModiUser(userId); |
| | | wrkDetlService.insert(wrkDetl); |
| | | } |
| | | |
| | | } |
| | | |
| | | } |