From e4ea838c20e94dff4fdbb4f82b542a8b5790fa9d Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期五, 18 六月 2021 09:22:06 +0800
Subject: [PATCH] # 库存跳转上报erp

---
 src/main/java/zy/cloud/wms/common/service/erp/ErpService.java |   58 ++++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 46 insertions(+), 12 deletions(-)

diff --git a/src/main/java/zy/cloud/wms/common/service/erp/ErpService.java b/src/main/java/zy/cloud/wms/common/service/erp/ErpService.java
index 18c5c8a..4404926 100644
--- a/src/main/java/zy/cloud/wms/common/service/erp/ErpService.java
+++ b/src/main/java/zy/cloud/wms/common/service/erp/ErpService.java
@@ -3,13 +3,18 @@
 import com.alibaba.fastjson.JSON;
 import com.core.common.Cools;
 import com.core.common.DateUtils;
-import com.core.common.SnowflakeIdWorker;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import zy.cloud.wms.common.model.BillDto;
 import zy.cloud.wms.common.service.erp.entity.UploadBill;
 import zy.cloud.wms.common.service.erp.entity.UploadBillDetail;
-import zy.cloud.wms.manager.entity.Comb;
+import zy.cloud.wms.manager.entity.DocType;
+import zy.cloud.wms.manager.entity.Mat;
+import zy.cloud.wms.manager.entity.RequestLog;
+import zy.cloud.wms.manager.service.DocTypeService;
+import zy.cloud.wms.manager.service.MatService;
+import zy.cloud.wms.manager.service.RequestLogService;
 import zy.cloud.wms.manager.utils.HttpHandler;
 
 import java.util.ArrayList;
@@ -24,32 +29,48 @@
 public class ErpService {
 
     @Autowired
-    private SnowflakeIdWorker snowflakeIdWorker;
-
+    private DocTypeService docTypeService;
+    @Autowired
+    private MatService matService;
+    @Autowired
+    private RequestLogService requestLogService;
     /**
      * 鍗曟嵁涓婃姤
      */
-    public Boolean uploadBill(List<Comb> combs, Integer docId, String docNumber){
+    public Boolean uploadBill(List<BillDto> dtos, Integer docId, String docNumber){
         try {
-            if (Cools.isEmpty(combs)) {
+            if (Cools.isEmpty(dtos)) {
                 return false;
             }
+            DocType docType = docTypeService.selectById(docId);
+            if (Cools.isEmpty(docType)) {
+                return false;
+            }
+
             UploadBill uploadBill = new UploadBill();
             uploadBill.setNumber(docNumber);
             uploadBill.setBillDate(DateUtils.convert(new Date(), DateUtils.yyyyMMdd_F));
-            uploadBill.setBTypeID("瀹忔尯瀹㈡埛");
+            uploadBill.setBTypeID("SHHT");
             uploadBill.setKTypeID("瀹忔尯浠撳簱");
             uploadBill.setVchType(docId);
+            if (docId == 9) {
+                uploadBill.setDifAtype(22);
+            } else if (docId == 14) {
+                uploadBill.setDifAtype(23);
+            }
+            uploadBill.setSummary(docType.getDocName() + " - " + DateUtils.convert(new Date(), "yyyy-MM-dd HH:mm"));
             List<UploadBillDetail> detail = new ArrayList<>();
             uploadBill.setDetail(detail);
-            for (Comb comb : combs) {
+            for (BillDto dto : dtos) {
+                Mat mat = matService.selectByMatnr(dto.getMatnr());
                 UploadBillDetail detl = new UploadBillDetail();
-                detl.setUserCode(comb.getMatnr());
-                detl.setQty(comb.getAnfme());
-                detl.setPrice(0.0D);
+                detl.setUserCode(dto.getMatnr());
+                detl.setQty(dto.getQty());
+                detl.setPrice(0);
+                detl.setUnit(mat==null?"鏆傛棤":mat.getUnit());
                 detail.add(detl);
             }
-            System.out.println(JSON.toJSONString(uploadBill));
+            log.warn(JSON.toJSONString(uploadBill));
             String response = new HttpHandler.Builder()
                     .setUri(ErpScheduler.URI)
                     .setPath(ErpScheduler.UPLOAD_BILL)
@@ -57,6 +78,19 @@
                     .build()
                     .doPost();
 
+            try {
+                // 鏃ュ織璁板綍
+                RequestLog logInfo = new RequestLog();
+                logInfo.setName("鍗曟嵁涓婁紶锛屽崟鎹被鍨�" + docId.toString());
+                logInfo.setRequest(JSON.toJSONString(uploadBill)); // 鍏ュ弬
+                logInfo.setResponse(response); // 鍑哄弬
+                logInfo.setCreateTime(new Date());
+                requestLogService.insert(logInfo);
+            } catch (Exception e) {
+                log.error(e.getMessage());
+            }
+
+
             if (!Cools.isEmpty(response)) {
                 log.warn(response);
                 Result result = JSON.parseObject(response, Result.class);

--
Gitblit v1.9.1