From 365b409cdb629396cd2cbb2635ee10309cd3cd96 Mon Sep 17 00:00:00 2001
From: wj <2932352213@qq.com>
Date: 星期三, 06 五月 2026 13:35:37 +0800
Subject: [PATCH] feat:添加批量放置货架功能,添加导出弹窗,可导出筛选的数据

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java |  143 +++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 119 insertions(+), 24 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 4331664..d8ebe5e 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
@@ -2,10 +2,10 @@
 
 import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
-import com.zy.acs.common.constant.CommonConstant;
 import com.zy.acs.common.utils.GsonUtils;
-import com.zy.acs.common.utils.Utils;
+import com.zy.acs.common.utils.QrCodeCodecSupport;
 import com.zy.acs.framework.common.Cools;
 import com.zy.acs.framework.common.R;
 import com.zy.acs.framework.exception.CoolException;
@@ -16,12 +16,13 @@
 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;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -43,6 +44,8 @@
     private CodeGapService codeGapService;
     @Autowired
     private RouteService routeService;
+    @Autowired
+    private FuncStaService funcStaService;
 
     @PreAuthorize("hasAuthority('manager:code:list')")
     @PostMapping("/code/page")
@@ -70,11 +73,58 @@
         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')")
     @OperationLog("Create Code")
     @PostMapping("/code/save")
     public R save(@RequestBody Code code) {
-        code.setData(Utils.zeroFill(code.getData(), CommonConstant.QR_CODE_LEN));
+        code.setData(QrCodeCodecSupport.normalize(code.getData()));
         code.setUuid("code".concat(code.getData()));
         code.setCreateBy(getLoginUserId());
         code.setCreateTime(new Date());
@@ -82,10 +132,8 @@
         code.setUpdateTime(new Date());
         if (!codeService.save(code)) {
             return R.error("Save Fail");
-        } else {
-            CodeServiceImpl.CODE_ID_CACHE.put(code.getId(), code);
-            CodeServiceImpl.CODE_DATA_CACHE.put(code.getData(), code);
         }
+        codeService.refreshCacheById(code.getId());
         return R.ok("Save Success").add(code);
     }
 
@@ -93,19 +141,25 @@
     @OperationLog("Update Code")
     @PostMapping("/code/update")
     public R update(@RequestBody Code code) {
-        code.setData(Utils.zeroFill(code.getData(), CommonConstant.QR_CODE_LEN));
+        Code origin = codeService.getById(code.getId());
+        boolean cornerChanged = origin != null
+                && code.getCorner() != null
+                && !Objects.equals(origin.getCorner(), code.getCorner());
+        code.setData(QrCodeCodecSupport.normalize(code.getData()));
         code.setUpdateBy(getLoginUserId());
         code.setUpdateTime(new Date());
         if (!codeService.updateById(code)) {
             return R.error("Update Fail");
-        } else {
-            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);
+        List<Long> affectedCodeIds = new ArrayList<>(routeService.getAdjacencyNode(code.getId()));
+        if (!cornerChanged) {
+            affectedCodeIds.add(code.getId());
+        }
+        codeService.evictCacheById(code.getId(), origin == null ? null : origin.getData());
+        codeService.refreshCacheById(code.getId());
+        if (!affectedCodeIds.isEmpty()) {
+            codeService.refreshCornerByCodeIds(affectedCodeIds);
+        }
         return R.ok("Update Success").add(code);
     }
 
@@ -125,10 +179,8 @@
             routeService.remove(new LambdaQueryWrapper<Route>().eq(Route::getStartCode, code.getId()).or().eq(Route::getEndCode, code.getId()));
             if (!codeService.removeById(id)) {
                 throw new CoolException("failed to remove code");
-            } else {
-                CodeServiceImpl.CODE_ID_CACHE.remove(code.getId());
-                CodeServiceImpl.CODE_DATA_CACHE.remove(code.getData());
             }
+            codeService.evictCacheById(code.getId(), code.getData());
         }
         codeService.refreshCornerByCodeIds(affectedCodeIds);
         return R.ok("Delete Success").add(ids);
@@ -151,7 +203,52 @@
     @PreAuthorize("hasAuthority('manager:code:list')")
     @PostMapping("/code/export")
     public void export(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
-        ExcelUtil.build(ExcelUtil.create(codeService.list(), Code.class), response);
+        // 1. 鎻愬彇绛涢�夋潯浠讹紙鍏煎鍓嶇 { filter: {...} } 鏍煎紡锛�
+        Map<String, Object> filter = map;
+        if (map != null && map.containsKey("filter")) {
+            Object filterObj = map.get("filter");
+            if (filterObj instanceof Map) {
+                filter = (Map<String, Object>) filterObj;
+            }
+        }
+
+        // 2. 鏋勫缓鏌ヨ鏉′欢锛圡yBatis-Plus锛�
+        QueryWrapper<Code> wrapper = new QueryWrapper<>();
+        if (filter != null && !filter.isEmpty()) {
+            // 鏍规嵁鍓嶇鍙兘浼犻�掔殑瀛楁娣诲姞鏉′欢锛堝瓧娈靛悕闇�涓庢暟鎹簱鍒楁垨瀹炰綋灞炴�у搴旓級
+            if (filter.containsKey("corner")) {
+                wrapper.eq("corner", filter.get("corner"));
+            }
+            if (filter.containsKey("condition")) {
+                String condition = (String) filter.get("condition");
+                wrapper.and(w -> w.like("data", condition).or().like("uuid", condition));
+            }
+            if (filter.containsKey("timeStart")) {
+                wrapper.ge("create_time", filter.get("timeStart"));
+            }
+            if (filter.containsKey("timeEnd")) {
+                wrapper.le("create_time", filter.get("timeEnd"));
+            }
+            if (filter.containsKey("x")) {
+                wrapper.eq("x", filter.get("x"));
+            }
+            if (filter.containsKey("y")) {
+                wrapper.eq("y", filter.get("y"));
+            }
+            if (filter.containsKey("memo")) {
+                wrapper.like("memo", filter.get("memo"));
+            }
+            if (filter.containsKey("status")) {
+                wrapper.eq("status", filter.get("status"));
+            }
+            // 杩樺彲浠ユ坊鍔犲叾浠栧瓧娈靛 data, uuid 绛�
+        }
+
+        // 3. 鏌ヨ绗﹀悎鏉′欢鐨勬暟鎹�
+        List<Code> list = codeService.list(wrapper);
+
+        // 4. 瀵煎嚭 Excel
+        ExcelUtil.build(ExcelUtil.create(list, Code.class), response);
     }
 
     @PreAuthorize("hasAuthority('manager:code:save')")
@@ -159,11 +256,11 @@
     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);
+            code.setData(QrCodeCodecSupport.normalize(code.getData()));
             if (null != codeService.getCacheByData(code.getData())) {
                 continue;
             }
-            code.setData(Utils.zeroFill(code.getData(), CommonConstant.QR_CODE_LEN));
             code.setUuid("code".concat(code.getData()));
 //            code.setCorner(0);
             code.setScale(GsonUtils.toJson(Cools.add("x", 1).add("y", 1)));
@@ -174,10 +271,8 @@
             code.setUpdateTime(now);
             if (!codeService.save(code)) {
                 log.error("failed to save code {}", JSON.toJSONString(map));
-            } else {
-                CodeServiceImpl.CODE_ID_CACHE.put(code.getId(), code);
-                CodeServiceImpl.CODE_DATA_CACHE.put(code.getData(), code);
             }
+            codeService.refreshCacheById(code.getId());
         }
         return R.ok();
     }

--
Gitblit v1.9.1