From ed0a79ffec5d25dae6b0b24393c331ab36d7d50b Mon Sep 17 00:00:00 2001
From: whycq <10027870+whycq@user.noreply.gitee.com>
Date: 星期二, 04 六月 2024 15:35:12 +0800
Subject: [PATCH] # 自动回流数量限制

---
 src/main/java/com/zy/asrs/service/impl/BasDevpServiceImpl.java |   63 ++++++++++++++++++++++++++++++-
 1 files changed, 61 insertions(+), 2 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/BasDevpServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/BasDevpServiceImpl.java
index 47c650d..297e517 100644
--- a/src/main/java/com/zy/asrs/service/impl/BasDevpServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/BasDevpServiceImpl.java
@@ -1,9 +1,13 @@
 package com.zy.asrs.service.impl;
 
 import com.baomidou.mybatisplus.service.impl.ServiceImpl;
+import com.core.exception.CoolException;
 import com.zy.asrs.entity.BasDevp;
+import com.zy.asrs.entity.WrkMast;
 import com.zy.asrs.mapper.BasDevpMapper;
 import com.zy.asrs.service.BasDevpService;
+import com.zy.asrs.service.WrkMastService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
 import java.util.List;
@@ -11,8 +15,63 @@
 @Service("basDevpService")
 public class BasDevpServiceImpl extends ServiceImpl<BasDevpMapper, BasDevp> implements BasDevpService {
 
+    @Autowired
+    private WrkMastService wrkMastService;
+
     @Override
-    public List<Integer> getAvailableDevp() {
-        return this.baseMapper.getAvailableDevp();
+    public List<Integer> getAvailableInSite() {
+        return this.baseMapper.getAvailableInSite(1);
+    }
+
+    @Override
+    public List<Integer> getAvailableEmptyInSite() {
+        return this.baseMapper.getAvailableInSite(10);
+    }
+
+    @Override
+    public List<Integer> getAvailableOutSite(Integer typeNo) {
+        return this.baseMapper.getAvailableOutSite(typeNo);
+    }
+
+    @Override
+    public List<Integer> getAvailableEmptyOutSite() {
+        return this.baseMapper.getAvailableOutSite(110);
+    }
+
+    @Override
+    public BasDevp checkSiteStatus(Integer devpNo) {
+        return checkSiteStatus(devpNo, false);
+    }
+
+    @Override
+    public BasDevp checkSiteStatus(Integer devpNo, boolean pakin) {
+        BasDevp station = selectById(devpNo);
+        if (station == null){
+            throw new CoolException(devpNo+"绔欑偣涓嶅瓨鍦�");
+        }
+        if (pakin) {
+            if(station.getAutoing()==null || !station.getAutoing().equals("Y")) {
+                throw new CoolException(devpNo+"绔欑偣涓嶆槸鑷姩鐘舵��");
+            }
+            if(station.getLoading()==null || !station.getLoading().equals("Y")) {
+                throw new CoolException(devpNo+"绔欑偣鏃犵墿");
+            }
+
+            if(station.getWrkNo()!=null && station.getWrkNo()>0 && station.getWrkNo() < 9990) {
+                WrkMast wrkMast = wrkMastService.selectById(station.getWrkNo());
+                if (wrkMast != null) {
+                    if (wrkMast.getIoType() != 103 && wrkMast.getIoType() != 104 && wrkMast.getIoType() != 107) {
+                        throw new CoolException(devpNo+"绔欑偣宸叉湁宸ヤ綔鍙�");
+                    }
+                }
+            }
+//            if(!station.getInEnable().equals("Y")) {
+//                throw new CoolException(devpNo+"绔欑偣涓嶆槸鍙叆鐘舵��");
+//            }
+            if(wrkMastService.getWorkingMast(devpNo) > 0){
+                throw new CoolException(devpNo+"绔欑偣涓嶈兘鍚屾椂鐢熸垚涓ょ瑪鍏ュ簱宸ヤ綔妗�");
+            }
+        }
+        return station;
     }
 }

--
Gitblit v1.9.1