|  |  |  | 
|---|
|  |  |  | package com.zy.asrs.service.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSON; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.mapper.Wrapper; | 
|---|
|  |  |  | import com.core.common.BaseRes; | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | import com.core.common.DateUtils; | 
|---|
|  |  |  | import com.core.common.SnowflakeIdWorker; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.zy.asrs.entity.param.LocDetlAdjustParam; | 
|---|
|  |  |  | import com.zy.asrs.entity.param.StockOutParam; | 
|---|
|  |  |  | import com.zy.asrs.service.*; | 
|---|
|  |  |  | import com.zy.asrs.utils.VersionUtils; | 
|---|
|  |  |  | import com.zy.asrs.utils.Utils; | 
|---|
|  |  |  | import com.zy.common.model.*; | 
|---|
|  |  |  | import com.zy.common.model.enums.IoWorkType; | 
|---|
|  |  |  | import com.zy.common.model.enums.WorkNoType; | 
|---|
|  |  |  | import com.zy.common.properties.SlaveProperties; | 
|---|
|  |  |  | import com.zy.common.service.CommonService; | 
|---|
|  |  |  | import com.zy.common.service.wms.Result; | 
|---|
|  |  |  | import com.zy.common.service.wms.WmsService; | 
|---|
|  |  |  | import com.zy.common.web.WcsController; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.jdbc.core.JdbcTemplate; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | private static final int DEFAULT_ROW_NO_TYPE = 1; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private MatService matService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkMastService wrkMastService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkDetlService wrkDetlService; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private LocDetlService locDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private MatCodeService matCodeService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private AdjDetlService adjDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkMastLogService wrkMastLogService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkDetlLogService wrkDetlLogService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WmsService wmsService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SnowflakeIdWorker snowflakeIdWorker; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderService orderService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderDetlService orderDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WcsController wcsController; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private RowLastnoService rowLastnoService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SlaveProperties slaveProperties; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WaitPakinService waitPakinService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public String startupFullPutStore(FullStoreParam param, Long userId) { | 
|---|
|  |  |  | // 参数非空判断 | 
|---|
|  |  |  | if (Cools.isEmpty(param.getDevpNo(), param.getList())) { | 
|---|
|  |  |  | throw new CoolException(BaseRes.PARAM); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 源站点状态检测 | 
|---|
|  |  |  | BasDevp sourceStaNo = basDevpService.checkSiteStatus(param.getDevpNo(), true); | 
|---|
|  |  |  | // 检索库位 | 
|---|
|  |  |  | LocTypeDto locTypeDto = new LocTypeDto(sourceStaNo); | 
|---|
|  |  |  | log.info(JSON.toJSONString(locTypeDto)); | 
|---|
|  |  |  | log.info("{}入库口尺寸检测:{}", param.getDevpNo(), locTypeDto.getLocType1()==1?"低规格库位":"高规格库位"); | 
|---|
|  |  |  | List<String> matNos = param.getList().stream().map(FullStoreParam.MatCodeStore::getMatNo).distinct().collect(Collectors.toList()); | 
|---|
|  |  |  | StartupDto dto = commonService.getLocNo(DEFAULT_ROW_NO_TYPE, 1, param.getDevpNo(), matNos, locTypeDto, 0); | 
|---|
|  |  |  | // 生成工作号 | 
|---|
|  |  |  | int workNo = dto.getWorkNo(); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(new Date()); | 
|---|
|  |  |  | wrkMast.setWrkSts(1L); // 工作状态:生成入库ID | 
|---|
|  |  |  | wrkMast.setIoType(1); // 入出库状态:1.入库 | 
|---|
|  |  |  | wrkMast.setIoPri(13D); // 优先级:10 | 
|---|
|  |  |  | wrkMast.setCrnNo(dto.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setSourceStaNo(dto.getSourceStaNo()); | 
|---|
|  |  |  | wrkMast.setStaNo(dto.getStaNo()); | 
|---|
|  |  |  | wrkMast.setLocNo(dto.getLocNo()); | 
|---|
|  |  |  | wrkMast.setBarcode(param.getBarcode()); // 托盘码 | 
|---|
|  |  |  | wrkMast.setFullPlt("Y"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("N"); // 空板 | 
|---|
|  |  |  | wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | wrkMast.setCtnType(sourceStaNo.getCtnType()); // 容器类型 | 
|---|
|  |  |  | // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeUser(userId); | 
|---|
|  |  |  | wrkMast.setAppeTime(new Date()); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | boolean res = wrkMastService.insert(wrkMast); | 
|---|
|  |  |  | if (!res) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 生成工作档明细 | 
|---|
|  |  |  | List<DetlDto> detlDtos = new ArrayList<>(); | 
|---|
|  |  |  | param.getList().forEach(elem -> { | 
|---|
|  |  |  | detlDtos.add(new DetlDto(elem.getMatNo(), elem.getCount())); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | wrkDetlService.createWorkDetail(workNo, detlDtos, param.getBarcode(), userId); | 
|---|
|  |  |  | // 更新源站点信息 | 
|---|
|  |  |  | sourceStaNo.setWrkNo(workNo); | 
|---|
|  |  |  | sourceStaNo.setModiUser(userId); | 
|---|
|  |  |  | sourceStaNo.setModiTime(new Date()); | 
|---|
|  |  |  | if (!basDevpService.updateById(sourceStaNo)){ | 
|---|
|  |  |  | throw new CoolException("更新源站失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 更新目标库位状态 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(dto.getLocNo()); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("O")){ | 
|---|
|  |  |  | locMast.setLocSts("S"); // S.入库预约 | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)){ | 
|---|
|  |  |  | throw new CoolException("改变库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(dto.getLocNo()+"目标库位已被占用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return dto.getLocNo(); | 
|---|
|  |  |  | //        if (Cools.isEmpty(param.getDevpNo(), param.getList())) { | 
|---|
|  |  |  | //            throw new CoolException(BaseRes.PARAM); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        Date now = new Date(); | 
|---|
|  |  |  | //        // 源站点状态检测 | 
|---|
|  |  |  | //        BasDevp sourceStaNo = basDevpService.checkSiteStatus(param.getDevpNo(), true); | 
|---|
|  |  |  | //        // 检索库位 | 
|---|
|  |  |  | //        LocTypeDto locTypeDto = new LocTypeDto(sourceStaNo); | 
|---|
|  |  |  | //        List<String> matnrs = param.getList().stream().map(FullStoreParam.MatCodeStore::getMatnr).distinct().collect(Collectors.toList()); | 
|---|
|  |  |  | //        List<String> batchs = param.getList().stream().map(FullStoreParam.MatCodeStore::getBatch).distinct().collect(Collectors.toList()); | 
|---|
|  |  |  | //        StartupDto dto = commonService.getLocNo(DEFAULT_ROW_NO_TYPE, 1, param.getDevpNo(), matnrs.get(0), batchs.get(0), null, locTypeDto); | 
|---|
|  |  |  | //        // 生成工作号 | 
|---|
|  |  |  | //        int workNo = dto.getWorkNo(); | 
|---|
|  |  |  | //        // 生成工作档 | 
|---|
|  |  |  | //        WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | //        wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | //        wrkMast.setIoTime(now); | 
|---|
|  |  |  | //        wrkMast.setWrkSts(1L); // 工作状态:生成入库ID | 
|---|
|  |  |  | //        wrkMast.setIoType(1); // 入出库状态:1.入库 | 
|---|
|  |  |  | //        wrkMast.setIoPri(13D); // 优先级:13 | 
|---|
|  |  |  | //        wrkMast.setCrnNo(dto.getCrnNo()); | 
|---|
|  |  |  | //        wrkMast.setSourceStaNo(dto.getSourceStaNo()); | 
|---|
|  |  |  | //        wrkMast.setStaNo(dto.getStaNo()); | 
|---|
|  |  |  | //        wrkMast.setLocNo(dto.getLocNo()); | 
|---|
|  |  |  | //        wrkMast.setBarcode(param.getBarcode()); // 托盘码 | 
|---|
|  |  |  | //        wrkMast.setFullPlt("Y"); // 满板:Y | 
|---|
|  |  |  | //        wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | //        wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | //        wrkMast.setEmptyMk("N"); // 空板 | 
|---|
|  |  |  | //        wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | //        wrkMast.setCtnType(sourceStaNo.getCtnType()); // 容器类型 | 
|---|
|  |  |  | //        wrkMast.setAppeUser(userId); | 
|---|
|  |  |  | //        wrkMast.setAppeTime(now); | 
|---|
|  |  |  | //        wrkMast.setModiUser(userId); | 
|---|
|  |  |  | //        wrkMast.setModiTime(now); | 
|---|
|  |  |  | //        if (!wrkMastService.insert(wrkMast)) { | 
|---|
|  |  |  | //            throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        // 生成工作档明细 | 
|---|
|  |  |  | //        List<DetlDto> detlDtos = new ArrayList<>(); | 
|---|
|  |  |  | //        param.getList().forEach(elem -> { | 
|---|
|  |  |  | //            DetlDto detlDto = new DetlDto(elem); | 
|---|
|  |  |  | //            if (DetlDto.has(detlDtos, detlDto)) { | 
|---|
|  |  |  | //                DetlDto detlDto1 = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch()); | 
|---|
|  |  |  | //                assert detlDto1 != null; | 
|---|
|  |  |  | //                detlDto1.setAnfme(detlDto1.getAnfme() + detlDto.getAnfme()); | 
|---|
|  |  |  | //            } else { | 
|---|
|  |  |  | //                detlDtos.add(detlDto); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        }); | 
|---|
|  |  |  | //        wrkDetlService.createWorkDetail(workNo, detlDtos, param.getBarcode(), userId, now); | 
|---|
|  |  |  | //        // 更新源站点信息 | 
|---|
|  |  |  | //        sourceStaNo.setWrkNo(workNo); | 
|---|
|  |  |  | //        sourceStaNo.setModiUser(userId); | 
|---|
|  |  |  | //        sourceStaNo.setModiTime(now); | 
|---|
|  |  |  | //        if (!basDevpService.updateById(sourceStaNo)) { | 
|---|
|  |  |  | //            throw new CoolException("更新源站失败"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        // 更新目标库位状态 | 
|---|
|  |  |  | //        LocMast locMast = locMastService.selectById(dto.getLocNo()); | 
|---|
|  |  |  | //        if (locMast.getLocSts().equals("O")) { | 
|---|
|  |  |  | //            locMast.setLocSts("S"); // S.入库预约 | 
|---|
|  |  |  | //            locMast.setModiUser(userId); | 
|---|
|  |  |  | //            locMast.setModiTime(now); | 
|---|
|  |  |  | //            if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | //                throw new CoolException("改变库位状态失败"); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } else { | 
|---|
|  |  |  | //            throw new CoolException(dto.getLocNo() + "目标库位已被占用"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        return dto.getLocNo(); | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | List<LocDetlDto> locDetlDtos = new ArrayList<>(); | 
|---|
|  |  |  | for (StockOutParam.LocDetl paramLocDetl : param.getLocDetls()) { | 
|---|
|  |  |  | if (!Cools.isEmpty(paramLocDetl.getLocNo(), paramLocDetl.getMatnr(), paramLocDetl.getCount())) { | 
|---|
|  |  |  | LocDetl sqlParam = new LocDetl(); | 
|---|
|  |  |  | sqlParam.setLocNo(paramLocDetl.getLocNo()); | 
|---|
|  |  |  | sqlParam.setMatnr(paramLocDetl.getMatnr()); | 
|---|
|  |  |  | LocDetl one = locDetlService.selectOne(new EntityWrapper<>(sqlParam)); | 
|---|
|  |  |  | LocDetl one = locDetlService.selectItem(paramLocDetl.getLocNo(), paramLocDetl); | 
|---|
|  |  |  | if (null != one) locDetlDtos.add(new LocDetlDto(one, paramLocDetl.getCount())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!locDetlDtos.isEmpty()) { | 
|---|
|  |  |  | // 启动出库开始 101.出库 | 
|---|
|  |  |  | stockOut(staNo, locDetlDtos, null, userId); | 
|---|
|  |  |  | LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", locDetlDtos.get(0).getLocDetl().getLocNo())); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F") || locMast.getLocSts().equals("D")) { | 
|---|
|  |  |  | // 启动出库开始 101.出库 | 
|---|
|  |  |  | stockOut(staNo, locDetlDtos, null, userId); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("所选库位存在状态不为F、D的库位,库位号:" + locMast.getLocNo() + " 、当前状态:" + locMast.getLocSts() + "-" + locMast.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("库位物料不存在"); | 
|---|
|  |  |  | throw new CoolException("库存不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void stockOut(BasDevp staNo, List<LocDetlDto> locDetlDtos, Integer ioType, Long userId) { | 
|---|
|  |  |  | public void stockOut(BasDevp staNo, List<LocDetlDto> locDetlDtos, IoWorkType ioWorkType, Long userId) { | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 合并同类项 | 
|---|
|  |  |  | Set<String> locNos = new HashSet<>(); | 
|---|
|  |  |  | locDetlDtos.forEach(dto -> locNos.add(dto.getLocDetl().getLocNo())); | 
|---|
|  |  |  | List<OutLocDto> dtos = new ArrayList<>(); | 
|---|
|  |  |  | for (String locNo : locNos) { | 
|---|
|  |  |  | List<LocDetlDto> list = new ArrayList<>(); | 
|---|
|  |  |  | Iterator<LocDetlDto> iterator = locDetlDtos.iterator(); | 
|---|
|  |  |  | while (iterator.hasNext()) { | 
|---|
|  |  |  | LocDetlDto dto = iterator.next(); | 
|---|
|  |  |  | if (locNo.equals(dto.getLocDetl().getLocNo())) { | 
|---|
|  |  |  | list.add(dto); | 
|---|
|  |  |  | iterator.remove(); | 
|---|
|  |  |  | for (LocDetlDto locDetlDto : locDetlDtos) { | 
|---|
|  |  |  | String locNo = locDetlDto.getLocDetl().getLocNo(); | 
|---|
|  |  |  | if (locNos.contains(locNo)) { | 
|---|
|  |  |  | for (OutLocDto dto : dtos) { | 
|---|
|  |  |  | if (dto.getLocNo().equals(locNo)) { | 
|---|
|  |  |  | dto.getLocDetlDtos().add(locDetlDto); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | locNos.add(locNo); | 
|---|
|  |  |  | dtos.add(new OutLocDto(locNo, locDetlDto)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | dtos.add(new OutLocDto(locNo, list)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Integer ioType = null; | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | for (OutLocDto dto : dtos) { | 
|---|
|  |  |  | // 判断入出库类型:101.全板出库 or 103.拣料出库 | 
|---|
|  |  |  | if (ioType == null) { | 
|---|
|  |  |  | if (ioWorkType == null) { | 
|---|
|  |  |  | ioType = dto.isAll() ? 101 : 103; | 
|---|
|  |  |  | } else if (ioWorkType.equals(IoWorkType.CHECK_OUT)) { | 
|---|
|  |  |  | ioType = 107; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | assert ioType != null; | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(dto.getLocNo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer outSta = staNo.getDevNo(); | 
|---|
|  |  |  | //            //2号堆垛机全板出库站指定为204站,拣料站指定为202 | 
|---|
|  |  |  | //            if(locMast.getCrnNo()==2){ | 
|---|
|  |  |  | //                outSta = ioType == 101 ? 204 : 202; | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取路径 | 
|---|
|  |  |  | Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>() | 
|---|
|  |  |  | .eq("type_no", ioType) | 
|---|
|  |  |  | .eq("stn_no", staNo.getDevNo()) | 
|---|
|  |  |  | .eq("crn_no", locMast.getCrnNo()); | 
|---|
|  |  |  | StaDesc staDesc = staDescService.selectOne(wrapper); | 
|---|
|  |  |  | if (Cools.isEmpty(staDesc)) { | 
|---|
|  |  |  | throw new CoolException("出库路径不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | StaDesc staDesc = staDescService.queryCrnStn(ioType, locMast.getCrnNo(), outSta); | 
|---|
|  |  |  | // 生成工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(ioType)); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("N"); // 空板 | 
|---|
|  |  |  | wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | wrkMast.setBarcode(locMast.getBarcode()); | 
|---|
|  |  |  | wrkMast.setAppeUser(userId); // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | if (!wrkMastService.insert(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败,出库库位号:"+dto.getLocNo()); | 
|---|
|  |  |  | throw new CoolException("保存工作档失败,出库库位号:" + dto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 生成工作档明细 | 
|---|
|  |  |  | for (LocDetlDto detlDto : dto.getLocDetlDtos()) { | 
|---|
|  |  |  | // 出库时,数量为0的直接忽略 | 
|---|
|  |  |  | if (detlDto.getCount()==null || detlDto.getCount() <= 0.0D) {continue;} | 
|---|
|  |  |  | if (detlDto.getCount() == null || detlDto.getCount() <= 0.0D) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WrkDetl wrkDetl = new WrkDetl(); | 
|---|
|  |  |  | wrkDetl.sync(detlDto.getLocDetl()); | 
|---|
|  |  |  | wrkDetl.setOrderNo(""); // 手动出库不需要带出库存中的单据编号 | 
|---|
|  |  |  | wrkDetl.setWrkNo(workNo); | 
|---|
|  |  |  | wrkDetl.setIoTime(new Date()); | 
|---|
|  |  |  | Double anfme = ioType==101?detlDto.getLocDetl().getAnfme():detlDto.getCount(); | 
|---|
|  |  |  | wrkDetl.setIoTime(now); | 
|---|
|  |  |  | Double anfme = ioType == 101 ? detlDto.getLocDetl().getAnfme() : detlDto.getCount(); | 
|---|
|  |  |  | wrkDetl.setAnfme(anfme); // 数量 | 
|---|
|  |  |  | VersionUtils.setWrkDetl(wrkDetl, detlDto.getLocDetl()); // 版本控制 | 
|---|
|  |  |  | wrkDetl.setAppeTime(now); | 
|---|
|  |  |  | wrkDetl.setAppeUser(userId); | 
|---|
|  |  |  | wrkDetl.setModiTime(now); | 
|---|
|  |  |  | 
|---|
|  |  |  | // 修改库位状态:   F.在库 ====>>> R.出库预约/P.拣料/盘点/并板出库中 | 
|---|
|  |  |  | locMast = locMastService.selectById(dto.getLocNo()); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | locMast.setLocSts(ioType==101?"R":"P"); | 
|---|
|  |  |  | locMast.setLocSts(ioType == 101 ? "R" : "P"); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("预约库位状态失败,库位号:"+dto.getLocNo()); | 
|---|
|  |  |  | throw new CoolException("预约库位状态失败,库位号:" + dto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(dto.getLocNo() + "库位不是在库状态"); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(taskDto.getLocNo()); | 
|---|
|  |  |  | // 构建出库明细(用于 isAll 判断) | 
|---|
|  |  |  | List<LocDetlDto> locDetlDtos = locDtos.stream().map(locDto -> { | 
|---|
|  |  |  | LocDetl locDetl = new LocDetl(); | 
|---|
|  |  |  | locDetl.setMatnr(locDto.getMatnr()); | 
|---|
|  |  |  | locDetl.setBatch(locDto.getBatch()); | 
|---|
|  |  |  | locDetl.setAnfme(locDto.getAnfme()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | LocDetlDto dto = new LocDetlDto(); | 
|---|
|  |  |  | dto.setLocDetl(locDetl); | 
|---|
|  |  |  | dto.setCount(locDto.getAnfme()); | 
|---|
|  |  |  | return dto; | 
|---|
|  |  |  | }).collect(Collectors.toList()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | taskDto.setLocDetlDtos(locDetlDtos); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取路径 | 
|---|
|  |  |  | int ioType = taskDto.isAll() ? 101 : 103; | 
|---|
|  |  |  | StaDesc staDesc = staDescService.queryCrnStn(ioType, locMast.getCrnNo(), staNo.getDevNo()); | 
|---|
|  |  |  | StaDesc staDesc = staDescService.queryCrnStnAuto(ioType, locMast.getCrnNo(), staNo.getDevNo()); | 
|---|
|  |  |  | // 生成工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(ioType)); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("N"); // 空板 | 
|---|
|  |  |  | wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | wrkMast.setBarcode(locMast.getBarcode()); | 
|---|
|  |  |  | wrkMast.setAppeUser(userId); // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | if (!wrkMastService.insert(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败,出库库位号:"+taskDto.getLocNo()); | 
|---|
|  |  |  | throw new CoolException("保存工作档失败,出库库位号:" + taskDto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 生成工作档明细 | 
|---|
|  |  |  | for (LocDto locDto : taskDto.getLocDtos()) { | 
|---|
|  |  |  | if (locDto.getAnfme()==null || locDto.getAnfme() <= 0.0D) { continue; } | 
|---|
|  |  |  | OrderDetl orderDetl = orderDetlService.selectItem(locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch()); | 
|---|
|  |  |  | if (locDto.getAnfme() == null || locDto.getAnfme() <= 0.0D) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.info("工作档明细:{},{},{},{}", locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch(),locDto.getAnfme()); | 
|---|
|  |  |  | OrderDetl orderDetl = orderDetlService.selectItem(locDto); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WrkDetl wrkDetl = new WrkDetl(); | 
|---|
|  |  |  | wrkDetl.sync(orderDetl); | 
|---|
|  |  |  | wrkDetl.setZpallet(wrkMast.getBarcode()); | 
|---|
|  |  |  | wrkDetl.setIoTime(now); | 
|---|
|  |  |  | wrkDetl.setWrkNo(workNo); | 
|---|
|  |  |  | wrkDetl.setBatch(locDto.getBatch()); | 
|---|
|  |  |  | //wrkDetl.setBatch(locDto.getBatch()); | 
|---|
|  |  |  | wrkDetl.setOrderNo(locDto.getOrderNo()); | 
|---|
|  |  |  | wrkDetl.setAnfme(locDto.getAnfme()); // 数量 | 
|---|
|  |  |  | VersionUtils.setWrkDetl(wrkDetl, orderDetl); // 版本控制 | 
|---|
|  |  |  | wrkDetl.setAppeTime(now); | 
|---|
|  |  |  | wrkDetl.setAppeUser(userId); | 
|---|
|  |  |  | wrkDetl.setModiTime(now); | 
|---|
|  |  |  | 
|---|
|  |  |  | if (!wrkDetlService.insert(wrkDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // todo:luxiaotao 修改订单明细数量 | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 修改订单明细 | 
|---|
|  |  |  | if (!orderDetlService.increaseWorkQty(orderDetl, locDto.getAnfme())) { | 
|---|
|  |  |  | throw new CoolException("修改订单明细数量失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | orderService.updateSettle(orderDetl.getOrderId(), 2L, userId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改库位状态:   F.在库 ====>>> R.出库预约/P.拣料/盘点/并板出库中 | 
|---|
|  |  |  | locMast = locMastService.selectById(taskDto.getLocNo()); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | locMast.setLocSts(ioType==101?"R":"P"); | 
|---|
|  |  |  | locMast.setLocSts(ioType == 101 ? "R" : "P"); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("预约库位状态失败,库位号:"+taskDto.getLocNo()); | 
|---|
|  |  |  | throw new CoolException("预约库位状态失败,库位号:" + taskDto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(taskDto.getLocNo() + "库位不是在库状态"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void stockOut(BasDevp staNo, TaskDto taskDto, Long userId, String endLocation) { | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | List<LocDto> locDtos = taskDto.getLocDtos(); | 
|---|
|  |  |  | for (LocDto locDto : locDtos) { | 
|---|
|  |  |  | if (!taskDto.getLocNo().equals(locDto.getLocNo()) && !taskDto.getStaNo().equals(locDto.getStaNo())) { | 
|---|
|  |  |  | throw new CoolException("订单出库异常,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(taskDto.getLocNo()); | 
|---|
|  |  |  | // 获取路径 | 
|---|
|  |  |  | int ioType = taskDto.isAll() ? 101 : 103; | 
|---|
|  |  |  | StaDesc staDesc = staDescService.queryCrnStnAuto(ioType, locMast.getCrnNo(), staNo.getDevNo()); | 
|---|
|  |  |  | // 生成工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(ioType)); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setInvWh(endLocation); // 地码 | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(11L); // 工作状态:11.生成出库ID | 
|---|
|  |  |  | wrkMast.setIoType(ioType); // 入出库状态 | 
|---|
|  |  |  | wrkMast.setIoPri(13D); // 优先级:13 | 
|---|
|  |  |  | wrkMast.setCrnNo(locMast.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setSourceStaNo(staDesc.getCrnStn()); // 源站 | 
|---|
|  |  |  | wrkMast.setStaNo(staDesc.getStnNo()); // 目标站 | 
|---|
|  |  |  | wrkMast.setSourceLocNo(taskDto.getLocNo()); // 源库位 | 
|---|
|  |  |  | wrkMast.setFullPlt("Y"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("N"); // 空板 | 
|---|
|  |  |  | wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | wrkMast.setBarcode(locMast.getBarcode()); | 
|---|
|  |  |  | wrkMast.setAppeUser(userId); // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | if (!wrkMastService.insert(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败,出库库位号:" + taskDto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 生成工作档明细 | 
|---|
|  |  |  | for (LocDto locDto : taskDto.getLocDtos()) { | 
|---|
|  |  |  | if (locDto.getAnfme() == null || locDto.getAnfme() <= 0.0D) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.info("工作档明细:{},{},{},{}", locDto.getOrderNo(), locDto.getMatnr(), locDto.getBatch(),locDto.getAnfme()); | 
|---|
|  |  |  | OrderDetl orderDetl = orderDetlService.selectItem(locDto); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WrkDetl wrkDetl = new WrkDetl(); | 
|---|
|  |  |  | wrkDetl.sync(orderDetl); | 
|---|
|  |  |  | wrkDetl.setZpallet(wrkMast.getBarcode()); | 
|---|
|  |  |  | wrkDetl.setIoTime(now); | 
|---|
|  |  |  | wrkDetl.setWrkNo(workNo); | 
|---|
|  |  |  | //wrkDetl.setBatch(locDto.getBatch()); | 
|---|
|  |  |  | wrkDetl.setOrderNo(locDto.getOrderNo()); | 
|---|
|  |  |  | wrkDetl.setAnfme(locDto.getAnfme()); // 数量 | 
|---|
|  |  |  | wrkDetl.setAppeTime(now); | 
|---|
|  |  |  | wrkDetl.setAppeUser(userId); | 
|---|
|  |  |  | wrkDetl.setModiTime(now); | 
|---|
|  |  |  | wrkDetl.setModiUser(userId); | 
|---|
|  |  |  | if (!wrkDetlService.insert(wrkDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改订单明细 | 
|---|
|  |  |  | if (!orderDetlService.increaseWorkQty(orderDetl, locDto.getAnfme())) { | 
|---|
|  |  |  | throw new CoolException("修改订单明细数量失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | orderService.updateSettle(orderDetl.getOrderId(), 2L, userId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改库位状态:   F.在库 ====>>> R.出库预约/P.拣料/盘点/并板出库中 | 
|---|
|  |  |  | locMast = locMastService.selectById(taskDto.getLocNo()); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | locMast.setLocSts(ioType == 101 ? "R" : "P"); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("预约库位状态失败,库位号:" + taskDto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(taskDto.getLocNo() + "库位不是在库状态"); | 
|---|
|  |  |  | 
|---|
|  |  |  | BasDevp sourceStaNo = basDevpService.checkSiteStatus(devpNo, true); | 
|---|
|  |  |  | // 检索库位 | 
|---|
|  |  |  | LocTypeDto locTypeDto = new LocTypeDto(sourceStaNo); | 
|---|
|  |  |  | StartupDto dto = commonService.getLocNo(DEFAULT_ROW_NO_TYPE, 10, devpNo, null, locTypeDto, 0); | 
|---|
|  |  |  | StartupDto dto = commonService.getLocNo(DEFAULT_ROW_NO_TYPE, 10, devpNo, null, null, null, locTypeDto); | 
|---|
|  |  |  | int workNo = dto.getWorkNo(); | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(new Date()); | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(1L); // 工作状态:生成入库ID | 
|---|
|  |  |  | wrkMast.setIoType(10); // 入出库状态:10.空板入库 | 
|---|
|  |  |  | wrkMast.setIoPri(10D); // 优先级:10 | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkMast.setCtnType(sourceStaNo.getCtnType()); // 容器类型 | 
|---|
|  |  |  | // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeUser(userId); | 
|---|
|  |  |  | wrkMast.setAppeTime(new Date()); | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | boolean res = wrkMastService.insert(wrkMast); | 
|---|
|  |  |  | if (!res) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | 
|---|
|  |  |  | // 更新源站点信息 | 
|---|
|  |  |  | sourceStaNo.setWrkNo(workNo); | 
|---|
|  |  |  | sourceStaNo.setModiUser(userId); | 
|---|
|  |  |  | sourceStaNo.setModiTime(new Date()); | 
|---|
|  |  |  | if (!basDevpService.updateById(sourceStaNo)){ | 
|---|
|  |  |  | sourceStaNo.setModiTime(now); | 
|---|
|  |  |  | if (!basDevpService.updateById(sourceStaNo)) { | 
|---|
|  |  |  | throw new CoolException("更新源站失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 更新目标库位状态 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(dto.getLocNo()); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("O")){ | 
|---|
|  |  |  | if (locMast.getLocSts().equals("O")) { | 
|---|
|  |  |  | locMast.setLocSts("S"); // S.入库预约 | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)){ | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("改变库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(dto.getLocNo()+"目标库位已被占用"); | 
|---|
|  |  |  | throw new CoolException(dto.getLocNo() + "目标库位已被占用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return dto.getLocNo(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(locNo); | 
|---|
|  |  |  | if (Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | throw new CoolException(locNo+"库位不存在"); | 
|---|
|  |  |  | throw new CoolException(locNo + "库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!locMast.getLocSts().equals("D")) { | 
|---|
|  |  |  | throw new CoolException("所选库位存在状态不为D的库位,库位号:" + locMast.getLocNo() + " 、当前状态:" + locMast.getLocSts() + "-" + locMast.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取源站 | 
|---|
|  |  |  | Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>() | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq("stn_no", param.getOutSite()) | 
|---|
|  |  |  | .eq("crn_no", locMast.getCrnNo()); | 
|---|
|  |  |  | StaDesc staDesc = staDescService.selectOne(wrapper); | 
|---|
|  |  |  | Integer sourceStaNo = staDesc.getCrnStn(); | 
|---|
|  |  |  | if (Cools.isEmpty(sourceStaNo)) { | 
|---|
|  |  |  | throw new CoolException("检索源站失败"); | 
|---|
|  |  |  | if (Cools.isEmpty(staDesc)) { | 
|---|
|  |  |  | throw new CoolException("不存在该空板出库路径,请更换站点"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Integer sourceStaNo = staDesc.getCrnStn(); | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 保存工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(new Date()); | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(11L); // 工作状态:11.生成出库ID | 
|---|
|  |  |  | wrkMast.setIoType(110); // 入出库状态: 110.空板出库 | 
|---|
|  |  |  | wrkMast.setIoPri(10D); | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkMast.setEmptyMk("Y"); // 空板 | 
|---|
|  |  |  | wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | wrkMast.setAppeUser(userId); | 
|---|
|  |  |  | wrkMast.setAppeTime(new Date()); | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | boolean res = wrkMastService.insert(wrkMast); | 
|---|
|  |  |  | if (!res) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 更新库位状态 D.空板 -> R.出库预约 | 
|---|
|  |  |  | if (locMast.getLocSts().equals("D")){ | 
|---|
|  |  |  | if (locMast.getLocSts().equals("D")) { | 
|---|
|  |  |  | locMast.setLocSts("R"); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("更新库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // todo 更新站点信息(工作号) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public WrkMast emptyPlateOut(EmptyPlateOutParam param) { | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | if (Cools.isEmpty(param.getOutSite())) { | 
|---|
|  |  |  | throw new CoolException("站点不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (String locNo : param.getLocNos()) { | 
|---|
|  |  |  | // 获取工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(0); | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(locNo); | 
|---|
|  |  |  | if (Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | throw new CoolException(locNo + "库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取源站 | 
|---|
|  |  |  | Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>() | 
|---|
|  |  |  | .eq("type_no", 110) | 
|---|
|  |  |  | //.eq("stn_no", param.getOutSite()) | 
|---|
|  |  |  | .eq("crn_stn", param.getOutSite()) | 
|---|
|  |  |  | .eq("crn_no", locMast.getCrnNo()); | 
|---|
|  |  |  | StaDesc staDesc = staDescService.selectOne(wrapper); | 
|---|
|  |  |  | Integer sourceStaNo = staDesc.getCrnStn(); | 
|---|
|  |  |  | if (Cools.isEmpty(sourceStaNo)) { | 
|---|
|  |  |  | throw new CoolException("检索源站失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 保存工作档 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(11L); // 工作状态:11.生成出库ID | 
|---|
|  |  |  | wrkMast.setIoType(110); // 入出库状态: 110.空板出库 | 
|---|
|  |  |  | wrkMast.setIoPri(10D); | 
|---|
|  |  |  | wrkMast.setSourceStaNo(sourceStaNo); // 源站 | 
|---|
|  |  |  | //wrkMast.setStaNo(param.getOutSite()); // 目标站 | 
|---|
|  |  |  | wrkMast.setStaNo(staDesc.getStnNo()); // 目标站 | 
|---|
|  |  |  | wrkMast.setCrnNo(locMast.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setSourceLocNo(locNo); // 源库位 | 
|---|
|  |  |  | wrkMast.setFullPlt("N"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("Y"); // 空板 | 
|---|
|  |  |  | wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | wrkMast.setAppeUser(1L); | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(1L); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setMemo("生成自动空板出库"); | 
|---|
|  |  |  | boolean res = wrkMastService.insert(wrkMast); | 
|---|
|  |  |  | if (!res) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 更新库位状态 D.空板 -> R.出库预约 | 
|---|
|  |  |  | if (locMast.getLocSts().equals("D")) { | 
|---|
|  |  |  | locMast.setLocSts("R"); | 
|---|
|  |  |  | locMast.setModiUser(1L); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("更新库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return wrkMast; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | // 获取库位明细 | 
|---|
|  |  |  | List<LocDetlDto> locDetlDtos = new ArrayList<>(); | 
|---|
|  |  |  | for (StockOutParam.LocDetl paramLocDetl : param.getLocDetls()) { | 
|---|
|  |  |  | if (!Cools.isEmpty(paramLocDetl.getLocNo(), paramLocDetl.getMatnr())) { | 
|---|
|  |  |  | LocDetl sqlParam = new LocDetl(); | 
|---|
|  |  |  | sqlParam.setLocNo(paramLocDetl.getLocNo()); | 
|---|
|  |  |  | sqlParam.setMatnr(paramLocDetl.getMatnr()); | 
|---|
|  |  |  | LocDetl one = locDetlService.selectOne(new EntityWrapper<>(sqlParam)); | 
|---|
|  |  |  | if (null != one) locDetlDtos.add(new LocDetlDto(one, one.getAnfme())); | 
|---|
|  |  |  | if (!Cools.isEmpty(paramLocDetl.getLocNo(), paramLocDetl.getMatnr(), paramLocDetl.getCount())) { | 
|---|
|  |  |  | LocDetl one = locDetlService.selectItem(paramLocDetl.getLocNo(), paramLocDetl); | 
|---|
|  |  |  | if (null != one) locDetlDtos.add(new LocDetlDto(one, paramLocDetl.getCount())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!locDetlDtos.isEmpty()) { | 
|---|
|  |  |  | // 启动出库开始 107.盘点出库 | 
|---|
|  |  |  | stockOut(staNo, locDetlDtos, 107, userId); | 
|---|
|  |  |  | LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", locDetlDtos.get(0).getLocDetl().getLocNo())); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | // 启动出库开始 107.盘点出库 | 
|---|
|  |  |  | stockOut(staNo, locDetlDtos, IoWorkType.CHECK_OUT, userId); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("所选库位存在状态不为F的库位,库位号:" + locMast.getLocNo() + " 、当前状态:" + locMast.getLocSts() + "-" + locMast.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("库位物料不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void locMove(String sourceLocNo, String locNo, Long userId) { | 
|---|
|  |  |  | LocMast sourceLoc = locMastService.selectById(sourceLocNo); | 
|---|
|  |  |  | if (Cools.isEmpty(sourceLoc)){ | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", sourceLocNo)); | 
|---|
|  |  |  | if (Cools.isEmpty(sourceLoc)) { | 
|---|
|  |  |  | throw new CoolException("未找到库位"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LocMast loc = locMastService.selectById(locNo); | 
|---|
|  |  |  | if (Cools.isEmpty(loc)){ | 
|---|
|  |  |  | if (Cools.isEmpty(loc)) { | 
|---|
|  |  |  | throw new CoolException("未找到库位"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!loc.getLocSts().equals("O") || (!sourceLoc.getLocSts().equals("F") && !sourceLoc.getLocSts().equals("D"))) { | 
|---|
|  |  |  | throw new CoolException("库位状态已改变"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!sourceLoc.getCrnNo().equals(loc.getCrnNo())) { | 
|---|
|  |  |  | throw new CoolException("移转库位属于不同堆垛机"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 获取工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.PICK.type); | 
|---|
|  |  |  | // 保存工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(new Date()); | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(11L); // 工作状态:11.生成出库ID | 
|---|
|  |  |  | wrkMast.setIoType(11); // 入出库状态: 11.库格移载 | 
|---|
|  |  |  | wrkMast.setIoPri(10D); | 
|---|
|  |  |  | wrkMast.setCrnNo(sourceLoc.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setSourceLocNo(sourceLocNo); // 源库位 | 
|---|
|  |  |  | wrkMast.setLocNo(locNo); // 目标库位 | 
|---|
|  |  |  | wrkMast.setFullPlt("N"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setFullPlt(Cools.isEmpty(locDetls) ? "N" : "Y"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk(sourceLoc.getLocSts().equals("D")?"Y":"N"); // 空板 | 
|---|
|  |  |  | wrkMast.setEmptyMk(sourceLoc.getLocSts().equals("D") ? "Y" : "N"); // 空板 | 
|---|
|  |  |  | wrkMast.setBarcode(sourceLoc.getBarcode()); // 托盘码 | 
|---|
|  |  |  | wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | wrkMast.setAppeUser(userId); | 
|---|
|  |  |  | wrkMast.setAppeTime(new Date()); | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | boolean res = wrkMastService.insert(wrkMast); | 
|---|
|  |  |  | if (!res) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 工作档明细保存 | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", sourceLocNo)); | 
|---|
|  |  |  | for (LocDetl locDetl : locDetls) { | 
|---|
|  |  |  | WrkDetl wrkDetl = new WrkDetl(); | 
|---|
|  |  |  | wrkDetl.sync(locDetl); | 
|---|
|  |  |  | wrkDetl.setWrkNo(workNo); | 
|---|
|  |  |  | wrkDetl.setIoTime(new Date()); | 
|---|
|  |  |  | wrkDetl.setIoTime(now); | 
|---|
|  |  |  | wrkDetl.setAnfme(locDetl.getAnfme()); | 
|---|
|  |  |  | VersionUtils.setWrkDetl(wrkDetl, locDetl); // 版本控制 | 
|---|
|  |  |  | wrkDetl.setAppeTime(new Date()); | 
|---|
|  |  |  | wrkDetl.setAppeTime(now); | 
|---|
|  |  |  | wrkDetl.setAppeUser(userId); | 
|---|
|  |  |  | wrkDetl.setModiTime(new Date()); | 
|---|
|  |  |  | wrkDetl.setModiTime(now); | 
|---|
|  |  |  | wrkDetl.setModiUser(userId); | 
|---|
|  |  |  | if (!wrkDetlService.insert(wrkDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档明细失败"); | 
|---|
|  |  |  | 
|---|
|  |  |  | if (sourceLoc.getLocSts().equals("D") || sourceLoc.getLocSts().equals("F")) { | 
|---|
|  |  |  | sourceLoc.setLocSts("R"); // R.出库预约 | 
|---|
|  |  |  | sourceLoc.setModiUser(userId); | 
|---|
|  |  |  | sourceLoc.setModiTime(new Date()); | 
|---|
|  |  |  | if (!locMastService.updateById(sourceLoc)){ | 
|---|
|  |  |  | sourceLoc.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(sourceLoc)) { | 
|---|
|  |  |  | throw new CoolException("更新源库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("源库位出库失败,状态:"+sourceLoc.getLocSts$()); | 
|---|
|  |  |  | throw new CoolException("源库位出库失败,状态:" + sourceLoc.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改目标库位状态 | 
|---|
|  |  |  | if (loc.getLocSts().equals("O")) { | 
|---|
|  |  |  | loc.setLocSts("S"); // S.入库预约 | 
|---|
|  |  |  | loc.setModiTime(new Date()); | 
|---|
|  |  |  | loc.setModiTime(now); | 
|---|
|  |  |  | loc.setModiUser(userId); | 
|---|
|  |  |  | if (!locMastService.updateById(loc)) { | 
|---|
|  |  |  | throw new CoolException("更新目标库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("移转失败,目标库位状态:"+loc.getLocSts$()); | 
|---|
|  |  |  | throw new CoolException("移转失败,目标库位状态:" + loc.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void completeWrkMast(String workNo, Long userId) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(workNo); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)){ | 
|---|
|  |  |  | throw new CoolException(workNo+"工作档不存在"); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException(workNo + "工作档不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (wrkMast.getWrkSts() == 4 || wrkMast.getWrkSts() == 14) { | 
|---|
|  |  |  | if (wrkMast.getWrkSts() == 4 || wrkMast.getWrkSts() >= 14) { | 
|---|
|  |  |  | throw new CoolException("当前工作档已完成"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 入库 + 库位转移 | 
|---|
|  |  |  | if (wrkMast.getWrkSts() < 4 || (wrkMast.getWrkSts() > 10 && wrkMast.getIoType()==11)) { | 
|---|
|  |  |  | if (wrkMast.getWrkSts() < 4 || (wrkMast.getWrkSts() > 10 && wrkMast.getIoType() == 11)) { | 
|---|
|  |  |  | wrkMast.setWrkSts(4L); | 
|---|
|  |  |  | // 出库 | 
|---|
|  |  |  | // 出库 | 
|---|
|  |  |  | } else if (wrkMast.getWrkSts() > 10) { | 
|---|
|  |  |  | wrkMast.setWrkSts(14L); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void adjustLocDetl(LocDetlAdjustParam param, Long userId) { | 
|---|
|  |  |  | param.integrate(); | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(param.getLocNo()); | 
|---|
|  |  |  | if (Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | throw new CoolException("库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (LocDetlAdjustParam.LocDetlAdjust adjust : param.getList()) { | 
|---|
|  |  |  | if (Cools.isEmpty(adjust.getMatnr())) { | 
|---|
|  |  |  | throw new CoolException(BaseRes.PARAM); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LocDetl sqlParam = new LocDetl(); | 
|---|
|  |  |  | sqlParam.setLocNo(locMast.getLocNo()); | 
|---|
|  |  |  | sqlParam.setMatnr(adjust.getMatnr()); | 
|---|
|  |  |  | LocDetl one = locDetlService.selectOne(new EntityWrapper<>(sqlParam)); | 
|---|
|  |  |  | // 保存新库存明细 | 
|---|
|  |  |  | if (Cools.isEmpty(one)) { | 
|---|
|  |  |  | if (adjust.getCount() == 0){ | 
|---|
|  |  |  | if (!(locMast.getLocSts().equals("F") || locMast.getLocSts().equals("D") || locMast.getLocSts().equals("O"))) { | 
|---|
|  |  |  | throw new CoolException("当前库位不可调整!库位状态:" + locMast.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", param.getLocNo())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<LocDetlAdjustParam.LocDetlAdjust> list = param.getList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 修改数量 | 
|---|
|  |  |  | Iterator<LocDetl> iterator = locDetls.iterator(); | 
|---|
|  |  |  | while (iterator.hasNext()) { | 
|---|
|  |  |  | LocDetl locDetl = iterator.next(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Iterator<LocDetlAdjustParam.LocDetlAdjust> iterator1 = list.iterator(); | 
|---|
|  |  |  | while (iterator1.hasNext()) { | 
|---|
|  |  |  | LocDetlAdjustParam.LocDetlAdjust adjust = iterator1.next(); | 
|---|
|  |  |  | if (adjust.getCount() == 0) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | MatCode matCode = matCodeService.selectById(adjust.getMatnr()); | 
|---|
|  |  |  | LocDetl locDetl = new LocDetl(); | 
|---|
|  |  |  | locDetl.setLocNo(locMast.getLocNo()); | 
|---|
|  |  |  | locDetl.setAnfme(adjust.getCount()); // 数量 | 
|---|
|  |  |  | VersionUtils.setLocDetl(locDetl, matCode); // 版本控制 | 
|---|
|  |  |  | locDetl.setModiUser(userId); // 操作人员信息 | 
|---|
|  |  |  | locDetl.setModiTime(new Date()); | 
|---|
|  |  |  | locDetl.setAppeUser(userId); | 
|---|
|  |  |  | locDetl.setAppeTime(new Date()); | 
|---|
|  |  |  | if (!locDetlService.insert(locDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | AdjDetl adjDetl = new AdjDetl(); | 
|---|
|  |  |  | adjDetl.setLocNo(locDetl.getLocNo()); | 
|---|
|  |  |  | adjDetl.setMatNo(locDetl.getMatnr()); | 
|---|
|  |  |  | adjDetl.setOriQty(0.0D); | 
|---|
|  |  |  | adjDetl.setAdjQty(adjust.getCount()); | 
|---|
|  |  |  | adjDetlService.save(adjDetl, userId); | 
|---|
|  |  |  | // 上报erp | 
|---|
|  |  |  | String docNum = "CS-" + String.valueOf(snowflakeIdWorker.nextId()).substring(0, 15); | 
|---|
|  |  |  | Integer docId = 14; // 报溢单 | 
|---|
|  |  |  | List<BillDto> dtos = new ArrayList<>(); | 
|---|
|  |  |  | BillDto billDto = new BillDto(); | 
|---|
|  |  |  | billDto.setMatnr(adjust.getMatnr()); | 
|---|
|  |  |  | billDto.setQty(Math.abs(adjust.getCount())); | 
|---|
|  |  |  | dtos.add(billDto); | 
|---|
|  |  |  | Result result = wmsService.erpUpload(dtos, docId, docNum); | 
|---|
|  |  |  | if (result.getCode() != 200) { | 
|---|
|  |  |  | throw new CoolException("库存调整失败,原因:无法上报至ERP"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改原库存明细 | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 如果数量修改,则更新库存明细 | 
|---|
|  |  |  | if (!adjust.getCount().equals(one.getAnfme())) { | 
|---|
|  |  |  | // 当数量被修改为 0 时,直接清除库存明细 | 
|---|
|  |  |  | if (adjust.getCount() == 0) { | 
|---|
|  |  |  | // 上报erp | 
|---|
|  |  |  | String docNum = "CD-" + String.valueOf(snowflakeIdWorker.nextId()).substring(0, 15); | 
|---|
|  |  |  | Integer docId = 9; // 报损单 | 
|---|
|  |  |  | List<BillDto> dtos = new ArrayList<>(); | 
|---|
|  |  |  | BillDto billDto = new BillDto(); | 
|---|
|  |  |  | billDto.setMatnr(adjust.getMatnr()); | 
|---|
|  |  |  | billDto.setQty(Math.abs(one.getAnfme())); | 
|---|
|  |  |  | dtos.add(billDto); | 
|---|
|  |  |  | Result result = wmsService.erpUpload(dtos, docId, docNum); | 
|---|
|  |  |  | if (result.getCode() != 200) { | 
|---|
|  |  |  | throw new CoolException("库存调整失败,原因:无法上报至ERP"); | 
|---|
|  |  |  | if (locDetl.getMatnr().equals(adjust.getMatnr()) && Cools.eq(locDetl.getBatch(), adjust.getBatch())) { | 
|---|
|  |  |  | if (!locDetl.getAnfme().equals(adjust.getCount())) { | 
|---|
|  |  |  | // todo 盘点记录 | 
|---|
|  |  |  | // 修改库存 | 
|---|
|  |  |  | if (!locDetlService.updateAnfme(adjust.getCount(), locDetl.getLocNo(), locDetl)) { | 
|---|
|  |  |  | throw new CoolException(locDetl.getLocNo() + "库位," + locDetl.getMatnr() + "商品," + locDetl.getBatch() + "批号修改数量失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 删除库存 | 
|---|
|  |  |  | if (!locDetlService.delete(new EntityWrapper<>(one))) { | 
|---|
|  |  |  | throw new CoolException("清除库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | LocDetl sqlParam1 = new LocDetl(); | 
|---|
|  |  |  | sqlParam1.setAnfme(adjust.getCount()); | 
|---|
|  |  |  | sqlParam1.setModiTime(new Date()); | 
|---|
|  |  |  | sqlParam1.setModiUser(userId); | 
|---|
|  |  |  | if (!locDetlService.update(sqlParam1, new EntityWrapper<LocDetl>() | 
|---|
|  |  |  | .eq("loc_no", locMast.getLocNo()) | 
|---|
|  |  |  | .eq("matnr", adjust.getMatnr()))) { | 
|---|
|  |  |  | throw new CoolException("修改库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 上报erp | 
|---|
|  |  |  | String docNum; | 
|---|
|  |  |  | Integer docId; | 
|---|
|  |  |  | if (one.getAnfme() > adjust.getCount()) { | 
|---|
|  |  |  | // 报损 | 
|---|
|  |  |  | docNum = "CD-" + String.valueOf(snowflakeIdWorker.nextId()).substring(0, 15); | 
|---|
|  |  |  | docId = 9; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 报溢 | 
|---|
|  |  |  | docNum = "CS-" + String.valueOf(snowflakeIdWorker.nextId()).substring(0, 15); | 
|---|
|  |  |  | docId = 14; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<BillDto> dtos = new ArrayList<>(); | 
|---|
|  |  |  | BillDto billDto = new BillDto(); | 
|---|
|  |  |  | billDto.setMatnr(adjust.getMatnr()); | 
|---|
|  |  |  | billDto.setQty(Math.abs(one.getAnfme() - adjust.getCount())); | 
|---|
|  |  |  | dtos.add(billDto); | 
|---|
|  |  |  | Result result = wmsService.erpUpload(dtos, docId, docNum); | 
|---|
|  |  |  | if (result.getCode() != 200) { | 
|---|
|  |  |  | throw new CoolException("库存调整失败,原因:无法上报至ERP"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | AdjDetl adjDetl = new AdjDetl(); | 
|---|
|  |  |  | adjDetl.setLocNo(locDetl.getLocNo()); | 
|---|
|  |  |  | adjDetl.setMatnr(locDetl.getMatnr()); | 
|---|
|  |  |  | adjDetl.setBatch(locDetl.getBatch()); | 
|---|
|  |  |  | adjDetl.setOriQty(locDetl.getAnfme()); | 
|---|
|  |  |  | adjDetl.setAdjQty(adjust.getCount()); | 
|---|
|  |  |  | adjDetl.setModiTime(now); | 
|---|
|  |  |  | adjDetl.setModiUser(userId); | 
|---|
|  |  |  | adjDetl.setAppeTime(now); | 
|---|
|  |  |  | adjDetl.setAppeUser(userId); | 
|---|
|  |  |  | adjDetlService.save(adjDetl, userId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | AdjDetl adjDetl = new AdjDetl(); | 
|---|
|  |  |  | adjDetl.setLocNo(locMast.getLocNo()); | 
|---|
|  |  |  | adjDetl.setMatNo(adjust.getMatnr()); | 
|---|
|  |  |  | adjDetl.setOriQty(one.getAnfme()); | 
|---|
|  |  |  | adjDetl.setAdjQty(adjust.getCount()); | 
|---|
|  |  |  | adjDetlService.save(adjDetl, userId); | 
|---|
|  |  |  | iterator.remove(); | 
|---|
|  |  |  | iterator1.remove(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", param.getLocNo())); | 
|---|
|  |  |  | if (locDetls.isEmpty()) { | 
|---|
|  |  |  | locMast.setLocSts("D"); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("更新库位状态失败"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 删除库存 | 
|---|
|  |  |  | for (LocDetl locDetl : locDetls) { | 
|---|
|  |  |  | // todo 盘点记录 | 
|---|
|  |  |  | if (!locDetlService.updateAnfme(-1.0D, locDetl.getLocNo(), locDetl)) { | 
|---|
|  |  |  | throw new CoolException("删除" + locDetl.getLocNo() + "库位," + locDetl.getMatnr() + "商品," + locDetl.getBatch() + "批号库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | AdjDetl adjDetl = new AdjDetl(); | 
|---|
|  |  |  | adjDetl.setLocNo(locDetl.getLocNo()); | 
|---|
|  |  |  | adjDetl.setMatnr(locDetl.getMatnr()); | 
|---|
|  |  |  | adjDetl.setBatch(locDetl.getBatch()); | 
|---|
|  |  |  | adjDetl.setOriQty(locDetl.getAnfme()); | 
|---|
|  |  |  | adjDetl.setAdjQty(0.0D); | 
|---|
|  |  |  | adjDetl.setModiTime(now); | 
|---|
|  |  |  | adjDetl.setModiUser(userId); | 
|---|
|  |  |  | adjDetl.setAppeTime(now); | 
|---|
|  |  |  | adjDetl.setAppeUser(userId); | 
|---|
|  |  |  | adjDetlService.save(adjDetl, userId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 添加库存 | 
|---|
|  |  |  | for (LocDetlAdjustParam.LocDetlAdjust adjust : list) { | 
|---|
|  |  |  | if (adjust.getCount() == 0.0D) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Mat mat = matService.selectByMatnr(adjust.getMatnr()); | 
|---|
|  |  |  | LocDetl locDetl = new LocDetl(); | 
|---|
|  |  |  | locDetl.sync(mat); | 
|---|
|  |  |  | locDetl.setBatch(adjust.getBatch()); | 
|---|
|  |  |  | locDetl.setLocNo(locMast.getLocNo()); | 
|---|
|  |  |  | locDetl.setAnfme(adjust.getCount()); // 数量 | 
|---|
|  |  |  | locDetl.setModiUser(userId); // 操作人员信息 | 
|---|
|  |  |  | locDetl.setModiTime(now); | 
|---|
|  |  |  | locDetl.setAppeUser(userId); | 
|---|
|  |  |  | locDetl.setAppeTime(now); | 
|---|
|  |  |  | if (!locDetlService.insert(locDetl)) { | 
|---|
|  |  |  | throw new CoolException("添加" + locDetl.getLocNo() + "库位," + locDetl.getMatnr() + "商品," + locDetl.getBatch() + "批号库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | AdjDetl adjDetl = new AdjDetl(); | 
|---|
|  |  |  | adjDetl.setLocNo(locMast.getLocNo()); | 
|---|
|  |  |  | adjDetl.setMatnr(adjust.getMatnr()); | 
|---|
|  |  |  | adjDetl.setBatch(adjust.getBatch()); | 
|---|
|  |  |  | adjDetl.setOriQty(0.0D); | 
|---|
|  |  |  | adjDetl.setAdjQty(adjust.getCount()); | 
|---|
|  |  |  | adjDetl.setModiTime(now); | 
|---|
|  |  |  | adjDetl.setModiUser(userId); | 
|---|
|  |  |  | adjDetl.setAppeTime(now); | 
|---|
|  |  |  | adjDetl.setAppeUser(userId); | 
|---|
|  |  |  | adjDetlService.save(adjDetl, userId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改库位状态 | 
|---|
|  |  |  | int count = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo())); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | if (count == 0) { | 
|---|
|  |  |  | locMast.setLocSts("D"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (locMast.getLocSts().equals("D") || locMast.getLocSts().equals("O")) { | 
|---|
|  |  |  | if (count > 0) { | 
|---|
|  |  |  | locMast.setLocSts("F"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("更新库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void cancelWrkMast(String workNo, Long userId) { | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(workNo); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)){ | 
|---|
|  |  |  | throw new CoolException(workNo+"工作档不存在"); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException(workNo + "工作档不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String locNo = ""; // 待修改目标库位 | 
|---|
|  |  |  | String locSts = ""; // 待修改目标库位状态 | 
|---|
|  |  |  | 
|---|
|  |  |  | if (wrkMast.getWrkSts() < 4) { | 
|---|
|  |  |  | locNo = wrkMast.getLocNo(); | 
|---|
|  |  |  | locSts = "O"; | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 库位转移 | 
|---|
|  |  |  | * 取消后 源库位 ==>> F.在库 | 
|---|
|  |  |  | *       目标库位 ===>> O.空库位 | 
|---|
|  |  |  | **/ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 库位转移 | 
|---|
|  |  |  | if (wrkMast.getIoType() == 11) { | 
|---|
|  |  |  | // 库位转移:源库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(wrkMast.getSourceLocNo()); | 
|---|
|  |  |  | if (Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | throw new CoolException("取消库位转移失败,源库位不存在:"+ wrkMast.getSourceLocNo()); | 
|---|
|  |  |  | throw new CoolException("取消库位转移失败,源库位不存在:" + wrkMast.getSourceLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | locMast.setLocSts("F"); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | locMast.setLocSts(wrkMast.getFullPlt().equalsIgnoreCase("N") ? "D" : "F"); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMastService.updateById(locMast); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 出库取消(修改源库位) | 
|---|
|  |  |  | // 出库取消(修改源库位) | 
|---|
|  |  |  | } else if (wrkMast.getWrkSts() > 10 && wrkMast.getWrkSts() != 14) { | 
|---|
|  |  |  | locNo = wrkMast.getSourceLocNo(); | 
|---|
|  |  |  | // 出库 ===>> F.在库 | 
|---|
|  |  |  | if (wrkMast.getIoType() > 100 && wrkMast.getIoType() != 110) { | 
|---|
|  |  |  | locSts = "F"; | 
|---|
|  |  |  | // 空板出库 ===>> D.空桶/空栈板 | 
|---|
|  |  |  | // 空板出库 ===>> D.空桶/空栈板 | 
|---|
|  |  |  | } else if (wrkMast.getIoType() == 110) { | 
|---|
|  |  |  | locSts = "D"; | 
|---|
|  |  |  | // 库位转移 ===>> D.空桶/空栈板 | 
|---|
|  |  |  | // 库位转移 ===>> D.空桶/空栈板 | 
|---|
|  |  |  | } else if (wrkMast.getIoType() == 11) { | 
|---|
|  |  |  | locSts = "F"; | 
|---|
|  |  |  | locSts = wrkMast.getFullPlt().equalsIgnoreCase("N") ? "D" : "F"; | 
|---|
|  |  |  | // 库位转移:目标库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(wrkMast.getLocNo()); | 
|---|
|  |  |  | if (Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | throw new CoolException("取消库位转移失败,目标库位不存在:"+ wrkMast.getSourceLocNo()); | 
|---|
|  |  |  | throw new CoolException("取消库位转移失败,目标库位不存在:" + wrkMast.getSourceLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | locMast.setLocSts("O"); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMastService.updateById(locMast); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("当前工作状态无法取消"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 订单关联 | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | if (!Cools.isEmpty(wrkDetl.getOrderNo())) { | 
|---|
|  |  |  | if (!orderDetlService.decrease(wrkDetl.getOrderNo(), wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getAnfme())) { | 
|---|
|  |  |  | throw new CoolException("订单数据回滚失败"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //取消入库工作档时,查询组托表,如果有将状态改为待处理 | 
|---|
|  |  |  | if (wrkMast.getIoType() == 1) { | 
|---|
|  |  |  | List<WaitPakin> waitPakins = waitPakinService.selectList(new EntityWrapper<WaitPakin>().eq("zpallet", wrkMast.getBarcode())); | 
|---|
|  |  |  | for (WaitPakin waitPakin : waitPakins) { | 
|---|
|  |  |  | if (!Cools.isEmpty(waitPakin)) { | 
|---|
|  |  |  | waitPakin.setIoStatus("N"); | 
|---|
|  |  |  | waitPakin.setLocNo(""); | 
|---|
|  |  |  | waitPakinService.update(waitPakin, new EntityWrapper<WaitPakin>() | 
|---|
|  |  |  | //                            .eq("order_no", waitPakin.getOrderNo()) | 
|---|
|  |  |  | .eq("zpallet", waitPakin.getZpallet()) | 
|---|
|  |  |  | .eq("matnr", waitPakin.getMatnr()) | 
|---|
|  |  |  | .eq("batch", waitPakin.getBatch())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 生成新的出库作业 | 
|---|
|  |  |  | //                        stockOutRe(wrkMast, wrkDetls); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //取消出库工作档时,查询单据管理表,回滚作业中数量 | 
|---|
|  |  |  | if (wrkMast.getIoType() == 101 || wrkMast.getIoType() == 103) { | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | if (!Cools.isEmpty(wrkDetl.getOrderNo())) { | 
|---|
|  |  |  | if (!orderDetlService.decrease(wrkDetl, wrkDetl.getAnfme())) { | 
|---|
|  |  |  | throw new CoolException("订单数据回滚失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //修改订单主表状态,没有作业数量时才可以修改 | 
|---|
|  |  |  | boolean flag = true; | 
|---|
|  |  |  | List<OrderDetl> orderDetls = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", wrkDetl.getOrderNo())); | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetls) { | 
|---|
|  |  |  | if (orderDetl.getWorkQty() > 0) { | 
|---|
|  |  |  | flag = false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (flag) { | 
|---|
|  |  |  | Order order = orderService.selectOne(new EntityWrapper<Order>().eq("order_no", wrkDetl.getOrderNo())); | 
|---|
|  |  |  | if (!Cools.isEmpty(order) && order.getSettle() == 2) { | 
|---|
|  |  |  | order.setSettle(1L); | 
|---|
|  |  |  | order.setUpdateBy(userId); | 
|---|
|  |  |  | order.setUpdateTime(now); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!orderService.update(order, new EntityWrapper<Order>().eq("order_no", wrkDetl.getOrderNo()))) { | 
|---|
|  |  |  | throw new CoolException("修改订单状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        // 订单关联 | 
|---|
|  |  |  | //        List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | //        for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | //            if (!Cools.isEmpty(wrkDetl.getOrderNo())) { | 
|---|
|  |  |  | //                if (!orderDetlService.decrease(wrkDetl.getOrderNo(), wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getAnfme())) { | 
|---|
|  |  |  | //                    throw new CoolException("订单数据回滚失败"); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                // 生成新的出库作业 | 
|---|
|  |  |  | ////                        stockOutRe(wrkMast, wrkDetls); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 取消操作人员记录 | 
|---|
|  |  |  | wrkMast.setManuType("手动取消"); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | if (!wrkMastService.updateById(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("取消工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (wrkMast.getIoType() != 10 && wrkMast.getIoType() != 110) { | 
|---|
|  |  |  | // 保存工作明细档历史档 | 
|---|
|  |  |  | if (!wrkDetlLogService.save(wrkMast.getWrkNo())) { | 
|---|
|  |  |  | throw new CoolException("保存工作明细历史档失败, workNo = " + wrkMast.getWrkNo()); | 
|---|
|  |  |  | //                throw new CoolException("保存工作明细历史档失败, workNo = " + wrkMast.getWrkNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 删除工作档明细 | 
|---|
|  |  |  | boolean wrkDetlRes = wrkDetlService.delete(new EntityWrapper<WrkDetl>().eq("wrk_no", workNo)); | 
|---|
|  |  |  | 
|---|
|  |  |  | // 修改库位状态 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(locNo); | 
|---|
|  |  |  | if (Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | throw new CoolException("取消工作档失败,库位不存在:"+ locNo); | 
|---|
|  |  |  | throw new CoolException("取消工作档失败,库位不存在:" + locNo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | locMast.setLocSts(locSts); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | boolean locMastRes = locMastService.updateById(locMast); | 
|---|
|  |  |  | if (!wrkMastRes || !locMastRes) { | 
|---|
|  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void pickWrkMast(String workNo, Long userId) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(workNo); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)){ | 
|---|
|  |  |  | throw new CoolException(workNo+"工作档不存在"); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException(workNo + "工作档不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 入出库类型判断 | 
|---|
|  |  |  | if (wrkMast.getIoType() != 103 && wrkMast.getIoType() != 104 && wrkMast.getIoType() != 107) { | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new CoolException("当前工作状态无法进行操作"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存工作明细档历史档 | 
|---|
|  |  |  | if (!wrkDetlLogService.save(wrkMast.getWrkNo())) { | 
|---|
|  |  |  | throw new CoolException("保存工作明细档历史档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        if (!wrkDetlLogService.save(wrkMast.getWrkNo())) { | 
|---|
|  |  |  | //            throw new CoolException("保存工作明细档历史档失败"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | // 保存工作主档历史档 | 
|---|
|  |  |  | if (!wrkMastLogService.save(wrkMast.getWrkNo())) { | 
|---|
|  |  |  | throw new CoolException("保存工作主档历史档失败"); | 
|---|
|  |  |  | 
|---|
|  |  |  | if (Cools.isEmpty(staDesc)) { | 
|---|
|  |  |  | throw new CoolException("入库路径不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 堆垛机站点(目标站) | 
|---|
|  |  |  | Integer staNo = staDesc.getCrnStn(); | 
|---|
|  |  |  | // 更新工作档数据状态 | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkMast.setStaNo(staNo); // 目标站 | 
|---|
|  |  |  | wrkMast.setLocNo(wrkMast.getSourceLocNo()); // 目标库位 = 出库时的源库位 | 
|---|
|  |  |  | wrkMast.setSourceLocNo(""); // 源库位清空 | 
|---|
|  |  |  | wrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | if (!wrkMastService.updateById(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("更新工作档数据状态失败"); | 
|---|
|  |  |  | 
|---|
|  |  |  | // 修改库位状态 Q.拣料/盘点/并板再入库 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(wrkMast.getLocNo()); | 
|---|
|  |  |  | locMast.setLocSts("Q"); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("修改库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private JdbcTemplate jdbcTemplate; | 
|---|
|  |  |  | private boolean pickSite = false; | 
|---|
|  |  |  | private void stockOutRe(WrkMast wrkMast, List<WrkDetl> wrkDetls) { | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectPakoutByRule(wrkDetl.getMatnr()); | 
|---|
|  |  |  | double issued = wrkDetl.getAnfme(); | 
|---|
|  |  |  | for (LocDetl locDetl : locDetls) { | 
|---|
|  |  |  | if (issued > 0) { | 
|---|
|  |  |  | // 生成出库工作档 | 
|---|
|  |  |  | // 全板 | 
|---|
|  |  |  | if (issued>=locDetl.getAnfme()) { | 
|---|
|  |  |  | BasDevp staNo = basDevpService.checkSiteStatus(103); | 
|---|
|  |  |  | List<LocDetlDto> detlDtos = new ArrayList<>(); | 
|---|
|  |  |  | LocDetlDto dto = new LocDetlDto(); | 
|---|
|  |  |  | dto.setLocDetl(locDetl); | 
|---|
|  |  |  | dto.setCount(issued>=locDetl.getAnfme()?locDetl.getAnfme():issued); | 
|---|
|  |  |  | detlDtos.add(dto); | 
|---|
|  |  |  | stockOut(staNo, detlDtos, 101, 9527L); | 
|---|
|  |  |  | // 拣料 | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | int priorCount = jdbcTemplate.queryForObject("select isnull(count(*),0) from man_prior where 1=1 and matnr = '" + wrkDetl.getMatnr() + "'", Integer.class); | 
|---|
|  |  |  | if (priorCount > 0) { | 
|---|
|  |  |  | BasDevp staNo = basDevpService.checkSiteStatus(103); | 
|---|
|  |  |  | List<LocDetlDto> detlDtos = new ArrayList<>(); | 
|---|
|  |  |  | LocDetlDto dto = new LocDetlDto(); | 
|---|
|  |  |  | dto.setLocDetl(locDetl); | 
|---|
|  |  |  | dto.setCount(locDetl.getAnfme()); | 
|---|
|  |  |  | detlDtos.add(dto); | 
|---|
|  |  |  | stockOut(staNo, detlDtos, 101, 9527L); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | BasDevp staNo = basDevpService.checkSiteStatus(pickSite?113:109); | 
|---|
|  |  |  | List<LocDetlDto> detlDtos = new ArrayList<>(); | 
|---|
|  |  |  | LocDetlDto dto = new LocDetlDto(); | 
|---|
|  |  |  | dto.setLocDetl(locDetl); | 
|---|
|  |  |  | dto.setCount(issued>=locDetl.getAnfme()?locDetl.getAnfme():issued); | 
|---|
|  |  |  | detlDtos.add(dto); | 
|---|
|  |  |  | stockOut(staNo, detlDtos, 103, 9527L); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 剩余待出数量递减 | 
|---|
|  |  |  | issued = issued - locDetl.getAnfme(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public StartupDto createWaitPainWrkMastStart(List<WaitPakin> list, Long userId) { | 
|---|
|  |  |  | if (Cools.isEmpty(list)) { | 
|---|
|  |  |  | throw new CoolException("入库通知档不能为空"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | pickSite = !pickSite; | 
|---|
|  |  |  | LocTypeDto locTypeDto = new LocTypeDto(); | 
|---|
|  |  |  | locTypeDto.setLocType1((short) 1); | 
|---|
|  |  |  | return wcsController.startupFullPutStore(301, list.get(0).getZpallet(), 0.0, locTypeDto, list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public String dealPreHaveStart(Integer wrkNo, Long userId) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(wrkNo); | 
|---|
|  |  |  | if (wrkMast == null) { | 
|---|
|  |  |  | throw new CoolException("任务已失效"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String locNo = wrkMast.getLocNo(); | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(locNo); | 
|---|
|  |  |  | assert locMast != null; | 
|---|
|  |  |  | RowLastno rowLastno = rowLastnoService.findBySection(locMast.getRow1()); | 
|---|
|  |  |  | assert rowLastno != null; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 目标库位 | 
|---|
|  |  |  | LocMast targetLoc = null; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (int curRow = rowLastno.getsRow(); curRow <= rowLastno.geteRow(); curRow++) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (Utils.isShallowLoc(slaveProperties, curRow)) { | 
|---|
|  |  |  | Integer deepRow = Utils.getDeepRow(slaveProperties, curRow); | 
|---|
|  |  |  | targetLoc = locMastService.queryFreeLocMast(deepRow, locMast.getLocType1()); | 
|---|
|  |  |  | // 因库位移转、需预留空库位 | 
|---|
|  |  |  | if (!locMastService.checkEmptyCount(targetLoc)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (Cools.isEmpty(targetLoc)) { | 
|---|
|  |  |  | targetLoc = locMastService.queryFreeLocMast(curRow, locMast.getLocType1()); | 
|---|
|  |  |  | // 因库位移转、需预留空库位 | 
|---|
|  |  |  | if (!locMastService.checkEmptyCount(targetLoc)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 目标库位 ===>> 浅库位, 则校验其深库位是否为 F D X | 
|---|
|  |  |  | if (null != targetLoc && Utils.isShallowLoc(slaveProperties, targetLoc.getLocNo())) { | 
|---|
|  |  |  | LocMast deepLoc = locMastService.selectById(Utils.getDeepLoc(slaveProperties, targetLoc.getLocNo())); | 
|---|
|  |  |  | if (!deepLoc.getLocSts().equals("F") && !deepLoc.getLocSts().equals("D") && !deepLoc.getLocSts().equals("X")) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 目标库位 ===>> 深库位, 则校验其浅库位是否为 O | 
|---|
|  |  |  | if (null != targetLoc && Utils.isDeepLoc(slaveProperties, targetLoc.getLocNo())) { | 
|---|
|  |  |  | LocMast shallowLoc = locMastService.selectById(Utils.getShallowLoc(slaveProperties, targetLoc.getLocNo())); | 
|---|
|  |  |  | if (!shallowLoc.getLocSts().equals("O")) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!Cools.isEmpty(targetLoc)) { | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (targetLoc == null) { | 
|---|
|  |  |  | throw new CoolException("操作失败,当前仓库找不到空库位"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 修改工作档 | 
|---|
|  |  |  | StaDesc staDesc = staDescService.queryCrnStn(targetLoc.getCrnNo()); | 
|---|
|  |  |  | if (Cools.isEmpty(staDesc)) { | 
|---|
|  |  |  | throw new CoolException("入库路径不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | wrkMast.setWrkSts(2L); | 
|---|
|  |  |  | wrkMast.setLocNo(targetLoc.getLocNo()); | 
|---|
|  |  |  | wrkMast.setStaNo(staDesc.getCrnStn()); | 
|---|
|  |  |  | wrkMast.setCrnNo(targetLoc.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setPreHave("N"); | 
|---|
|  |  |  | if (!wrkMastService.updateById(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("修改工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改库位状态 O ===>>> S | 
|---|
|  |  |  | if (targetLoc.getLocSts().equals("O")) { | 
|---|
|  |  |  | targetLoc.setLocSts("S"); // S.入库预约 | 
|---|
|  |  |  | targetLoc.setModiUser(userId); | 
|---|
|  |  |  | targetLoc.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(targetLoc)) { | 
|---|
|  |  |  | throw new CoolException("改变库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(targetLoc.getLocNo() + "目标库位已被占用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 禁用异常库位 | 
|---|
|  |  |  | //        locMast.setLocSts("X"); // X.禁用 | 
|---|
|  |  |  | //        locMast.setModiUser(userId); | 
|---|
|  |  |  | //        locMast.setModiTime(now); | 
|---|
|  |  |  | //        if (!locMastService.updateById(locMast)){ | 
|---|
|  |  |  | //            throw new CoolException("改变库位状态失败"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | return targetLoc.getLocNo(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void turnMatLocDetl(EmptyPlateOutParam param, Long userId) { | 
|---|
|  |  |  | Mat mat = matService.selectOne(new EntityWrapper<Mat>().eq("id", param.getMatId())); | 
|---|
|  |  |  | if (Cools.isEmpty(mat)) { | 
|---|
|  |  |  | throw new CoolException("目标库位商品编码有误!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("matnr", param.getLocDetls().get(0).getMatnr())); | 
|---|
|  |  |  | if (Cools.isEmpty(locDetls) || locDetls.size() < 1) { | 
|---|
|  |  |  | throw new CoolException("待修改商品无库存,无需修改!  品号:" + param.getLocDetls().get(0).getMatnr()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | locDetlService.updateMatTurn(param.getLocDetls().get(0).getMatnr(), mat.getMatnr()); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | throw new CoolException("对数据库修改出错!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (LocDetl locDetl : locDetls) { | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | AdjDetl adjDetl = new AdjDetl(); | 
|---|
|  |  |  | adjDetl.setLocNo(locDetl.getLocNo()); | 
|---|
|  |  |  | adjDetl.setMatnr(mat.getMatnr()); | 
|---|
|  |  |  | adjDetl.setMatnrOld(param.getLocDetls().get(0).getMatnr()); | 
|---|
|  |  |  | adjDetl.setAdjQty(locDetl.getAnfme()); | 
|---|
|  |  |  | adjDetlService.save(adjDetl, userId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void locClampOut(StockOutParam param, Long userId) { | 
|---|
|  |  |  | // 目标站点状态检测 | 
|---|
|  |  |  | BasDevp staNo = basDevpService.checkSiteStatus(param.getOutSite()); | 
|---|
|  |  |  | // 获取库位明细 | 
|---|
|  |  |  | List<LocDetlDto> locDetlDtos = new ArrayList<>(); | 
|---|
|  |  |  | for (StockOutParam.LocDetl paramLocDetl : param.getLocDetls()) { | 
|---|
|  |  |  | if (!Cools.isEmpty(paramLocDetl.getLocNo(), paramLocDetl.getMatnr(), paramLocDetl.getCount())) { | 
|---|
|  |  |  | LocDetl one = locDetlService.selectItem(paramLocDetl.getLocNo(), paramLocDetl); | 
|---|
|  |  |  | if (null != one) locDetlDtos.add(new LocDetlDto(one, paramLocDetl.getCount())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!locDetlDtos.isEmpty()) { | 
|---|
|  |  |  | LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", locDetlDtos.get(0).getLocDetl().getLocNo())); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | // 启动出库开始 107.盘点出库 | 
|---|
|  |  |  | clampOut(staNo, locDetlDtos, IoWorkType.CHECK_OUT, userId); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("所选库位存在状态不为F的库位,库位号:" + locMast.getLocNo() + " 、当前状态:" + locMast.getLocSts() + "-" + locMast.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("库位物料不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void clampOut(BasDevp staNo, List<LocDetlDto> locDetlDtos, IoWorkType ioWorkType, Long userId) { | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 合并同类项 | 
|---|
|  |  |  | Set<String> locNos = new HashSet<>(); | 
|---|
|  |  |  | List<OutLocDto> dtos = new ArrayList<>(); | 
|---|
|  |  |  | for (LocDetlDto locDetlDto : locDetlDtos) { | 
|---|
|  |  |  | String locNo = locDetlDto.getLocDetl().getLocNo(); | 
|---|
|  |  |  | if (locNos.contains(locNo)) { | 
|---|
|  |  |  | for (OutLocDto dto : dtos) { | 
|---|
|  |  |  | if (dto.getLocNo().equals(locNo)) { | 
|---|
|  |  |  | dto.getLocDetlDtos().add(locDetlDto); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | locNos.add(locNo); | 
|---|
|  |  |  | dtos.add(new OutLocDto(locNo, locDetlDto)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Integer ioType = null; | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | for (OutLocDto dto : dtos) { | 
|---|
|  |  |  | ioType = 104; | 
|---|
|  |  |  | assert ioType != null; | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(dto.getLocNo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer outSta = staNo.getDevNo(); | 
|---|
|  |  |  | // 获取路径 | 
|---|
|  |  |  | StaDesc staDesc = staDescService.queryCrnStn(ioType, locMast.getCrnNo(), outSta); | 
|---|
|  |  |  | // 生成工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(ioType)); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(11L); // 工作状态:11.生成出库ID | 
|---|
|  |  |  | wrkMast.setIoType(ioType); // 入出库状态 | 
|---|
|  |  |  | wrkMast.setIoPri(13D); // 优先级:13 | 
|---|
|  |  |  | wrkMast.setCrnNo(locMast.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setSourceStaNo(staDesc.getCrnStn()); // 源站 | 
|---|
|  |  |  | wrkMast.setStaNo(staDesc.getStnNo()); // 目标站 | 
|---|
|  |  |  | wrkMast.setSourceLocNo(dto.getLocNo()); // 源库位 | 
|---|
|  |  |  | wrkMast.setFullPlt("Y"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("N"); // 空板 | 
|---|
|  |  |  | wrkMast.setLinkMis("N"); | 
|---|
|  |  |  | wrkMast.setBarcode(locMast.getBarcode()); | 
|---|
|  |  |  | wrkMast.setAppeUser(userId); // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(userId); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | if (!wrkMastService.insert(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败,出库库位号:" + dto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 生成工作档明细 | 
|---|
|  |  |  | for (LocDetlDto detlDto : dto.getLocDetlDtos()) { | 
|---|
|  |  |  | if (detlDto.getCount() == null || detlDto.getCount() <= 0.0D) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WrkDetl wrkDetl = new WrkDetl(); | 
|---|
|  |  |  | wrkDetl.sync(detlDto.getLocDetl()); | 
|---|
|  |  |  | wrkDetl.setOrderNo(""); // 手动出库不需要带出库存中的单据编号 | 
|---|
|  |  |  | wrkDetl.setWrkNo(workNo); | 
|---|
|  |  |  | wrkDetl.setIoTime(now); | 
|---|
|  |  |  | Double anfme = ioType == 101 ? detlDto.getLocDetl().getAnfme() : detlDto.getCount(); | 
|---|
|  |  |  | wrkDetl.setAnfme(anfme); // 数量 | 
|---|
|  |  |  | wrkDetl.setAppeTime(now); | 
|---|
|  |  |  | wrkDetl.setAppeUser(userId); | 
|---|
|  |  |  | wrkDetl.setModiTime(now); | 
|---|
|  |  |  | wrkDetl.setModiUser(userId); | 
|---|
|  |  |  | if (!wrkDetlService.insert(wrkDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改库位状态:   F.在库 ====>>> R.出库预约/P.拣料/盘点/并板出库中 | 
|---|
|  |  |  | locMast = locMastService.selectById(dto.getLocNo()); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | locMast.setLocSts(ioType == 101 ? "R" : "P"); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("预约库位状态失败,库位号:" + dto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(dto.getLocNo() + "库位不是在库状态"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|