From 307a04b33d1054c89e1acae24ed2913e394635b8 Mon Sep 17 00:00:00 2001
From: czkh <czkh@163.com>
Date: 星期一, 01 十二月 2025 09:07:31 +0800
Subject: [PATCH] #1

---
 src/main/java/com/zy/asrs/service/impl/MatBarcodeServiceImpl.java |   37 ++++++++++++++++++++++++++++++-------
 1 files changed, 30 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/MatBarcodeServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MatBarcodeServiceImpl.java
index 4b0b6d4..fa83c2b 100644
--- a/src/main/java/com/zy/asrs/service/impl/MatBarcodeServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MatBarcodeServiceImpl.java
@@ -3,16 +3,12 @@
 import com.baomidou.mybatisplus.service.impl.ServiceImpl;
 import com.core.common.Cools;
 import com.core.exception.CoolException;
-import com.zy.asrs.entity.HalfBarcode;
-import com.zy.asrs.entity.Mat;
-import com.zy.asrs.entity.MatBarcode;
-import com.zy.asrs.entity.WaitPakin;
+import com.zy.asrs.entity.*;
 import com.zy.asrs.mapper.MatBarcodeMapper;
-import com.zy.asrs.service.HalfBarcodeService;
-import com.zy.asrs.service.MatBarcodeService;
-import com.zy.asrs.service.MatService;
+import com.zy.asrs.service.*;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 
 import java.util.List;
 import java.util.Map;
@@ -27,14 +23,41 @@
     private MatService matService;
     @Autowired
     private HalfBarcodeService halfBarcodeService;
+    @Autowired
+    private WaitPakinService waitPakinService;
+    @Autowired
+    private WrkDetlService wrkDetlService;
+    @Autowired
+    private LocDetlService locDetlService;
+    @Autowired
+    private WrkMastService wrkMastService;
     @Override
     public MatBarcode selectbyMatnr(String matnr) {
         return this.baseMapper.selectByMatnr(matnr);
     }
 
+    @Transactional
     @Override
     public void deleteMatBarcode(List<MatBarcode> list) {
         for (MatBarcode matBarcode : list) {
+            //瀵逛簬宸茬粡鏈夊簱瀛� 缁勬墭妗� 宸ヤ綔妗g殑鏁版嵁 涓嶅厑璁歌В缁�
+            Integer locCount = locDetlService.selectCountByMatNr(matBarcode.getMatnr());
+            Integer waitCount = waitPakinService.selectCountByMatNr(matBarcode.getMatnr());
+            //Integer wrkCount = wrkDetlService.selectCountByMatNr(matBarcode.getMatnr());
+            if (locCount > 0 || waitCount > 0){
+                throw new CoolException("搴撳瓨/缁勬墭妗e瓨鍦ㄨ妯″叿,涓嶈兘瑙g粦,鍟嗗搧妯″叿鍚嶇О:" + matBarcode.getMatnr() + "鎵樼洏鐮�:" + matBarcode.getZpallet());
+            }
+            Integer wrkNo = wrkDetlService.selectWrkNoByMatnr(matBarcode.getMatnr());
+            WrkMast wrkMast = wrkMastService.selectById(wrkNo);
+            if (wrkMast == null){
+                throw new CoolException("宸ヤ綔妗e紓甯革紝鏈夊伐浣滄槑缁嗘。鏃犲伐浣滄。");
+            }
+            if (wrkMast.getIoType() != 103 && wrkMast.getIoType() != 101){
+                throw new CoolException("宸ヤ綔妗d笉鏄叏鏉垮嚭搴�/鎷f枡鍑哄簱");
+            }
+            if (wrkMast.getWrkSts() != 14 && wrkMast.getWrkSts() != 15){
+                throw new CoolException("宸ヤ綔妗f湭瀹屾垚");
+            }
             //瀵规ā鍏风殑瑙勬牸鍋氬鐞嗗緱鍒板帤搴�
             Integer thickness = 0;
             if (!Cools.isEmpty(matBarcode.getSpecs())){

--
Gitblit v1.9.1