From 9d0acfb65c80c4948c305ca01338f894b87346a0 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期一, 08 四月 2024 09:44:37 +0800 Subject: [PATCH] Merge branch 'Four-Way-Rack' of http://47.97.1.152:5880/r/zy-asrs-master into Four-Way-Rack --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java | 90 +++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 86 insertions(+), 4 deletions(-) diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java index 21b798f..763cdfe 100644 --- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java +++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java @@ -2,25 +2,36 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.zy.asrs.framework.common.BaseRes; import com.zy.asrs.framework.common.Cools; import com.zy.asrs.framework.common.R; +import com.zy.asrs.framework.common.SnowflakeIdWorker; import com.zy.asrs.wcs.common.annotation.OperationLog; import com.zy.asrs.wcs.common.domain.BaseParam; import com.zy.asrs.wcs.common.domain.KeyValVo; import com.zy.asrs.wcs.common.domain.PageParam; +import com.zy.asrs.wcs.core.domain.param.ShuttleOperatorParam; import com.zy.asrs.wcs.core.entity.BasShuttle; +import com.zy.asrs.wcs.core.entity.Motion; +import com.zy.asrs.wcs.core.entity.Task; +import com.zy.asrs.wcs.core.entity.TaskCtg; +import com.zy.asrs.wcs.core.kernel.AnalyzeService; +import com.zy.asrs.wcs.core.model.enums.TaskStsType; import com.zy.asrs.wcs.core.service.BasShuttleService; +import com.zy.asrs.wcs.core.service.MotionService; +import com.zy.asrs.wcs.core.service.TaskCtgService; +import com.zy.asrs.wcs.core.service.TaskService; +import com.zy.asrs.wcs.core.utils.Utils; +import com.zy.asrs.wcs.rcs.News; import com.zy.asrs.wcs.system.controller.BaseController; import com.zy.asrs.wcs.utils.ExcelUtil; 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; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.List; -import java.util.Map; +import java.util.*; @RestController @RequestMapping("/api") @@ -28,6 +39,16 @@ @Autowired private BasShuttleService basShuttleService; + @Autowired + private TaskCtgService taskCtgService; + @Autowired + private SnowflakeIdWorker snowflakeIdWorker; + @Autowired + private TaskService taskService; + @Autowired + private AnalyzeService analyzeService; + @Autowired + private MotionService motionService; @PreAuthorize("hasAuthority('core:basShuttle:list')") @PostMapping("/basShuttle/page") @@ -99,4 +120,65 @@ ExcelUtil.build(ExcelUtil.create(basShuttleService.list(), BasShuttle.class), response); } + @PreAuthorize("hasAuthority('core:basShuttle:operator')") + @PostMapping("/basShuttle/operator/shuttle") + @Transactional + public R shuttleOperator(@RequestBody ShuttleOperatorParam param) { + if (Cools.isEmpty(param.getShuttleNo(), param.getShuttleTaskMode())) { + return R.error("鍙傛暟涓虹┖"); + } + + Integer shuttleNo = param.getShuttleNo(); + + //鑾峰彇杩佺Щ浠诲姟绫诲瀷 + TaskCtg taskCtg = taskCtgService.getOne(new LambdaQueryWrapper<TaskCtg>() + .eq(TaskCtg::getFlag, "MANUAL") + .eq(TaskCtg::getStatus, 1)); + if (taskCtg == null) { + return R.error(); + } + + String targetLoc = null;//浠诲姟鐩爣(鍊熺敤瀛楁) + String targetSite = param.getShuttleTaskMode();//浠诲姟绫诲瀷(鍊熺敤瀛楁) + if (param.getShuttleTaskMode().equals("moveLoc")) { + //杩佺Щ浠诲姟 + targetLoc = param.getTargetLocNo(); + } + + Task task = new Task(); + task.setUuid(String.valueOf(snowflakeIdWorker.nextId())); + task.setTaskNo(String.valueOf(Utils.getTaskNo("MANUAL"))); + task.setTaskSts(TaskStsType.NEW_MANUAL.getId()); + task.setTaskCtg(taskCtg.getId()); + task.setPriority(10); + task.setOriginSite(null); + task.setOriginLoc(null); + task.setDestSite(targetSite); + task.setDestLoc(targetLoc); + task.setIoTime(new Date()); + task.setStartTime(new Date()); + task.setStatus(1); + task.setMemo("manual"); + task.setShuttleNo(param.getShuttleNo()); + boolean result = taskService.save(task); + if (!result) { + return R.error(); + } + + // generate motion list + List<Motion> motionList = analyzeService.generateShuttleManualMotion(task); + if (Cools.isEmpty(motionList)) { + News.error("淇濆瓨{}鍙峰洓鍚戠┛姊溅鎵嬪姩浠诲姟澶辫触!!!", shuttleNo); + return R.error(); + } + motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo())); + + task.setTaskSts(TaskStsType.ANALYZE_MANUAL.getId()); + if (!taskService.updateById(task)) { + News.error("淇濆瓨{}鍙峰洓鍚戠┛姊溅鎵嬪姩浠诲姟澶辫触!!!", shuttleNo); + return R.error(); + } + return R.ok(); + } + } -- Gitblit v1.9.1