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 | 94 ++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 88 insertions(+), 6 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 3620b95..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
@@ -8,18 +8,27 @@
import com.zy.acs.common.utils.Utils;
import com.zy.acs.framework.common.Cools;
import com.zy.acs.framework.common.R;
+import com.zy.acs.framework.exception.CoolException;
import com.zy.acs.manager.common.annotation.OperationLog;
import com.zy.acs.manager.common.domain.BaseParam;
import com.zy.acs.manager.common.domain.KeyValVo;
import com.zy.acs.manager.common.domain.PageParam;
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;
import org.springframework.security.access.prepost.PreAuthorize;
+import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletResponse;
@@ -32,6 +41,12 @@
@Autowired
private CodeService codeService;
+ @Autowired
+ private CodeGapService codeGapService;
+ @Autowired
+ private RouteService routeService;
+ @Autowired
+ private FuncStaService funcStaService;
@PreAuthorize("hasAuthority('manager:code:list')")
@PostMapping("/code/page")
@@ -56,7 +71,54 @@
@PreAuthorize("hasAuthority('manager:code:list')")
@GetMapping("/code/{id}")
public R get(@PathVariable("id") Long id) {
- return R.ok().add(codeService.getById(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')")
@@ -91,16 +153,35 @@
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);
}
@PreAuthorize("hasAuthority('manager:code:remove')")
@OperationLog("Delete Code")
@PostMapping("/code/remove/{ids}")
+ @Transactional
public R remove(@PathVariable Long[] ids) {
- if (!codeService.removeByIds(Arrays.asList(ids))) {
- return R.error("Delete Fail");
+ 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)) {
+ throw new CoolException("failed to remove code");
+ } else {
+ CodeServiceImpl.CODE_ID_CACHE.remove(code.getId());
+ CodeServiceImpl.CODE_DATA_CACHE.remove(code.getData());
+ }
}
+ codeService.refreshCornerByCodeIds(affectedCodeIds);
return R.ok("Delete Success").add(ids);
}
@@ -129,14 +210,15 @@
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);
- if (null != codeService.selectByData(code.getData())) {
+ Code code = Cools.convert(map, Code.class);
+ if (null != codeService.getCacheByData(code.getData())) {
continue;
}
code.setData(Utils.zeroFill(code.getData(), CommonConstant.QR_CODE_LEN));
code.setUuid("code".concat(code.getData()));
- code.setConcer(0);
+// code.setCorner(0);
code.setScale(GsonUtils.toJson(Cools.add("x", 1).add("y", 1)));
+ code.setStatus(StatusType.ENABLE.val);
code.setCreateBy(userId);
code.setCreateTime(now);
code.setUpdateBy(userId);
--
Gitblit v1.9.1