From e5199245eb5304daf88b86621e829d5711788de8 Mon Sep 17 00:00:00 2001
From: zhangherong <571457620@qq.com>
Date: 星期一, 25 八月 2025 15:58:21 +0800
Subject: [PATCH] art: 物料拉动相关接口

---
 src/main/java/org/jeecg/modules/mes/service/impl/MesMaterialTransferRequestServiceImpl.java |  111 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 110 insertions(+), 1 deletions(-)

diff --git a/src/main/java/org/jeecg/modules/mes/service/impl/MesMaterialTransferRequestServiceImpl.java b/src/main/java/org/jeecg/modules/mes/service/impl/MesMaterialTransferRequestServiceImpl.java
index 18bdf44..6c20944 100644
--- a/src/main/java/org/jeecg/modules/mes/service/impl/MesMaterialTransferRequestServiceImpl.java
+++ b/src/main/java/org/jeecg/modules/mes/service/impl/MesMaterialTransferRequestServiceImpl.java
@@ -1,18 +1,127 @@
 package org.jeecg.modules.mes.service.impl;
 
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.jeecg.common.constant.CommonConstant;
+import org.jeecg.common.exception.JeecgBootException;
+import org.jeecg.modules.base.entity.LineSideWarehouse;
+import org.jeecg.modules.base.service.ILineSideWarehouseService;
 import org.jeecg.modules.mes.entity.MesMaterialTransferRequest;
+import org.jeecg.modules.mes.entity.MesProductionWorkOrder;
+import org.jeecg.modules.mes.enums.MaterialTransferPublishStatus;
+import org.jeecg.modules.mes.enums.MaterialTransferRequestStatus;
+import org.jeecg.modules.mes.enums.ProductionWorkOrderStatus;
 import org.jeecg.modules.mes.mapper.MesMaterialTransferRequestMapper;
 import org.jeecg.modules.mes.service.IMesMaterialTransferRequestService;
+import org.jeecg.modules.mes.service.IMesProductionWorkOrderService;
+import org.jeecg.modules.sap.dto.MaterialRequestDTO;
+import org.jeecg.modules.sap.request.MaterialRequest;
+import org.jeecg.modules.sap.service.OrderMaterialRequestService;
+import org.jeecg.modules.wms.dto.WSResponse;
+import org.jeecg.modules.wms.request.WebReservationOrder;
+import org.jeecg.modules.wms.service.WMSWebServiceClient;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.*;
 
 /**
  * @Description: 鐗╂枡鎷夊姩鐢宠
  * @Author: jeecg-boot
- * @Date:   2025-07-04
+ * @Date: 2025-07-04
  * @Version: V1.0
  */
 @Service
 public class MesMaterialTransferRequestServiceImpl extends ServiceImpl<MesMaterialTransferRequestMapper, MesMaterialTransferRequest> implements IMesMaterialTransferRequestService {
 
+    @Autowired
+    private IMesProductionWorkOrderService productionWorkOrderService;
+    @Autowired
+    private OrderMaterialRequestService orderMaterialRequestService;
+    @Autowired
+    private ILineSideWarehouseService lineSideWarehouseService;
+    @Autowired
+    private WMSWebServiceClient wmsWebServiceClient;
+
+    @Override
+    public List<MesMaterialTransferRequest> queryMaterialTransferRequestByWorkOrderId(String workOrderId) {
+        return baseMapper.queryMaterialTransferRequestByWorkOrderId(workOrderId);
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean addMaterialTransferRequest(MesMaterialTransferRequest request) {
+        MesProductionWorkOrder order = productionWorkOrderService.getById(request.getWorkOrderId());
+        if (order == null) {
+            throw new JeecgBootException("鎺掍骇宸ュ崟涓嶅瓨鍦�");
+        }
+        if (!ProductionWorkOrderStatus.PUBLISHED.name().equals(order.getWorkOrderStatus())) {
+            throw new JeecgBootException("鍙湁鍙戝竷鐘舵�佺殑鎺掍骇宸ュ崟鎵嶅彲鐢宠鐗╂枡");
+        }
+        request.setPublishStatus(MaterialTransferPublishStatus.WAIT_PUBLISH.name());
+        request.setRequestStatus(MaterialTransferRequestStatus.WAIT_REQUEST.name());
+        request.setDelFlag(CommonConstant.DEL_FLAG_0);
+        this.getBaseMapper().insert(request);
+        return true;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean publish(String id) {
+        MesMaterialTransferRequest entity = super.getById(id);
+        if (entity == null) {
+            throw new JeecgBootException("鏁版嵁涓嶅瓨鍦紝璇峰埛鏂伴噸璇曪紒");
+        }
+        if (!MaterialTransferPublishStatus.WAIT_PUBLISH.name().equals(entity.getPublishStatus())) {
+            throw new JeecgBootException("鏁版嵁宸插彂甯冿紒");
+        }
+        LineSideWarehouse warehouse = lineSideWarehouseService.getById(entity.getTargetWarehouseId());
+        if (warehouse == null) {
+            throw new JeecgBootException("绾胯竟搴撲笉瀛樺湪锛�");
+        }
+        MaterialRequest request = new MaterialRequest();
+        request.setMaterialNumber(entity.getMaterialNumber());
+        request.setQuantity(request.getQuantity());
+        request.setWarehouseCode(entity.getOriginalWarehouseId());
+        try {
+            Map<String, Object> response = orderMaterialRequestService.orderMaterialRequest("2301", warehouse.getWarehouseCode(), Collections.singletonList(request));
+            Object ztype = response.get("ztype");
+            if (!"S".equals(ztype)) {
+                throw new JeecgBootException("璋冪敤SAP璇锋眰棰勭暀鍙峰け璐ワ紒" + response.get("zmess"));
+            }
+            MaterialRequestDTO result = (MaterialRequestDTO) response.get("result");
+            entity.setReservationCode(result.getO_SAP_RESV());
+            entity.setPublishStatus(MaterialTransferPublishStatus.PUBLISHED.name());
+            entity.setPublishTime(new Date());
+            super.updateById(entity);
+            return true;
+        } catch (Exception e) {
+            throw new JeecgBootException("璋冪敤SAP璇锋眰棰勭暀鍙峰け璐ワ紒");
+        }
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean request(String id) {
+        MesMaterialTransferRequest entity = super.getById(id);
+        if (entity == null) {
+            throw new JeecgBootException("鏁版嵁涓嶅瓨鍦紝璇峰埛鏂伴噸璇曪紒");
+        }
+        if (!MaterialTransferPublishStatus.PUBLISHED.name().equals(entity.getPublishStatus()) || !MaterialTransferRequestStatus.WAIT_REQUEST.name().equals(entity.getRequestStatus())) {
+            throw new JeecgBootException("鏁版嵁鐘舵�佷笉鍙姹俉MS锛�");
+        }
+        WebReservationOrder request = new WebReservationOrder();
+        request.setFactoryCode("2301");
+        request.setReservationOrder(entity.getReservationCode());
+        request.setTotal(entity.getSpecifiedQuantity());
+        Map<String, Object> resultMap = wmsWebServiceClient.receiveReservation(request);
+        WSResponse result = (WSResponse)resultMap.get("result");
+        if("Y".equals(result.getErrorCode())) {
+            entity.setRequestStatus(MaterialTransferRequestStatus.REQUESTED.name());
+            entity.setRequestTime(new Date());
+            super.updateById(entity);
+            return true;
+        }
+        return false;
+    }
 }

--
Gitblit v1.9.3