From 78a59eda850857e1bfeb48541f0c64d442877a4d Mon Sep 17 00:00:00 2001
From: lty <876263681@qq.com>
Date: 星期二, 08 四月 2025 11:17:10 +0800
Subject: [PATCH] #实现pda简单入库出库操作

---
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java |  193 ++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 184 insertions(+), 9 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
index e6aef59..6a7aeae 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -1,30 +1,30 @@
 package com.zy.asrs.service.impl;
 
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
+import com.core.common.BaseRes;
 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.param.OpenOrderCompleteParam;
-import com.zy.asrs.entity.param.OpenOrderPakinParam;
-import com.zy.asrs.entity.param.OpenOrderPakoutParam;
-import com.zy.asrs.entity.param.PackParam;
+import com.zy.asrs.entity.param.*;
 import com.zy.asrs.entity.result.OpenOrderCompeteResult;
 import com.zy.asrs.entity.result.StockVo;
+import com.zy.asrs.mapper.ReportQueryMapper;
 import com.zy.asrs.mapper.TagMapper;
 import com.zy.asrs.service.*;
+import com.zy.asrs.task.core.ReturnT;
+import com.zy.asrs.task.handler.WorkLogHandler;
 import com.zy.asrs.utils.MatUtils;
 import com.zy.common.model.DetlDto;
