From 33664d7d7f8478fb961f8fbda44c885fd854bf3d Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期三, 13 八月 2025 16:43:33 +0800
Subject: [PATCH] 保存一个版本

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java |   70 +++++++++++++++++++++++++++++++++--
 1 files changed, 66 insertions(+), 4 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 1711b4d..6c11241 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,17 +1,28 @@
 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.enums.LocStsType;
+import com.zy.acs.manager.manager.service.LocService;
+import com.zy.acs.manager.system.controller.BaseController;
 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
@@ -24,7 +35,10 @@
     @Autowired
     private MainService mainService;
 
-    @PreAuthorize("hasAuthority('open:bus:submit')")
+    @Autowired
+    private LocService locService;
+
+    //@PreAuthorize("hasAuthority('open:bus:submit')")
     @PostMapping("/bus/submit")
     @OperationLog("generate task from open api")
     public R save(@RequestBody OpenBusSubmitParam param) {
@@ -32,4 +46,52 @@
         return R.ok("generate tasks success");
     }
 
+    //@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) {
+        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")){
+             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, LocStsType.IDLE.val());
+        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));
+    }
+
 }

--
Gitblit v1.9.1