package com.zy.asrs.service.impl; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.core.common.Cools; import com.core.common.DateUtils; import com.core.common.SnowflakeIdWorker; import com.core.exception.CoolException; import com.zy.asrs.entity.*; import com.zy.asrs.entity.enums.WKType; import com.zy.asrs.entity.param.*; import com.zy.asrs.entity.result.OpenOrderCompeteResult; import com.zy.asrs.entity.result.StockVo; import com.zy.asrs.entity.vo.OpenInventoryVo; import com.zy.asrs.mapper.TagMapper; import com.zy.asrs.service.*; import com.zy.asrs.utils.MatUtils; import com.zy.common.model.DetlDto; import com.zy.common.utils.NodeUtils; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.*; import java.util.stream.Collectors; /** * Created by vincent on 2022/4/9 */ @Slf4j @Service public class OpenServiceImpl implements OpenService { @Autowired private OrderService orderService; @Autowired private OrderDetlService orderDetlService; @Autowired private SnowflakeIdWorker snowflakeIdWorker; @Autowired private DocTypeService docTypeService; @Autowired private MatService matService; @Autowired private LocDetlService locDetlService; @Autowired private PackService packService; @Autowired private TagService tagService; @Autowired private TagMapper tagMapper; @Autowired private WrkMastService wrkMastService; @Autowired private WrkMastLogServiceImpl wrkMastLogService; @Autowired private WrkDetlLogServiceImpl wrkDetlLogService; @Override @Transactional public void pakinOrderCreate(OpenOrderPakinParam param) { Order order = orderService.selectByNo(param.getOrderNo()); if (!Cools.isEmpty(order) && order.getSettle() != 1) { throw new CoolException(param.getOrderNo() + "单据已有工作任务"); } if (!Cools.isEmpty(order)) { boolean orderNo = orderService.delete(new EntityWrapper().eq("order_no", param.getOrderNo())); boolean orderNo1 = orderDetlService.delete(new EntityWrapper().eq("order_no", param.getOrderNo())); } DocType docType = docTypeService.selectOrAdd(param.getOrderType(), Boolean.TRUE); Date now = new Date(); // 单据主档 order = new Order( String.valueOf(snowflakeIdWorker.nextId()), // 编号[非空] param.getOrderNo(), // 订单编号 param.getInboundDate(), // 单据日期 docType.getDocId(), // 单据类型 null, // 项目编号 param.getWarehouse(), //仓库 itemName null, // 调拨项目编号 param.getOriginWarehouse(), // 初始票据号 来源仓库 param.getDepartment(), // 票据号 null, // 客户编号 param.getSuppliers(), // 供应商 cstmrName null, // 联系方式 param.getUser(), // 制单人 null, // 合计金额 null, // 优惠率 null, // 优惠金额 null, // 销售或采购费用合计 null, // 实付金额 null, // 付款类型 param.getSalesman(), // 业务员 null, // 结算天数 null, // 邮费支付类型 null, // 邮费 null, // 付款时间 null, // 发货时间 param.getBusinessType(), // 物流名称 null, // 物流单号 1L, // 订单状态 1, // 状态 9527L, // 添加人员 now, // 添加时间 9527L, // 修改人员 now, // 修改时间 null // 备注 ); if (!orderService.insert(order)) { throw new CoolException("生成单据主档失败,请联系管理员"); } // 单据明细档 List list = new ArrayList<>(); List orderDetails = param.getOrderDetails(); for (DetlDto detail : orderDetails) { DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getAnfme(), detail.getFromOrderNo() , detail.getMark(), detail.getCustomer(), detail.getSuppName(), detail.getTemp1(), detail.getTemp2(), detail.getTemp3(), detail.getTemp4()); if (DetlDto.has(list, dto)) { DetlDto detlDto = DetlDto.find(list, dto.getMatnr(), dto.getBatch()); assert detlDto != null; detlDto.setAnfme(detlDto.getAnfme() + detail.getAnfme()); } else { list.add(dto); } } for (DetlDto detlDto : list) { Mat mat = matService.selectByMatnr(detlDto.getMatnr()); if (Cools.isEmpty(mat)) { throw new CoolException(detlDto.getMatnr() + "编号商品检索失败,请先添加商品"); } OrderDetl orderDetl = new OrderDetl(); orderDetl.sync(mat); orderDetl.setBatch(detlDto.getBatch()); orderDetl.setAnfme(detlDto.getAnfme()); orderDetl.setOrderId(order.getId()); orderDetl.setOrderNo(order.getOrderNo()); orderDetl.setCreateBy(9527L); orderDetl.setCreateTime(now); orderDetl.setUpdateBy(9527L); orderDetl.setUpdateTime(now); orderDetl.setStatus(1); orderDetl.setQty(0.0D); orderDetl.setThreeCode(detlDto.getOrderNo()); orderDetl.setSuppCode(detlDto.getFromOrderNo()); orderDetl.setMemo(detlDto.getMemo()); orderDetl.setManu(detlDto.getMark()); orderDetl.setSupp(detlDto.getSuppName()); //供应商 orderDetl.setSku(detlDto.getCustomer()); orderDetl.setTemp1(detlDto.getTemp1()); orderDetl.setTemp2(detlDto.getTemp2()); orderDetl.setTemp3(detlDto.getTemp3()); orderDetl.setTemp4(detlDto.getTemp4()); if (!orderDetlService.insert(orderDetl)) { throw new CoolException("生成单据明细失败,请联系管理员"); } } } @Override @Transactional public List pakinOrderComplete(OpenOrderCompleteParam param) { List results = new ArrayList<>(); if (!Cools.isEmpty(param) && !Cools.isEmpty(param.getOrderNo())) { // 指定订单 Order order = orderService.selectByNo(param.getOrderNo()); if (null != order) { OpenOrderCompeteResult result = new OpenOrderCompeteResult(); results.add(result); result.setOrderNo(order.getOrderNo()); result.setOrderTime(order.getOrderTime()); result.setOrderType(order.getDocType$()); List orderDetls = orderDetlService.selectByOrderId(order.getId()); for (OrderDetl orderDetl : orderDetls) { result.getOrderDetails().add(new DetlDto(orderDetl.getOrderNo(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getQty())); } if (order.getSettle() == 4L) { // 修改订单状态 4.完成 ===>> 6.已上报 if (!orderService.updateSettle(order.getId(), 6L, null)) { throw new CoolException("服务器内部错误,请联系管理员"); } } } } else { // 所有订单 List orders = orderService.selectList(new EntityWrapper().eq("settle", 4L)); for (Order order : orders) { OpenOrderCompeteResult result = new OpenOrderCompeteResult(); results.add(result); result.setOrderNo(order.getOrderNo()); result.setOrderTime(order.getOrderTime()); result.setOrderType(order.getDocType$()); List orderDetls = orderDetlService.selectByOrderId(order.getId()); for (OrderDetl orderDetl : orderDetls) { result.getOrderDetails().add(new DetlDto(orderDetl.getOrderNo(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getQty())); } // 修改订单状态 4.完成 ===>> 6.已上报 if (!orderService.updateSettle(order.getId(), 6L, null)) { throw new CoolException("服务器内部错误,请联系管理员"); } } } return results; } @Override @Transactional public void pakoutOrderCreate(OpenOrderPakoutParam param) { Order order = orderService.selectByNo(param.getOrderNo()); // 如果单据不存在则添加;如果单据存在,作业中无法修改,反之则修改单据 if (!Cools.isEmpty(order)) { if (order.getSettle() > 1L) { throw new CoolException(param.getOrderNo() + "正在出库,无法修改单据"); } orderService.remove(order.getId()); } DocType docType = docTypeService.selectOrAdd(param.getOrderType(), Boolean.FALSE); Date now = new Date(); // 单据主档 order = new Order( String.valueOf(snowflakeIdWorker.nextId()), // 编号[非空] param.getOrderNo(), // 订单编号 param.getInboundDate(), // 单据日期 docType.getDocId(), // 单据类型 null, // 项目编号 param.getWarehouse(), //仓库 itemName null, // 调拨项目编号 param.getOriginWarehouse(), // 初始票据号 来源仓库 param.getDepartment(), // 票据号 null, // 客户编号 param.getSuppliers(), // 供应商 cstmrName null, // 联系方式 param.getUser(), // 制单人 null, // 合计金额 null, // 优惠率 null, // 优惠金额 null, // 销售或采购费用合计 null, // 实付金额 null, // 付款类型 param.getSalesman(), // 业务员 null, // 结算天数 null, // 邮费支付类型 null, // 邮费 null, // 付款时间 null, // 发货时间 param.getBusinessType(), // 物流名称 null, // 物流单号 1L, // 订单状态 1, // 状态 9527L, // 添加人员 now, // 添加时间 9527L, // 修改人员 now, // 修改时间 null // 备注 ); if (!orderService.insert(order)) { throw new CoolException("生成单据主档失败,请联系管理员"); } // 单据明细档 List list = new ArrayList<>(); List orderDetails = param.getOrderDetails(); for (DetlDto detail : orderDetails) { DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getAnfme(), detail.getFromOrderNo() , detail.getMark(), detail.getCustomer(), detail.getSuppName(), detail.getTemp1(), detail.getTemp2(), detail.getTemp3(), detail.getTemp4()); if (DetlDto.has(list, dto)) { DetlDto detlDto = DetlDto.find(list, dto.getMatnr(), dto.getBatch()); assert detlDto != null; detlDto.setAnfme(detlDto.getAnfme() + detail.getAnfme()); } else { list.add(dto); } } for (DetlDto detlDto : list) { Mat mat = matService.selectByMatnr(detlDto.getMatnr()); if (Cools.isEmpty(mat)) { throw new CoolException(detlDto.getMatnr() + "编号商品检索失败,请先添加商品"); } OrderDetl orderDetl = new OrderDetl(); orderDetl.sync(mat); orderDetl.setBatch(detlDto.getBatch()); orderDetl.setAnfme(detlDto.getAnfme()); orderDetl.setOrderId(order.getId()); orderDetl.setOrderNo(order.getOrderNo()); orderDetl.setCreateBy(9527L); orderDetl.setCreateTime(now); orderDetl.setUpdateBy(9527L); orderDetl.setUpdateTime(now); orderDetl.setStatus(1); orderDetl.setQty(0.0D); orderDetl.setThreeCode(detlDto.getOrderNo()); orderDetl.setSuppCode(detlDto.getFromOrderNo()); orderDetl.setMemo(detlDto.getMemo()); orderDetl.setManu(detlDto.getMark()); orderDetl.setSupp(detlDto.getSuppName()); orderDetl.setSku(detlDto.getCustomer()); orderDetl.setTemp1(detlDto.getTemp1()); orderDetl.setTemp2(detlDto.getTemp2()); orderDetl.setTemp3(detlDto.getTemp3()); orderDetl.setTemp4(detlDto.getTemp4()); if (!orderDetlService.insert(orderDetl)) { throw new CoolException("生成单据明细失败,请联系管理员"); } } } @Override public List pakoutOrderComplete(OpenOrderCompleteParam param) { List results = new ArrayList<>(); if (!Cools.isEmpty(param) && !Cools.isEmpty(param.getOrderNo())) { // 指定订单 Order order = orderService.selectByNo(param.getOrderNo()); if (null != order) { OpenOrderCompeteResult result = new OpenOrderCompeteResult(); results.add(result); result.setOrderNo(order.getOrderNo()); result.setOrderTime(order.getOrderTime()); result.setOrderType(order.getDocType$()); List orderDetls = orderDetlService.selectByOrderId(order.getId()); for (OrderDetl orderDetl : orderDetls) { result.getOrderDetails().add(new DetlDto(orderDetl.getOrderNo(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getQty())); } if (order.getSettle() == 4L) { // 修改订单状态 4.完成 ===>> 6.已上报 if (!orderService.updateSettle(order.getId(), 6L, null)) { throw new CoolException("服务器内部错误,请联系管理员"); } } } } else { // 所有订单 List orders = orderService.selectList(new EntityWrapper().eq("settle", 4L)); for (Order order : orders) { OpenOrderCompeteResult result = new OpenOrderCompeteResult(); results.add(result); result.setOrderNo(order.getOrderNo()); result.setOrderTime(order.getOrderTime()); result.setOrderType(order.getDocType$()); List orderDetls = orderDetlService.selectByOrderId(order.getId()); for (OrderDetl orderDetl : orderDetls) { result.getOrderDetails().add(new DetlDto(orderDetl.getOrderNo(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getQty())); } // 修改订单状态 4.完成 ===>> 6.已上报 if (!orderService.updateSettle(order.getId(), 6L, null)) { throw new CoolException("服务器内部错误,请联系管理员"); } } } return results; } @Override @Transactional public List queryStock() { return locDetlService.queryStockTotal(); } @Override @Transactional public void packageUp(PackParam param) { if (Cools.isEmpty(param.getBarcode())) { throw new CoolException("barcode不能为空"); } Mat analyse = MatUtils.analyseMat(param.getBarcode()); Pack pack = packService.selectByBarcode(param.getBarcode()); if (null != pack) { throw new CoolException(param.getBarcode() + "重复提交"); } Date now = new Date(); pack = new Pack( param.getBarcode(), // 条码[非空] analyse.getMatnr(), // 商品编号 analyse.getBarcode(), // 序列码 1L, // 订单状态 1, // 状态 now, // 添加时间 null, // 添加人员 now, // 修改时间 null, // 修改人员 null // 备注 ); if (!packService.insert(pack)) { throw new CoolException("服务器内部错误,请联系管理员"); } Mat mat = matService.selectByMatnr(analyse.getMatnr()); if (mat == null) { mat = new Mat(); // 分类 Long tagId; // 一级分类 if (!Cools.isEmpty(param.getGroupCode()) && !Cools.isEmpty(param.getGroupName())) { Tag priTag = tagService.selectByName(param.getGroupCode(), 2); if (priTag == null) { Tag top = tagService.getTop(); NodeUtils nodeUtils = new NodeUtils(); nodeUtils.executePath(top.getId()); priTag = new Tag( null, // 编号 param.getGroupCode(), // 名称 top.getId(), // 父级 top.getName(), // 父级名称 nodeUtils.path.toString(), // 关联路径 nodeUtils.pathName.toString(), // 关联路径名 0, // 类型 null, // 负责人 null, // 图片 null, // 简要描述 null, // 数量 2, // 等级 null, // 排序 1, // 状态 now, // 添加时间 null, // 添加人员 now, // 修改时间 null, // 修改人员 null // 备注 ); if (tagMapper.insert(priTag) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } } // 二级分类 Tag secTag = tagService.selectByName(param.getGroupName(), 3); if (secTag == null) { NodeUtils nodeUtils = new NodeUtils(); nodeUtils.executePath(priTag.getId()); secTag = new Tag( null, // 编号 param.getGroupName(), // 名称 priTag.getId(), // 父级 priTag.getName(), // 父级名称 nodeUtils.path.toString(), // 关联路径 nodeUtils.pathName.toString(), // 关联路径名 0, // 类型 null, // 负责人 null, // 图片 null, // 简要描述 null, // 数量 3, // 等级 null, // 排序 1, // 状态 now, // 添加时间 null, // 添加人员 now, // 修改时间 null, // 修改人员 null // 备注 ); if (tagMapper.insert(secTag) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } } tagId = secTag.getId(); } else { tagId = tagService.getTop().getId(); } mat.setTagId(tagId); mat.setMatnr(analyse.getMatnr()); mat.setMaktx(param.getMaterialName()); mat.setSpecs(param.getConfigureDesc()); mat.setModel(analyse.getModel()); mat.setStatus(1); mat.setCreateTime(now); mat.setUpdateTime(now); if (!matService.insert(mat)) { throw new CoolException("服务器内部错误,请联系管理员"); } else { log.info("打包上线添加新物料[商品编号:{}]", mat.getMatnr()); } } } @Override @Transactional public void syncMat(MatSyncParam param) { if (Cools.isEmpty(param.getMatDetails()) || param.getMatDetails().size() <= 0) { throw new CoolException("商品数据为空"); } for (MatSyncParam.MatParam matParam : param.getMatDetails()) { if (Cools.isEmpty(matParam.getMatnr())) { throw new CoolException("商品编码不能为空"); } Date now = new Date(); Mat mat = matService.selectByMatnr(matParam.getMatnr()); if (mat == null) { mat = new Mat(); // 分类 Long tagId; // 一级分类 if (!Cools.isEmpty(matParam.getGroupCode()) && !Cools.isEmpty(matParam.getGroupName())) { Tag priTag = tagService.selectByName(matParam.getGroupCode(), 2); if (priTag == null) { Tag top = tagService.getTop(); NodeUtils nodeUtils = new NodeUtils(); nodeUtils.executePath(top.getId()); priTag = new Tag( null, // 编号 matParam.getGroupCode(), // 名称 top.getId(), // 父级 top.getName(), // 父级名称 nodeUtils.path.toString(), // 关联路径 nodeUtils.pathName.toString(), // 关联路径名 0, // 类型 null, // 负责人 null, // 图片 null, // 简要描述 null, // 数量 2, // 等级 null, // 排序 1, // 状态 now, // 添加时间 null, // 添加人员 now, // 修改时间 null, // 修改人员 null // 备注 ); if (tagMapper.insert(priTag) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } } // 二级分类 Tag secTag = tagService.selectByName(matParam.getGroupName(), 3); if (secTag == null) { NodeUtils nodeUtils = new NodeUtils(); nodeUtils.executePath(priTag.getId()); secTag = new Tag( null, // 编号 matParam.getGroupName(), // 名称 priTag.getId(), // 父级 priTag.getName(), // 父级名称 nodeUtils.path.toString(), // 关联路径 nodeUtils.pathName.toString(), // 关联路径名 0, // 类型 null, // 负责人 null, // 图片 null, // 简要描述 null, // 数量 3, // 等级 null, // 排序 1, // 状态 now, // 添加时间 null, // 添加人员 now, // 修改时间 null, // 修改人员 null // 备注 ); if (tagMapper.insert(secTag) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } } tagId = secTag.getId(); } else { tagId = tagService.getTop().getId(); } mat.sync(matParam); // mat.setMatnr(param.getMatnr()); // mat.setMaktx(param.getMaktx()); // mat.setSpecs(param.getSpecs()); // mat.setModel(param.getModel()); mat.setTagId(tagId); mat.setStatus(1); mat.setCreateTime(now); mat.setUpdateTime(now); if (!matService.insert(mat)) { throw new CoolException("服务器内部错误,请联系管理员"); } else { log.info("同步新物料[商品编号:{}]", mat.getMatnr()); } } else { mat.sync(matParam); if (!matService.update(mat, new EntityWrapper().eq("matnr", matParam.getMatnr()))) { throw new CoolException("更新已存在商品信息失败,请联系管理员"); } } } } @Override public List selectTimeLocDetl(TimeSelectParam param) { ArrayList locDetlByTimeDTOS = new ArrayList<>(); EntityWrapper wrkMastLogEntityWrapper = new EntityWrapper<>(); wrkMastLogEntityWrapper.ge("modi_time", param.getStartTime()); wrkMastLogEntityWrapper.le("modi_time", param.getEndTime()); // wrkMastLogEntityWrapper.isNotNull("sheet_no"); wrkMastLogService.selectList(wrkMastLogEntityWrapper).forEach(wrkMastLog -> { if (wrkMastLog.getWrkSts() == 5 || wrkMastLog.getWrkSts() == 15) { EntityWrapper wrkDetlLogEntityWrapper = new EntityWrapper<>(); wrkDetlLogEntityWrapper.eq("wrk_no", wrkMastLog.getWrkNo()); if (wrkMastLog.getIoType() != 300 && wrkMastLog.getIoType() != 301) { wrkDetlLogEntityWrapper.eq("zpallet", wrkMastLog.getBarcode()); } List wrkDetlLogs = wrkDetlLogService.selectList(wrkDetlLogEntityWrapper); wrkDetlLogs.forEach(wrkDetlLog -> { if (wrkDetlLog.getOrderNo() != null && !wrkDetlLog.getOrderNo().isEmpty()) { LocDetlByTimeDTO locDetlByTimeDTO = new LocDetlByTimeDTO(); if (!Cools.isEmpty(wrkDetlLog.getOrderNo())) { Order order = orderService.selectByNo(wrkDetlLog.getOrderNo()); if (!Cools.isEmpty(order)) { locDetlByTimeDTO.setDate(order.getOrderTime()); locDetlByTimeDTO.setWarehouse(order.getItemName()); locDetlByTimeDTO.setOrderType(order.getDocType$()); } locDetlByTimeDTO.setMatnr(wrkDetlLog.getMatnr()); locDetlByTimeDTO.setLocNo(wrkMastLog.getIoType() < 100 ? wrkMastLog.getLocNo() : wrkMastLog.getSourceLocNo()); locDetlByTimeDTO.setBatch(wrkDetlLog.getBatch()); locDetlByTimeDTO.setAnfme(wrkDetlLog.getAnfme()); locDetlByTimeDTO.setOrderNo(wrkDetlLog.getOrderNo()); locDetlByTimeDTO.setMark(wrkDetlLog.getManu()); locDetlByTimeDTO.setWorkNo(wrkDetlLog.getWrkNo().toString()); locDetlByTimeDTOS.add(locDetlByTimeDTO); } } }); } }); // if (!Cools.isEmpty(locDetls)) { // for (LocDetl locDetl : locDetls) { // // if (!Cools.isEmpty(locDetl.getOrderNo())){ // Order order = orderService.selectByNo(locDetl.getOrderNo()); // if (!Cools.isEmpty(order)) { // locDetlByTimeDTO.setDate(order.getOrderTime()); // locDetlByTimeDTO.setWarehouse(order.getItemName()); // locDetlByTimeDTO.setOrderType(order.getDocType().toString()); // } // } // // locDetlByTimeDTO.setMatnr(locDetl.getMatnr()); // locDetlByTimeDTO.setLocNo(locDetl.getLocNo()); // locDetlByTimeDTO.setBatch(locDetl.getBatch()); // locDetlByTimeDTO.setAnfme(locDetl.getAnfme()); // locDetlByTimeDTO.setOrderNo(locDetl.getOrderNo()); // locDetlByTimeDTOS.add(locDetlByTimeDTO); // } // } return locDetlByTimeDTOS; } @Override @Transactional public boolean agvHaiKang(String wrkNo) { WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper().eq("wrk_no", Long.parseLong(wrkNo))); wrkMast.setWrkSts(wrkMast.getWrkStsComplete()); wrkMastService.updateById(wrkMast); return true; } @Override @Transactional public void syncTag(List param) { param.forEach(tag -> { // 分类 Long tagId; Date now = new Date(); if (Cools.isEmpty(tag.getParentItemClassId())) { Tag priTag = tagService.selectByName("全部", 1); // 二级分类 Tag secTag = tagService.selectByName(tag.getName(), 2); if (secTag == null) { NodeUtils nodeUtils = new NodeUtils(); nodeUtils.executePath(priTag.getId()); secTag = new Tag( null, // 编号 tag.getName(), // 名称 priTag.getId(), // 父级 priTag.getName(), // 父级名称 nodeUtils.path.toString(), // 关联路径 nodeUtils.pathName.toString(), // 关联路径名 0, // 类型 null, // 负责人 null, // 图片 null, // 简要描述 null, // 数量 2, // 等级 null, // 排序 1, // 状态 now, // 添加时间 null, // 添加人员 now, // 修改时间 null, // 修改人员 tag.getItemClassId() // 备注 ); if (tagMapper.insert(secTag) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } } } else { Tag priTag = tagService.selectOne(new EntityWrapper().eq("memo", tag.getParentItemClassId())); if (priTag == null) { Tag top = tagService.getTop(); NodeUtils nodeUtils = new NodeUtils(); nodeUtils.executePath(top.getId()); priTag = new Tag( null, // 编号 tag.getParentName(), // 名称 top.getId(), // 父级 top.getName(), // 父级名称 nodeUtils.path.toString(), // 关联路径 nodeUtils.pathName.toString(), // 关联路径名 0, // 类型 null, // 负责人 null, // 图片 null, // 简要描述 null, // 数量 2, // 等级 null, // 排序 1, // 状态 now, // 添加时间 null, // 添加人员 now, // 修改时间 null, // 修改人员 tag.getParentItemClassId() // 备注 ); if (tagMapper.insert(priTag) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } } // 二级分类 Tag secTag = tagService.selectOne(new EntityWrapper().eq("memo", tag.getItemClassId())); NodeUtils nodeUtils = new NodeUtils(); nodeUtils.executePath(priTag.getId()); if (secTag == null) { secTag = new Tag( null, // 编号 tag.getName(), // 名称 priTag.getId(), // 父级 priTag.getName(), // 父级名称 nodeUtils.path.toString(), // 关联路径 nodeUtils.pathName.toString(), // 关联路径名 0, // 类型 null, // 负责人 null, // 图片 null, // 简要描述 null, // 数量 2, // 等级 null, // 排序 1, // 状态 now, // 添加时间 null, // 添加人员 now, // 修改时间 null, // 修改人员 tag.getItemClassId() // 备注 ); if (tagMapper.insert(secTag) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } } else { secTag.setName(tag.getName()); secTag.setParentId(priTag.getId()); secTag.setParentName(priTag.getName()); secTag.setPath(nodeUtils.path.toString()); secTag.setPathName(nodeUtils.pathName.toString()); if (tagMapper.updateById(secTag) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } List tags = tagService.selectList(new EntityWrapper().eq("parent_id", secTag.getId())); if (!Cools.isEmpty(tags)) { for (Tag tag1 : tags) { tag1.setPath(nodeUtils.path.toString() + "," + secTag.getId()); tag1.setPathName(nodeUtils.pathName.toString() + "," + secTag.getName()); if (tagMapper.updateById(tag1) == 0) { throw new CoolException("服务器内部错误,请联系管理员"); } } } } } }); } @Transactional @Override public void orderDelete(String orderNo) { Order order = orderService.selectByNo(orderNo); if (order == null) { throw new CoolException("未查询到对应订单信息"); } if (order.getSettle() != 1) { throw new CoolException("该订单已有对应任务,禁止删除"); } List OrderDetl = orderDetlService.selectList(new EntityWrapper().eq("order_no", orderNo)); if (!Cools.isEmpty(OrderDetl)) { orderDetlService.delete(new EntityWrapper().eq("order_no", orderNo)); } orderService.delete(new EntityWrapper().eq("order_no", orderNo)); } /** * 入/出库通知单下发 * * @param param */ @Override @Transactional public void orderCreate(OpenOrderParam param) { Order order = orderService.selectByNo(param.getOrderNo()); if (!Cools.isEmpty(order)) { throw new CoolException(param.getOrderNo() + "订单已存在,请勿重复创建"); } Date now = new Date(); order = new Order( String.valueOf(snowflakeIdWorker.nextId()), // 编号[非空] param.getOrderNo(), // 订单编码[非空] DateUtils.convert(now), //单据日期 WKType.query(param.getWkType()).wkType, //单据类型 null, //项目编号 null, //项目名称 客户PO号 null, //调拨项目编号 null, //初始票据号 null, //票据号 null, //客户编号 null, //客户 param.getOrderInternalCode(), //单据内码 null, //操作人员 null, //合计金额 null, //优惠率 null, //优惠金额 null, //销售或采购费用合计 null, //实付金额 null, //付款类型 1: 现金 2: 记账 null, //业务员 null, //结算天数 null, //邮费支付类型 1: 在线支付 2: 货到付款 null, //邮费 param.getBusinessTime(), //业务日期 param.getCreateTime(), //创建日期 null, //物流名称 null, //物流单号 1L, //订单状态 1, //状态 1: 正常 0: 禁用 9527L, //添加人员 now, //添加时间 9527L, //修改人员 now, //修改时间 param.getStationId(), //入/出库接驳站点 param.getOperateType(), // 操作类型 1.新增 2.修改 3.取消 param.getOrderType() // 订单类型 1 出库单 2 入库单 3 调拨单 ); if (!orderService.insert(order)) { throw new CoolException("保存订单主档失败,请联系管理员!" + order); } List list = new ArrayList<>(); List orderItems = param.getOrderItems(); for (OpenOrderParam.OrderItem item : orderItems) { OpenOrderParam.OrderItem orderItem = new OpenOrderParam.OrderItem( item.getLineId(), item.getMatNr(), item.getMakTx(), item.getAnfme(), item.getSpec(), item.getModel(), item.getUnit(), item.getBatch(), item.getPalletId(), item.getPlanNo(), item.getTargetWareHouseId(), item.getSourceWareHouseId() ); if (OpenOrderParam.OrderItem.hasLineNumber(list, orderItem)) { OpenOrderParam.OrderItem oi = OpenOrderParam.OrderItem.findLineNumber( list, item.getLineId(), item.getMatNr(), item.getMakTx(), item.getAnfme(), item.getSpec(), item.getModel(), item.getUnit(), item.getBatch(), item.getPalletId(), item.getPlanNo(), item.getTargetWareHouseId(), item.getSourceWareHouseId() ); assert oi != null; oi.setAnfme(oi.getAnfme() + orderItem.getAnfme()); } else { list.add(orderItem); } } for (OpenOrderParam.OrderItem orderItem : list) { Mat mat = matService.selectByMatnr(orderItem.getMatNr()); if (Cools.isEmpty(mat)) { throw new CoolException("订单明细中的商品编号不存在:" + orderItem.getMatNr()); } OrderDetl orderDetl = new OrderDetl(); orderDetl.sync(mat); orderDetl.setOrderNo(order.getOrderNo()); // 订单编号 orderDetl.setOrderId(order.getId()); // 订单内码 orderDetl.setStandby1(order.getTel()); // 行内码 唯一标识 orderDetl.setAnfme(orderItem.getAnfme()); // 订单数量 orderDetl.setBatch(orderItem.getBatch()); // 批次 orderDetl.setStandby2(orderItem.getPalletId()); // 托盘码 orderDetl.setStandby3(orderItem.getPlanNo()); // 计划跟踪号 orderDetl.setBoxType1(orderItem.getSourceWareHouseId()); // 建议入库仓库 orderDetl.setBoxType2(orderItem.getTargetWareHouseId()); // 建议出库仓库 orderDetl.setCreateBy(9527L); orderDetl.setCreateTime(now); orderDetl.setUpdateBy(9527L); orderDetl.setUpdateTime(now); orderDetl.setStatus(1); orderDetl.setQty(0.0D); // orderDetl.setPakinPakoutStatus(1); if (!orderDetlService.insert(orderDetl)) { throw new CoolException("保存订单明细失败,请联系管理员!" + orderDetl); } } } }