+import com.zy.common.utils.ListUtils;
 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.ArrayList;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
 
 /**
  * Created by vincent on 2022/4/9
@@ -51,6 +51,14 @@
     private TagService tagService;
     @Autowired
     private TagMapper tagMapper;
+    @Autowired
+    private ApiLogService apiLogService;
+    @Autowired
+    private WaitPakinService waitPakinService;
+    @Autowired
+    private WrkDetlService wrkDetlService;
+    @Autowired
+    private ReportQueryMapper reportQueryMapper;
 
     @Override
     @Transactional
@@ -337,7 +345,7 @@
         Date now = new Date();
         pack = new Pack(
                 param.getBarcode(),    // 鏉$爜[闈炵┖]
-                analyse.getMatnr(),    // 鍗曟嵁鍙�
+                analyse.getMatnr(),    // 鐗╂枡鍙�
                 analyse.getBarcode(),    // 搴忓垪鐮�
                 1L,    // 璁㈠崟鐘舵��
                 1,    // 鐘舵��
@@ -433,9 +441,176 @@
             if (!matService.insert(mat)) {
                 throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
             } else {
-                log.info("鎵撳寘涓婄嚎娣诲姞鏂扮墿鏂橻鍗曟嵁鍙凤細{}]", mat.getMatnr());
+                log.info("鎵撳寘涓婄嚎娣诲姞鏂扮墿鏂橻鐗╂枡鍙凤細{}]", mat.getMatnr());
             }
         }
     }
+    @Override
+    @Transactional
+    public MatSyncParam syncMat(MatSyncParam param) {
+        if (Cools.isEmpty(param.getMats()) || param.getMats().size() <=0 ) {
+            throw new CoolException("鍟嗗搧鏁版嵁涓虹┖");
+        }
+        MatSyncParam matSyncParam = new MatSyncParam();
+        ArrayList<MatSyncParam.Mats> matParams = new ArrayList<>();
+        Tag tag = tagService.selectByName("鍏ㄩ儴", 1);
+        for (MatSyncParam.Mats matParam : param.getMats()){
+            Date date = new Date();
+            Mat mat = matService.selectByMatnr(matParam.getMatnr());
+            if (Cools.isEmpty(mat)) {
+                Mat matNew = new Mat();
+                matNew.setTagId(tag.getId());
+                matNew.setMatnr(matParam.getMatnr());//鐗╂枡缂栫爜
+                matNew.setMaktx(matParam.getMaktx());//鐗╂枡鍚嶇О
+                matNew.setSpecs(matParam.getSpecs());//瑙勬牸
+                matNew.setModel(matParam.getModel());//鍨嬪彿
+                matNew.setColor(matParam.getColor());//棰滆壊
+                matNew.setUnit(matParam.getUnit());//鍗曚綅
+                matNew.setMemo(matParam.getMemo());//澶囨敞
+                matNew.setCreateBy(9999L);//9999琛ㄧずerp涓嬪彂
+                matNew.setCreateTime(date);
+                matNew.setUpdateBy(9999L);//9999琛ㄧずerp涓嬪彂
+                matNew.setUpdateTime(date);
+                if (matService.insert(matNew)) {
+                    callApiLogSave(matParam, "/open/asrs/mat/v1", "鎺ユ敹ERP涓嬪彂鍟嗗搧淇℃伅鎴愬姛锛佹坊鍔犲晢鍝佷俊鎭垚鍔燂紒", true);
+                    matParam.setType(true);
+                } else {
+                    callApiLogSave(matParam, "/open/asrs/mat/v1", "娣诲姞ERP涓嬪彂鍟嗗搧淇℃伅澶辫触锛侊紒锛佺姸鎬佸紓甯革紒锛侊紒", false);
+                    matParam.setType(false);
+                    matParam.setMemo("娣诲姞ERP涓嬪彂鍟嗗搧淇℃伅澶辫触锛�");
+                }
+            } else {
+                callApiLogSave(matParam, "/open/asrs/mat/v1", "鎺ユ敹ERP涓嬪彂鍟嗗搧淇℃伅澶辫触锛侊紒锛佸晢鍝佸凡瀛樺湪锛侊紒锛�", false);
+                matParam.setType(false);
+                matParam.setMemo("鍟嗗搧宸插瓨鍦紒");
+            }
+            matParams.add(matParam);
+        }
+        matSyncParam.setMats(matParams);
+        return matSyncParam;
+    }
+    public void callApiLogSave(MatSyncParam.Mats matParam, String tableName, String response, Boolean bool) {
+        apiLogService.save("ERP涓嬪彂鍟嗗搧淇℃伅", tableName, "null", "10.10.10.1",
+                "鐗╂枡缂栫爜锛�" + matParam.getMatnr() + "銆佺墿鏂欏悕绉帮細" + matParam.getMaktx() + "銆佽鏍硷細" + matParam.getSpecs() + "銆佸娉細" + matParam.getMemo(),
+                response, bool);
+    }
+
+
+    @Override
+    @Transactional
+    public void combMes(CombParam param) {
+        Long userId=9999l;
+        if (Cools.isEmpty(param.getBarcode(), param.getCombMats())) {
+            callApiLogSaveMES(null, null, BaseRes.PARAM, false);
+            throw new CoolException(BaseRes.PARAM);
+        }
+        if(param.getBarcode().length()!=8){
+            callApiLogSaveMES(param, null, param.getBarcode() + "锛氭潯鐮侀暱搴︿笉鏄�8浣�", false);
+            throw new CoolException("鏉$爜闀垮害涓嶆槸8浣�===>>" + param.getBarcode());
+        }
+        // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁
+        if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>().
+                eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) {
+            callApiLogSaveMES(param, null, param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱", false);
+            throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱");
+        }
+
+        int countLoc = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet",param.getBarcode()));
+        int countWrk = wrkDetlService.selectCount(new EntityWrapper<WrkDetl>().eq("zpallet",param.getBarcode()));
+        if (countLoc > 0) {
+            callApiLogSaveMES(param, null, param.getBarcode() + "锛氬簱瀛樻潯鐮佹暟鎹凡瀛樺湪", false);
+            throw new CoolException("搴撳瓨鏉$爜鏁版嵁宸插瓨鍦�===>>" + param.getBarcode());
+        }else if (countWrk > 0){
+            callApiLogSaveMES(param, null, param.getBarcode() + "锛氬伐浣滄槑缁嗘。宸插瓨鍦ㄦ鏁版嵁", false);
+            throw new CoolException("宸ヤ綔鏄庣粏妗e凡瀛樺湪姝ゆ暟鎹�===>>" + param.getBarcode());
+        }
+
+        Date now = new Date();
+        try{
+            // 鐢熸垚鍏ュ簱閫氱煡妗�
+            List<DetlDto> detlDtos = new ArrayList<>();
+            param.getCombMats().forEach(elem -> {
+                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme());
+                if (DetlDto.has(detlDtos, detlDto)) {
+                    DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch());
+                    assert one != null;
+                    one.setAnfme(one.getAnfme() + detlDto.getAnfme());
+                } else {
+                    detlDtos.add(detlDto);
+                }
+            });
+
+            for (DetlDto detlDto : detlDtos) {
+                Mat mat = matService.selectByMatnr(detlDto.getMatnr());
+                if (Cools.isEmpty(mat)) {
+                    callApiLogSaveMES(param, null,mat.getMatnr()+"鍟嗗搧妗f涓嶅瓨鍦�", false);
+                    throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�");
+                }
+                WaitPakin waitPakin = new WaitPakin();
+                waitPakin.sync(mat);
+                waitPakin.setBatch(detlDto.getBatch());
+                waitPakin.setZpallet(param.getBarcode());   // 鎵樼洏鐮�
+                waitPakin.setIoStatus("N");     // 鍏ュ嚭鐘舵��
+                waitPakin.setAnfme(detlDto.getAnfme());  // 鏁伴噺
+                waitPakin.setStatus("Y");    // 鐘舵��
+                waitPakin.setAppeUser(userId);
+                waitPakin.setAppeTime(now);
+                waitPakin.setModiUser(userId);
+                waitPakin.setModiTime(now);
+                if (!waitPakinService.insert(waitPakin)) {
+                    callApiLogSaveMES(param, null,mat.getMatnr()+"淇濆瓨鍏ュ簱閫氱煡妗eけ璐�", false);
+                    throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�");
+                }
+            }
+        }catch (Exception e){
+            callApiLogSaveMES(null, null,""+e, false);
+        }
+        callApiLogSaveMES(param, param.getCombMats().get(0),"缁勬墭鎴愬姛", true);
+    }
+    public void callApiLogSaveMES(CombParam combParam,CombParam.CombMat combMat, String response, Boolean bool) {
+        if (Cools.isEmpty(combParam)){
+            apiLogService.save("MES涓嬪彂鍏ュ簱閫氱煡鍗�", "/open/asrs/comb/v1", "null", "10.10.10.1",
+                    "",
+                    response, bool);
+        }else if (Cools.isEmpty(combMat)){
+            apiLogService.save("MES涓嬪彂鍏ュ簱閫氱煡鍗�", "/open/asrs/comb/v1", "null", "10.10.10.1",
+                    "鎵樼洏鐮侊細" + combParam.getBarcode(),
+                    response, bool);
+        }else {
+            apiLogService.save("MES涓嬪彂鍏ュ簱閫氱煡鍗�", "/open/asrs/comb/v1", "null", "10.10.10.1",
+                    "鎵樼洏鐮侊細" + combParam.getBarcode() + "銆佺墿鏂欑紪鍙凤細" + combMat.getMatnr() + "銆佹暟閲忥細" + combMat.getAnfme(),
+                    response, bool);
+        }
+    }
+
+    /**
+     * 鍏ュ簱璁板綍鑾峰彇
+     */
+    @Override
+    @Transactional
+    public List<ViewWorkInBean> inlogERP() {
+        List<ViewWorkInBean> viewWorkInERP = reportQueryMapper.getViewWorkInERP();
+        ArrayList<ViewWorkInBean> viewWorkInBeans = new ArrayList<>();
+        for (ViewWorkInBean viewWorkInBean:viewWorkInERP){
+            viewWorkInBean.sype();
+            viewWorkInBeans.add(viewWorkInBean);
+        }
+        return viewWorkInBeans;
+    }
+
+    /**
+     * 鍑哄簱璁板綍鑾峰彇
+     */
+    @Override
+    @Transactional
+    public List<ViewWorkInBean> outlogERP() {
+        List<ViewWorkInBean> viewWorkInERP = reportQueryMapper.getViewWorkOutERP();
+        ArrayList<ViewWorkInBean> viewWorkInBeans = new ArrayList<>();
+        for (ViewWorkInBean viewWorkInBean:viewWorkInERP){
+            viewWorkInBean.sype();
+            viewWorkInBeans.add(viewWorkInBean);
+        }
+        return viewWorkInBeans;
+    }
 
 }

--
Gitblit v1.9.1