From 7c4d3d957c431aad12f90511770e2fe429bcd380 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期二, 24 十二月 2024 16:38:25 +0800
Subject: [PATCH] #
---
zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/AgvController.java | 81 +++++++++++++++++++++++++++++++++++-----
1 files changed, 70 insertions(+), 11 deletions(-)
diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/AgvController.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/AgvController.java
index a754666..3defd6e 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/AgvController.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/AgvController.java
@@ -1,24 +1,27 @@
package com.zy.acs.manager.manager.controller;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
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.domain.PageResult;
import com.zy.acs.manager.common.utils.ExcelUtil;
+import com.zy.acs.manager.core.service.astart.MapDataDispatcher;
import com.zy.acs.manager.manager.controller.result.AgvResult;
import com.zy.acs.manager.manager.entity.Agv;
-import com.zy.acs.manager.manager.service.AgvDetailService;
-import com.zy.acs.manager.manager.service.AgvService;
-import com.zy.acs.manager.manager.service.CodeService;
-import com.zy.acs.manager.manager.service.TaskService;
+import com.zy.acs.manager.manager.entity.AgvDetail;
+import com.zy.acs.manager.manager.entity.AgvModel;
+import com.zy.acs.manager.manager.service.*;
import com.zy.acs.manager.system.controller.BaseController;
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;
@@ -33,9 +36,13 @@
@Autowired
private AgvDetailService agvDetailService;
@Autowired
+ private AgvModelService agvModelService;
+ @Autowired
private CodeService codeService;
@Autowired
private TaskService taskService;
+ @Autowired
+ private MapDataDispatcher mapDataDispatcher;
// @PreAuthorize("hasAuthority('manager:agv:list')")
// @PostMapping("/agv/page")
@@ -57,7 +64,7 @@
PageParam<Agv, BaseParam> pageParam = new PageParam<>(baseParam, Agv.class);
PageResult<AgvResult> page = agvService.pageRel(pageParam);
for (AgvResult result : page.getRecords()) {
- result.sync(agvDetailService.selectByAgvId(result.getId()), codeService, taskService);
+ result.sync(agvDetailService.selectByAgvId(result.getId()), codeService, taskService, agvService);
}
return R.ok().add(page);
}
@@ -77,19 +84,46 @@
@PreAuthorize("hasAuthority('manager:agv:list')")
@GetMapping("/agv/{id}")
public R get(@PathVariable("id") Long id) {
- return R.ok().add(agvService.getById(id));
+ Agv agv = agvService.getById(id);
+ if (null != agv) {
+ agv.setOnline(agvService.judgeOnline(agv.getId()));
+ if (agv.getUuid().equals("2")) { agv.setOnline(true); }
+ AgvDetail agvDetail = agvDetailService.selectByAgvId(agv.getId());
+ if (null != agvDetail) {
+ agv.setAgvDetail(agvDetail);
+ }
+ AgvModel agvModel = agvModelService.getById(agv.getAgvModel());
+ if (null != agvModel) {
+ agv.setAgvModelData(agvModel);
+ }
+ }
+ return R.ok().add(agv);
}
@PreAuthorize("hasAuthority('manager:agv:save')")
@OperationLog("Create Agv")
@PostMapping("/agv/save")
+ @Transactional
public R save(@RequestBody Agv agv) {
- agv.setCreateBy(getLoginUserId());
- agv.setCreateTime(new Date());
- agv.setUpdateBy(getLoginUserId());
- agv.setUpdateTime(new Date());
+ if (agvService.count(new LambdaQueryWrapper<Agv>()
+ .eq(Agv::getUuid, agv.getUuid())) > 0) {
+ return R.error("agv no has already exist !");
+ }
+ Long loginUserId = getLoginUserId();
+ Date now = new Date();
+ agv.setCreateBy(loginUserId);
+ agv.setCreateTime(now);
+ agv.setUpdateBy(loginUserId);
+ agv.setUpdateTime(now);
if (!agvService.save(agv)) {
- return R.error("Save Fail");
+ throw new CoolException("Save Fail");
+ }
+ AgvDetail agvDetail = new AgvDetail();
+ agvDetail.setAgvId(agv.getId());
+ agvDetail.setCreateBy(loginUserId);
+ agvDetail.setUpdateBy(loginUserId);
+ if (!agvDetailService.save(agvDetail)) {
+ throw new CoolException("Save Fail");
}
return R.ok("Save Success").add(agv);
}
@@ -98,6 +132,11 @@
@OperationLog("Update Agv")
@PostMapping("/agv/update")
public R update(@RequestBody Agv agv) {
+ if (agvService.count(new LambdaQueryWrapper<Agv>()
+ .eq(Agv::getUuid, agv.getUuid())
+ .ne(Agv::getId, agv.getId())) > 0) {
+ return R.error("Update Fail");
+ }
agv.setUpdateBy(getLoginUserId());
agv.setUpdateTime(new Date());
if (!agvService.updateById(agv)) {
@@ -136,4 +175,24 @@
ExcelUtil.build(ExcelUtil.create(agvService.list(), Agv.class), response);
}
+ @PreAuthorize("hasAuthority('manager:agv:remove')")
+ @OperationLog("Remove Agv From Map")
+ @PostMapping("/agv/remove/from/map")
+ public R removeFromMap(@RequestBody Agv agv) {
+ AgvDetail agvDetail = agvDetailService.selectByAgvId(agv.getId());
+ if (null != agvDetail) {
+ LambdaUpdateWrapper<AgvDetail> wrapper = new LambdaUpdateWrapper<>();
+ wrapper.set(AgvDetail::getCode, null)
+ .set(AgvDetail::getLastCode, null)
+ .set(AgvDetail::getUpdateBy, getLoginUserId())
+ .set(AgvDetail::getUpdateTime, new Date())
+ .eq(AgvDetail::getId, agvDetail.getId());
+ if (!agvDetailService.update(null, wrapper)) {
+ return R.error("Remove Fail");
+ }
+ mapDataDispatcher.modifyDynamicMatrix(MapDataDispatcher.MAP_DEFAULT_LEV, null, agv.getUuid(), true);
+ }
+ return R.ok("Remove Success").add(agv);
+ }
+
}
--
Gitblit v1.9.1