From 11da5829433e788d8f901ee5cd910d5923f0806a Mon Sep 17 00:00:00 2001
From: Junjie <540245094@qq.com>
Date: 星期四, 13 六月 2024 09:51:37 +0800
Subject: [PATCH] #小车地图严格模式

---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/OpenController.java |   38 ++++++++++++++++++++++++++++++--------
 1 files changed, 30 insertions(+), 8 deletions(-)

diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/OpenController.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/OpenController.java
index 3e9339b..d986ca4 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/OpenController.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/OpenController.java
@@ -11,6 +11,7 @@
 import com.zy.asrs.wcs.core.entity.Task;
 import com.zy.asrs.wcs.core.entity.TaskCtg;
 import com.zy.asrs.wcs.core.model.enums.DeviceCtgType;
+import com.zy.asrs.wcs.core.model.enums.TaskCtgType;
 import com.zy.asrs.wcs.core.model.enums.TaskStsType;
 import com.zy.asrs.wcs.core.service.LocService;
 import com.zy.asrs.wcs.core.service.TaskCtgService;
@@ -23,6 +24,8 @@
 import com.zy.asrs.wcs.rcs.service.DeviceService;
 import com.zy.asrs.wcs.rcs.thread.ShuttleThread;
 import com.zy.asrs.wcs.system.controller.BaseController;
+import com.zy.asrs.wcs.system.entity.Dict;
+import com.zy.asrs.wcs.system.service.DictService;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestBody;
@@ -49,13 +52,15 @@
     private DeviceService deviceService;
     @Autowired
     private LocService locService;
+    @Autowired
+    private DictService dictService;
 
     //鐢熸垚鍏ュ簱浠诲姟
     @PostMapping("/createInTask")
     public R createInTask(@RequestBody CreateInTaskParam param) {
         //鑾峰彇鍏ュ簱浠诲姟绫诲瀷
         TaskCtg taskCtg = taskCtgService.getOne(new LambdaQueryWrapper<TaskCtg>()
-                .eq(TaskCtg::getFlag, "IN")
+                .eq(TaskCtg::getFlag, String.valueOf(TaskCtgType.IN))
                 .eq(TaskCtg::getStatus, 1));
         if (taskCtg == null) {
             return R.error("浠诲姟绫诲瀷寮傚父");
@@ -66,7 +71,14 @@
             return R.error("搴撲綅鍙蜂笉瀛樺湪");
         }
 
-        if (!loc.getLocStsFlag().equals("O")) {
+        //鑾峰彇涓ユ牸妯″紡鍙傛暟
+        boolean mapStrict = true;//榛樿涓ユ牸妯″紡
+        Dict dict = dictService.getOne(new LambdaQueryWrapper<Dict>().eq(Dict::getFlag, "shuttleMapStrict"));
+        if (dict != null) {
+            mapStrict = Boolean.parseBoolean(dict.getValue());
+        }
+
+        if (mapStrict && !loc.getLocStsFlag().equals("O")) {
             return R.error("搴撲綅鐘舵�佷笉婊¤冻鍏ュ簱鏉′欢");
         }
 
@@ -106,7 +118,7 @@
     public R createOutTask(@RequestBody CreateOutTaskParam param) {
         //鑾峰彇鍑哄簱浠诲姟绫诲瀷
         TaskCtg taskCtg = taskCtgService.getOne(new LambdaQueryWrapper<TaskCtg>()
-                .eq(TaskCtg::getFlag, "OUT")
+                .eq(TaskCtg::getFlag, String.valueOf(TaskCtgType.OUT))
                 .eq(TaskCtg::getStatus, 1));
         if (taskCtg == null) {
             return R.error("浠诲姟绫诲瀷寮傚父");
@@ -117,7 +129,14 @@
             return R.error("搴撲綅鍙蜂笉瀛樺湪");
         }
 
-        if (!loc.getLocStsFlag().equals("F")) {
+        //鑾峰彇涓ユ牸妯″紡鍙傛暟
+        boolean mapStrict = true;//榛樿涓ユ牸妯″紡
+        Dict dict = dictService.getOne(new LambdaQueryWrapper<Dict>().eq(Dict::getFlag, "shuttleMapStrict"));
+        if (dict != null) {
+            mapStrict = Boolean.parseBoolean(dict.getValue());
+        }
+
+        if (mapStrict && !loc.getLocStsFlag().equals("F")) {
             return R.error("搴撲綅鐘舵�佷笉婊¤冻鍑哄簱鏉′欢");
         }
 
@@ -157,7 +176,7 @@
     public R createManualTakeTask(@RequestBody CreateManualTakeTaskParam param) {
         //鑾峰彇鎵嬪姩浠诲姟绫诲瀷
         TaskCtg taskCtg = taskCtgService.getOne(new LambdaQueryWrapper<TaskCtg>()
-                .eq(TaskCtg::getFlag, "MANUAL")
+                .eq(TaskCtg::getFlag, String.valueOf(TaskCtgType.MANUAL))
                 .eq(TaskCtg::getStatus, 1));
         if (taskCtg == null) {
             return R.error("浠诲姟绫诲瀷寮傚父");
@@ -199,7 +218,7 @@
     public R createMoveTask(@RequestBody CreateMoveTaskParam param) {
         //鑾峰彇鍑哄簱浠诲姟绫诲瀷
         TaskCtg taskCtg = taskCtgService.getOne(new LambdaQueryWrapper<TaskCtg>()
-                .eq(TaskCtg::getFlag, "MOVE")
+                .eq(TaskCtg::getFlag, String.valueOf(TaskCtgType.MOVE))
                 .eq(TaskCtg::getStatus, 1));
         if (taskCtg == null) {
             return R.error("浠诲姟绫诲瀷寮傚父");
@@ -218,7 +237,10 @@
             return R.error("绌挎杞︿笉鍦ㄧ嚎");
         }
         ShuttleProtocol shuttleProtocol = shuttleThread.getStatus();
-        if (Utils.getLev(shuttleProtocol.getCurrentLocNo()) != Utils.getLev(param.getDestSite())) {
+        if (shuttleProtocol == null) {
+            return R.error("绌挎杞︿笉鍦ㄧ嚎");
+        }
+        if (Utils.getLev(shuttleProtocol.getCurrentLocNo()) != Utils.getLev(param.getDestLoc())) {
             return R.error("绌挎杞﹀拰鐩爣浣嶇疆涓嶅湪鍚屼竴妤煎眰");
         }
 
@@ -236,7 +258,7 @@
         task.setPriority(priority);
         task.setOriginSite(null);
         task.setOriginLoc(null);
-        task.setDestSite(param.getDestSite());
+        task.setDestSite(param.getDestLoc());
         task.setDestLoc(null);
         task.setIoTime(new Date());
         task.setStartTime(new Date());

--
Gitblit v1.9.1