From 70930071a49190f414c8d8bc9c9e9795a4096739 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期一, 23 三月 2026 16:08:27 +0800
Subject: [PATCH] Merge branch 'refs/heads/rcs_master' into jdxaj

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java |   60 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 59 insertions(+), 1 deletions(-)

diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java
index 462d8a3..b541781 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java
@@ -16,10 +16,12 @@
 import com.zy.acs.manager.common.utils.ExcelUtil;
 import com.zy.acs.manager.manager.entity.Code;
 import com.zy.acs.manager.manager.entity.CodeGap;
+import com.zy.acs.manager.manager.entity.FuncSta;
 import com.zy.acs.manager.manager.entity.Route;
 import com.zy.acs.manager.manager.enums.StatusType;
 import com.zy.acs.manager.manager.service.CodeGapService;
 import com.zy.acs.manager.manager.service.CodeService;
+import com.zy.acs.manager.manager.service.FuncStaService;
 import com.zy.acs.manager.manager.service.RouteService;
 import com.zy.acs.manager.manager.service.impl.CodeServiceImpl;
 import com.zy.acs.manager.system.controller.BaseController;
@@ -43,6 +45,8 @@
     private CodeGapService codeGapService;
     @Autowired
     private RouteService routeService;
+    @Autowired
+    private FuncStaService funcStaService;
 
     @PreAuthorize("hasAuthority('manager:code:list')")
     @PostMapping("/code/page")
@@ -68,6 +72,53 @@
     @GetMapping("/code/{id}")
     public R get(@PathVariable("id") Long id) {
         return R.ok().add(codeService.getCacheById(id));
+    }
+
+    @PreAuthorize("hasAuthority('manager:code:list')")
+    @PostMapping("/code/info")
+    public R info(@RequestParam(required = false) String codeData) {
+        if (Cools.isEmpty(codeData)) {
+            return R.error();
+        }
+        Code code = codeService.getCacheByData(codeData);
+        if (code == null) {
+            return R.error("Code Not Found");
+        }
+        return R.ok().add(code);
+    }
+
+    @PreAuthorize("hasAuthority('manager:code:list')")
+    @PostMapping("/code/route/list")
+    public R routeList(@RequestParam(required = false) String codeData) {
+        if (Cools.isEmpty(codeData)) {
+            return R.error();
+        }
+        Code code = codeService.getCacheByData(codeData);
+        if (code == null) {
+            return R.ok().add(Collections.emptyList());
+        }
+        List<Route> routeList = routeService.list(new LambdaQueryWrapper<Route>()
+                .eq(Route::getStatus, StatusType.ENABLE.val)
+                .and(wrapper -> wrapper.eq(Route::getStartCode, code.getId()).or().eq(Route::getEndCode, code.getId()))
+                .orderByAsc(Route::getId));
+        return R.ok().add(routeList);
+    }
+
+    @PreAuthorize("hasAuthority('manager:code:list')")
+    @PostMapping("/code/funcSta/list")
+    public R funcStaList(@RequestParam(required = false) String codeData) {
+        if (Cools.isEmpty(codeData)) {
+            return R.error();
+        }
+        Code code = codeService.getCacheByData(codeData);
+        if (code == null) {
+            return R.ok().add(Collections.emptyList());
+        }
+        List<FuncSta> funcStaList = funcStaService.list(new LambdaQueryWrapper<FuncSta>()
+                .eq(FuncSta::getCode, code.getId())
+                .eq(FuncSta::getStatus, StatusType.ENABLE.val)
+                .orderByAsc(FuncSta::getId));
+        return R.ok().add(funcStaList);
     }
 
     @PreAuthorize("hasAuthority('manager:code:save')")
@@ -102,6 +153,10 @@
             CodeServiceImpl.CODE_ID_CACHE.put(code.getId(), code);
             CodeServiceImpl.CODE_DATA_CACHE.put(code.getData(), code);
         }
+        List<Long> affectedCodeIds = Utils.singletonList(code.getId());
+        affectedCodeIds.add(code.getId());
+        affectedCodeIds.addAll(routeService.getAdjacencyNode(code.getId()));
+        codeService.refreshCornerByCodeIds(affectedCodeIds);
         return R.ok("Update Success").add(code);
     }
 
@@ -110,11 +165,13 @@
     @PostMapping("/code/remove/{ids}")
     @Transactional
     public R remove(@PathVariable Long[] ids) {
+        List<Long> affectedCodeIds = new ArrayList<>();
         for (Long id : ids) {
             Code code = codeService.getById(id);
             if (null == code) {
                 continue;
             }
+            affectedCodeIds.addAll(routeService.getAdjacencyNode(code.getId()));
             codeGapService.remove(new LambdaQueryWrapper<CodeGap>().eq(CodeGap::getCode0, code.getId()).or().eq(CodeGap::getCode1, code.getId()));
             routeService.remove(new LambdaQueryWrapper<Route>().eq(Route::getStartCode, code.getId()).or().eq(Route::getEndCode, code.getId()));
             if (!codeService.removeById(id)) {
@@ -124,6 +181,7 @@
                 CodeServiceImpl.CODE_DATA_CACHE.remove(code.getData());
             }
         }
+        codeService.refreshCornerByCodeIds(affectedCodeIds);
         return R.ok("Delete Success").add(ids);
     }
 
@@ -152,7 +210,7 @@
     public R importBatch(@RequestBody List<Map<String, Object>> list) {
         Date now = new Date();  Long userId = getLoginUserId();
         for (Map<String, Object> map : list) {
-            Code code = Cools.conver(map, Code.class);
+            Code code = Cools.convert(map, Code.class);
             if (null != codeService.getCacheByData(code.getData())) {
                 continue;
             }

--
Gitblit v1.9.1