From 4696a0be1e0235e4a9e5077c3f42e038da8c6809 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期四, 14 八月 2025 16:30:37 +0800
Subject: [PATCH] 1

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java |  120 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 112 insertions(+), 8 deletions(-)

diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java
index fba286a..a55eee0 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java
@@ -1,22 +1,36 @@
 package com.zy.acs.manager.manager.controller;
 
-import com.zy.acs.manager.common.annotation.OperationLog;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.zy.acs.framework.common.Cools;
 import com.zy.acs.framework.common.R;
-import com.zy.acs.manager.system.controller.BaseController;
+import com.zy.acs.manager.common.annotation.OperationLog;
+import com.zy.acs.manager.common.domain.BaseParam;
+import com.zy.acs.manager.common.domain.PageParam;
+import com.zy.acs.manager.core.constant.LocGroupConstant;
 import com.zy.acs.manager.core.service.MainService;
 import com.zy.acs.manager.manager.controller.param.OpenBusSubmitParam;
+import com.zy.acs.manager.manager.entity.Loc;
+import com.zy.acs.manager.manager.entity.Sta;
+import com.zy.acs.manager.manager.enums.StaStsType;
+import com.zy.acs.manager.manager.service.LocService;
+import com.zy.acs.manager.manager.service.StaService;
+import com.zy.acs.manager.system.controller.BaseController;
+import com.zy.acs.manager.system.service.ConfigService;
 import io.swagger.annotations.Api;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RestController;
 
+import java.util.Collections;
+import java.util.List;
+import java.util.Map;
+
 /**
  * Created by vincent on 2023/6/12
  */
-@Api(tags = "寮�鏀惧钩鍙�")
+@Api(tags = "Open Api")
 @RestController
 @RequestMapping("/api/open")
 public class OpenController extends BaseController {
@@ -24,12 +38,102 @@
     @Autowired
     private MainService mainService;
 
-    @PreAuthorize("hasAuthority('open:bus:submit')")
+    @Autowired
+    private LocService locService;
+
+    @Autowired
+    private StaService staService;
+
+    @Autowired
+    private ConfigService configService;
+
+    //@PreAuthorize("hasAuthority('open:bus:submit')")
     @PostMapping("/bus/submit")
-    @OperationLog("浠诲姟涓嬪彂")
+    @OperationLog("generate task from open api")
     public R save(@RequestBody OpenBusSubmitParam param) {
-        mainService.generateBusAndTask(param, null);
-        return R.ok("淇濆瓨鎴愬姛");
+        if (!configService.getVal("TaskAssignMode", Boolean.class)) {
+            if (configService.getVal("InAndOutMode", Boolean.class, false)) {
+                mainService.generateBusAndTask(param, null);
+                return R.ok("generate tasks success");
+            }
+        }
+        return R.error("generate tasks error");
+    }
+
+    @PostMapping("/sta/update")
+    @OperationLog("sync sta")
+    public R updateLoc(@RequestBody Map<String, Object> map) {
+        if (!configService.getVal("TaskAssignMode", Boolean.class)) {
+            if (configService.getVal("InAndOutMode", Boolean.class, false)) {
+                String staNo = map.get("staNo").toString();
+                Sta loc = staService.selectByStaNo(staNo);
+                if (staNo.equals("1001")) {
+                    if (loc.getStaSts() == StaStsType.STOCK.val()) {
+                        loc.setStaSts(Long.parseLong(map.get("sts").toString()));
+                        return staService.updateById(loc) ? R.ok() : R.error("update loc fail");
+                    }
+                } else if (staNo.equals("1007")) {
+                    if (loc.getStaSts() == StaStsType.IDLE.val()) {
+                        loc.setStaSts(Long.parseLong(map.get("sts").toString()));
+                        return staService.updateById(loc) ? R.ok() : R.error("update loc fail");
+                    }
+                }
+            }
+        }
+        return R.error("update loc fail");
+    }
+
+    //@PreAuthorize("hasAuthority('open:bus:submit')")
+    @PostMapping("/loc/sync")
+    @OperationLog("sync loc")
+    public R loc(@RequestBody Map<String, Object> map) {
+        BaseParam baseParam = buildParam(map, BaseParam.class);
+        PageParam<Loc, BaseParam> pageParam = new PageParam<>(baseParam, Loc.class);
+        return R.ok().add(locService.page(pageParam, pageParam.buildWrapper(true)));
+    }
+
+    @PostMapping("/loc/one")
+    @OperationLog("one loc")
+    public R emptyLoc(@RequestBody Map<String, Object> map) {
+        if (!configService.getVal("TaskAssignMode", Boolean.class)) {
+            if (configService.getVal("InAndOutMode", Boolean.class, false)) {
+                String staNo = map.get("staNo").toString();
+                Integer startRow = null;
+                Integer endRow = null;
+                if (staNo.equals("101-2") || staNo.equals("101-3") || staNo.equals("102-2") || staNo.equals("102-3")) {
+                    startRow = Collections.min(LocGroupConstant.FAR_RIGHT_LOC_ROW_LIST);
+                    endRow = Collections.max(LocGroupConstant.FAR_RIGHT_LOC_ROW_LIST);
+                } else if (staNo.equals("103-2") || staNo.equals("103-3") || staNo.equals("104-2") || staNo.equals("104-3")) {
+                    startRow = Collections.min(LocGroupConstant.RIGHT_LOC_ROW_LIST);
+                    endRow = Collections.max(LocGroupConstant.RIGHT_LOC_ROW_LIST);
+                } else if (staNo.equals("105-2") || staNo.equals("105-3") || staNo.equals("106-2") || staNo.equals("106-3")) {
+                    startRow = Collections.min(LocGroupConstant.MIDDLE_LOC_ROW_LIST);
+                    endRow = Collections.max(LocGroupConstant.MIDDLE_LOC_ROW_LIST);
+                } else if (staNo.equals("107-2") || staNo.equals("107-3") || staNo.equals("108-2") || staNo.equals("108-3")) {
+                    startRow = Collections.min(LocGroupConstant.LEFT_LOC_ROW_LIST);
+                    endRow = Collections.max(LocGroupConstant.LEFT_LOC_ROW_LIST);
+                } else if (staNo.equals("1007") || staNo.equals("1001")) {
+                    startRow = Collections.min(LocGroupConstant.FAR_LEFT_LOC_ROW_LIST);
+                    endRow = Collections.max(LocGroupConstant.FAR_LEFT_LOC_ROW_LIST);
+                } else {
+                    return R.error("staNo is not support");
+                }
+                LambdaQueryWrapper<Loc> idleWrapper = new LambdaQueryWrapper<Loc>().eq(Loc::getLocSts, Long.parseLong(map.get("sts").toString()));
+                if (null != startRow) {
+                    idleWrapper.ge(Loc::getRow, startRow);
+                }
+                if (null != endRow) {
+                    idleWrapper.le(Loc::getRow, endRow);
+                }
+                List<Loc> idleList = locService.list(idleWrapper);
+                if (Cools.isEmpty(idleList)) {
+                    return R.error("娌$┖搴撲綅");
+                }
+                Collections.shuffle(idleList);
+                return R.ok().add(idleList.get(0));
+            }
+        }
+        return R.error("鏈紑鍚妯″紡");
     }
 
 }

--
Gitblit v1.9.1