From ea327cdeca992d02acc2b2744e09ef449c0ee3cb Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期五, 12 五月 2023 14:27:51 +0800
Subject: [PATCH] 库临、库存上下限

---
 src/main/java/com/zy/asrs/service/impl/LocRuleServiceImpl.java |   62 +++++++++++++++++++++----------
 1 files changed, 42 insertions(+), 20 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/LocRuleServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/LocRuleServiceImpl.java
index 4e01f89..79ab983 100644
--- a/src/main/java/com/zy/asrs/service/impl/LocRuleServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/LocRuleServiceImpl.java
@@ -2,23 +2,31 @@
 
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Cools;
+import com.zy.asrs.entity.LocMast;
 import com.zy.asrs.entity.Mat;
 import com.zy.asrs.mapper.LocRuleMapper;
 import com.zy.asrs.entity.LocRule;
+import com.zy.asrs.service.LocMastService;
 import com.zy.asrs.service.LocRuleService;
 import com.baomidou.mybatisplus.service.impl.ServiceImpl;
 import com.zy.asrs.service.MatService;
+import com.zy.asrs.utils.Utils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+
+import java.util.ArrayList;
+import java.util.List;
 
 @Service("locRuleService")
 public class LocRuleServiceImpl extends ServiceImpl<LocRuleMapper, LocRule> implements LocRuleService {
 
     @Autowired
     private MatService matService;
+    @Autowired
+    private LocMastService locMastService;
 
     @Override
-    public LocRule find(String matnr, String batch, int startRow, int endRow) {
+    public LocRule find(String matnr) {
         if (Cools.isEmpty(matnr)) {
             return null;
         }
@@ -26,25 +34,39 @@
         if (Cools.isEmpty(mat)) {
             return null;
         }
-        LocRule locRule = null;
-        do {
-            locRule = this.selectOne(new EntityWrapper<LocRule>().eq("matnr", matnr).ge("row_beg", startRow).le("row_end", endRow).eq("status", 1));
-            if (null != locRule) {
-                break;
+
+        return this.baseMapper.selectByMatnr(matnr);
+    }
+
+    //鎵炬贩杞藉簱浣嶈鍒�
+    @Override
+    public LocRule findMixed() {
+        return this.baseMapper.selectByMixed(1);//鎼滅储娣疯浇搴撲綅瑙勫垯
+    }
+
+    //灏嗗簱浣嶈鍒欒浆鎹负搴撲綅缁�
+    @Override
+    public List<LocMast> locRuleToLocNos(LocRule locRule) {
+        ArrayList<String> locNos = new ArrayList<>();
+        //灏嗘墍鏈夌鍚堟贩杞借鍒欑殑搴撲綅鍙疯繘琛屽瓨鍌�
+        Integer rowBeg = locRule.getRowBeg();
+        Integer rowEnd = locRule.getRowEnd();
+
+        Integer bayBeg = locRule.getBayBeg();
+        Integer bayEnd = locRule.getBayEnd();
+
+        Integer levBeg = locRule.getLevBeg();
+        Integer levEnd = locRule.getLevEnd();
+
+        for (int i = rowBeg; i <= rowEnd; i++) {
+            for (int j = bayBeg; j <= bayEnd; j++) {
+                for (int k = levBeg; k <= levEnd; k++) {
+                    String locNo = Utils.getLocNo(i, j, k);
+                    locNos.add(locNo);
+                }
             }
-            locRule = this.selectOne(new EntityWrapper<LocRule>().eq("specs", mat.getSpecs()).ge("row_beg", startRow).le("row_end", endRow).eq("status", 1));
-            if (null != locRule) {
-                break;
-            }
-            locRule = this.selectOne(new EntityWrapper<LocRule>().eq("model", mat.getModel()).ge("row_beg", startRow).le("row_end", endRow).eq("status", 1));
-            if (null != locRule) {
-                break;
-            }
-            locRule = this.selectOne(new EntityWrapper<LocRule>().eq("batch", batch).ge("row_beg", startRow).le("row_end", endRow).eq("status", 1));
-            if (null != locRule) {
-                break;
-            }
-        } while (false);
-        return locRule;
+        }
+
+        return locMastService.selectEmptyByLocNos(locNos);
     }
 }

--
Gitblit v1.9.1