MesServiceImpl.java 10.5 KB
package com.huaheng.api.mes.service;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.huaheng.api.general.service.ReceiptApiService;
import com.huaheng.api.mes.domain.MesTransferShipmentItem;
import com.huaheng.api.mes.domain.ProductReceiptDomain;
import com.huaheng.api.mes.domain.ProductReceiptItem;
import com.huaheng.common.constant.QuantityConstant;
import com.huaheng.common.exception.service.ServiceException;
import com.huaheng.common.utils.DateUtils;
import com.huaheng.common.utils.StringUtils;
import com.huaheng.framework.web.domain.AjaxResult;
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.material.service.MaterialService;
import com.huaheng.pc.receipt.receiptDetail.domain.ReceiptDetail;
import com.huaheng.pc.receipt.receiptHeader.domain.ReceiptHeader;
import com.huaheng.pc.receipt.receiptHeader.service.ReceiptHeaderService;
import com.huaheng.pc.shipment.shipmentDetail.domain.ShipmentDetail;
import com.huaheng.pc.shipment.shipmentDetail.service.ShipmentDetailService;
import com.huaheng.pc.shipment.shipmentHeader.domain.ShipmentHeader;
import com.huaheng.pc.shipment.shipmentHeader.mapper.ShipmentHeaderMapper;
import com.huaheng.pc.shipment.shipmentHeader.service.ShipmentHeaderService;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import javax.annotation.Resource;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

@Service
public class MesServiceImpl implements MesService {

    @Resource
    private ReceiptHeaderService receiptHeaderService;
    @Resource
    private MaterialService materialService;
    @Resource
    private ReceiptApiService receiptApiService;
    @Resource
    private ShipmentHeaderService shipmentHeaderService;
    @Resource
    private ShipmentDetailService shipmentDetailService;
    @Resource
    private ShipmentHeaderMapper shipmentHeaderMapper;

    @Override
    @Transactional(rollbackFor = Exception.class)
    public AjaxResult productReceiptAdd(ProductReceiptDomain domain) {
        LambdaQueryWrapper<ReceiptHeader> headerWrapper = Wrappers.lambdaQuery();
        headerWrapper.eq(ReceiptHeader::getReferCode, domain.getOrderNo());
        if (receiptHeaderService.count(headerWrapper) > 0) {
            return AjaxResult.success("成品入库单已存在,任务号:" + domain.getOrderNo());
        }

        com.huaheng.api.general.domain.ReceiptDomain receiptDomain = new com.huaheng.api.general.domain.ReceiptDomain();
        ReceiptHeader receiptHeader = new ReceiptHeader();
        receiptHeader.setWarehouseCode(QuantityConstant.DEFAULT_WAREHOUSE);
        receiptHeader.setCompanyCode(QuantityConstant.COMPANYCODE);
        receiptHeader.setReceiptType(domain.getOrderType());
        receiptHeader.setReferCode(domain.getOrderNo());
        receiptHeader.setQcFlag(domain.getQcFlag());
        receiptHeader.setMakerName(domain.getMakerName());
        receiptHeader.setPo(domain.getPo());
        receiptHeader.setOrderDate(DateUtils.parseDate(domain.getOrderDate()));
        receiptHeader.setSource(QuantityConstant.PLATFORM_MES);
        receiptDomain.setReceiptHeader(receiptHeader);

        List<ReceiptDetail> receiptDetails = new ArrayList<>();
        for (ProductReceiptItem item : domain.getItems()) {
            if (StringUtils.isEmpty(item.getSku())) {
                return AjaxResult.error("成品入库单明细物料编码不能为空");
            }
            if (item.getQuantity() == null || BigDecimal.ZERO.compareTo(item.getQuantity()) == 0) {
                return AjaxResult.error("成品入库单明细入库数量不能为空或为0,物料编码:" + item.getSku());
            }
            Material material = materialService.getMaterialByCode(item.getSku(), QuantityConstant.DEFAULT_WAREHOUSE);
            if (material == null) {
                return AjaxResult.error("物料不存在,物料编码:" + item.getSku());
            }
            ReceiptDetail receiptDetail = new ReceiptDetail();
            receiptDetail.setWarehouseCode(QuantityConstant.DEFAULT_WAREHOUSE);
            receiptDetail.setCompanyCode(QuantityConstant.COMPANYCODE);
            receiptDetail.setMaterialCode(item.getSku());
            receiptDetail.setMaterialName(item.getSkuName());
            receiptDetail.setMaterialSpec(item.getSkuSpec());
            receiptDetail.setMaterialUnit(item.getUom());
            receiptDetail.setLot(item.getLot());
            receiptDetail.setQty(item.getQuantity());
            receiptDetail.setReferCode(domain.getOrderNo());
            receiptDetail.setReferLineNum(item.getPoLine());
            receiptDetail.setAreaCode(item.getAreaCode());
            receiptDetail.setCtn(item.getCtn());
            receiptDetail.setManufactureDate(DateUtils.parseDate(item.getManufactureDate()));
            receiptDetails.add(receiptDetail);
        }
        receiptDomain.setReceiptDetails(receiptDetails);
        return receiptApiService.receipt(receiptDomain);
    }

    @Override
    @Transactional(rollbackFor = Exception.class)
    public AjaxResult transferShipment(List<MesTransferShipmentItem> items) {
        if (items == null || items.isEmpty()) {
            return AjaxResult.error("出库单明细列表为空");
        }
        Map<String, List<MesTransferShipmentItem>> groupMap = items.stream()
                .collect(Collectors.groupingBy(MesTransferShipmentItem::getMergeBillNo));
        for (Map.Entry<String, List<MesTransferShipmentItem>> entry : groupMap.entrySet()) {
            String mergeBillNo = entry.getKey();
            List<MesTransferShipmentItem> groupItems = entry.getValue();
            if (StringUtils.isEmpty(mergeBillNo)) {
                return AjaxResult.error("合并工单号不能为空");
            }
            if (shipmentHeaderService.lambdaQuery().eq(ShipmentHeader::getMesCode, mergeBillNo).count() > 0) {
                return AjaxResult.error("合并工单号已存在:" + mergeBillNo);
            }
            MesTransferShipmentItem first = groupItems.get(0);
            BigDecimal totalQty = BigDecimal.ZERO;
            for (MesTransferShipmentItem item : groupItems) {
                if (StringUtils.isEmpty(item.getMaterial())) {
                    return AjaxResult.error("物料编码不能为空");
                }
                if (item.getNumber() == null) {
                    return AjaxResult.error("需求数量不能为空,物料:" + item.getMaterial());
                }
                if (materialService.lambdaQuery().eq(Material::getCode, item.getMaterial()).count() == 0) {
                    return AjaxResult.error("物料不存在,物料编码:" + item.getMaterial());
                }
                totalQty = totalQty.add(item.getNumber());
            }
            ShipmentHeader shipmentHeader = new ShipmentHeader();
            String code = shipmentHeaderService.createCode(first.getBillType());
            shipmentHeader.setCode(code);
            shipmentHeader.setMesCode(mergeBillNo);
            shipmentHeader.setWarehouseCode(QuantityConstant.DEFAULT_WAREHOUSE);
            shipmentHeader.setCompanyCode(QuantityConstant.COMPANYCODE);
            shipmentHeader.setShipmentType(first.getBillType());
            shipmentHeader.setTotalQty(totalQty);
            shipmentHeader.setTotalLines(groupItems.size());
            shipmentHeader.setFirstStatus(QuantityConstant.SHIPMENT_HEADER_BUILD);
            shipmentHeader.setLastStatus(QuantityConstant.SHIPMENT_HEADER_BUILD);
            shipmentHeader.setOutWarehouseCode(first.getOutWarehouseCode());
            shipmentHeader.setInWarehouseCode(first.getInWarehouseCode());
            shipmentHeader.setBillType(first.getBillType());
            shipmentHeader.setMaterialType(first.getMaterialType());
            shipmentHeader.setIndadocno(first.getIndadocno());
            shipmentHeader.setApplyUserName(first.getApplyUserName());
            shipmentHeader.setDeptCode(first.getDeptCode());
            shipmentHeader.setProductionOrderNumber(first.getProductionOrderNumber());
            if ("1".equals(first.getOrderStatus())) {
                shipmentHeader.setUrgentFlag("1");
            }
            shipmentHeader.setCreatedBy(QuantityConstant.PLATFORM_MES);
            shipmentHeader.setLastUpdatedBy(QuantityConstant.PLATFORM_MES);
            if (!shipmentHeaderService.save(shipmentHeader)) {
                throw new ServiceException("新增出库单头表失败");
            }
            ShipmentHeader header = shipmentHeaderMapper.getByOrderHeader(mergeBillNo);
            if (header == null) {
                throw new ServiceException("新增出库单头表后查询失败");
            }
            List<ShipmentDetail> detailList = new ArrayList<>();
            for (MesTransferShipmentItem item : groupItems) {
                Material material = materialService.getMaterialByCode(item.getMaterial());
                if (material == null) {
                    throw new ServiceException("物料不存在,物料编码:" + item.getMaterial());
                }
                ShipmentDetail detail = new ShipmentDetail();
                detail.setShipmentId(header.getId());
                detail.setShipmentCode(header.getCode());
                detail.setMesCode(mergeBillNo);
                detail.setMaterialCode(item.getMaterial());
                detail.setMaterialName(material.getName());
                detail.setMaterialSpec(material.getSpec());
                detail.setMaterialUnit(material.getUnit());
                detail.setMaterialID(item.getCpMaterial());
                detail.setQty(item.getNumber());
                detail.setBatch(item.getProductionBatch());
                detail.setMesId(item.getMesId());
                detail.setOutLocationCode(item.getOutLocationCode());
                detail.setInLocationCode(item.getInLocationCode());
                detail.setWarehouseCode(QuantityConstant.DEFAULT_WAREHOUSE);
                detail.setCompanyCode(QuantityConstant.COMPANYCODE);
                detail.setInventorySts(QuantityConstant.GOOD);
                detail.setCreatedBy(QuantityConstant.PLATFORM_MES);
                detail.setLastUpdatedBy(QuantityConstant.PLATFORM_MES);
                detailList.add(detail);
            }
            if (!shipmentDetailService.saveBatch(detailList)) {
                throw new ServiceException("新增出库单明细失败");
            }
        }
        return AjaxResult.success("调拨出库单下发成功");
    }
}