自动化立体仓库 - WMS系统
zhangc
2024-12-19 73cddc1f15fbee51a0f79189f7df631361483b0d
src/main/java/com/zy/asrs/controller/AgvMobileController.java
@@ -1,5 +1,6 @@
package com.zy.asrs.controller;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.core.annotations.ManagerAuth;
@@ -12,13 +13,15 @@
import com.zy.asrs.service.*;
import com.zy.asrs.service.impl.OrderServiceImpl;
import com.zy.common.web.BaseController;
import io.swagger.models.auth.In;
import lombok.Synchronized;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.*;
import java.util.stream.Collectors;
@@ -29,7 +32,7 @@
 */
@RestController
@RequestMapping("agvMobile")
public class AgvMobileController extends BaseController  {
public class AgvMobileController extends BaseController {
    private static final Logger log = LoggerFactory.getLogger(AgvMobileController.class);
@@ -61,7 +64,7 @@
    locno?组托+绑定暂存位 : 组托
     */
    @PostMapping("/comb/auth")
    public R comb(@RequestBody CombParam combParam){
    public R comb(@RequestBody CombParam combParam) {
        agvMobileService.comb(combParam, getUserId());
        return R.ok();
@@ -70,7 +73,7 @@
    //    再次拣料
    @RequestMapping("/pick/again/auth")
    @ManagerAuth(memo = "再次拣料")
    public R pickAgain(@RequestBody PickParam pickParams){
    public R pickAgain(@RequestBody PickParam pickParams) {
        agvMobileService.pickAgain(pickParams, 1l);
        return R.ok("拣料成功");
    }
@@ -79,11 +82,11 @@
    绑定货架条码与暂存位
     */
    @PostMapping("/combBinging/auth")
    public R combBinding(@RequestBody Map<String,Object> map){
    public R combBinding(@RequestBody Map<String, Object> map) {
        String barcode = map.get("barcode").toString();
        String stationCode = map.get("stationCode").toString();
        Short containerType = Short.valueOf(barcode.substring(0,2));
        agvMobileService.combBinding(barcode,stationCode,containerType);
        Short containerType = Short.valueOf(barcode.substring(0, 2));
        agvMobileService.combBinding(barcode, stationCode, containerType);
        return R.ok("货架绑定站点成功");
    }
@@ -91,9 +94,9 @@
    获取当前已绑定的还没生成工作档的暂存位
     */
    @PostMapping("/getBasDevp/auth")
    public R getBasDevpByFloor(@RequestBody Map<String,Object> map){
    public R getBasDevpByFloor(@RequestBody Map<String, Object> map) {
        String floor = map.get("floor").toString();
        if("1".equals(floor) || "3".equals(floor)){
        if ("1".equals(floor) || "3".equals(floor)) {
            return R.ok(agvMobileService.getAgvBasDevpByFloor(Integer.parseInt(floor)));
        }
        return R.error("参数错误");
@@ -103,7 +106,7 @@
    获取输送线站点
     */
    @PostMapping("/getBasDevp/noCacheShelves/auth")
    public R getBasDevpByNoCacheShelves(){
    public R getBasDevpByNoCacheShelves() {
        return R.ok(agvBasDevpService.getBasDevpByNoCacheShelves());
    }
@@ -112,15 +115,15 @@
     */
    @PostMapping("/pakin/auth")
    @Synchronized
    public R pakin(@RequestBody Map<String,Object> map){
    public R pakin(@RequestBody Map<String, Object> map) {
        List<String> devNos = (List<String>) map.get("devNo");
        List<AgvBasDevp> agvBasDevpList = devNos.stream().map(devNo -> {
            return agvBasDevpService.selectById(devNo);
        }).collect(Collectors.toList());
        workService.createWaitPainWrkMastStart(agvBasDevpList, getUserId(),false);
        workService.createWaitPainWrkMastStart(agvBasDevpList, getUserId(), false);
        return R.ok("生成工作档成功");
    }
@@ -131,13 +134,14 @@
    @Synchronized
    @Transactional
    @ManagerAuth(memo = "启动入库")
    public R startPakin(@RequestBody AgvMobileStartPakin params){
    public R startPakin(@RequestBody AgvMobileStartPakin params) {
        log.info("启动入库,{}", JSON.toJSONString(params));
        // 组托
        params.getCombParams().forEach(combParam -> {
            agvMobileService.comb(combParam,getUserId());
            agvMobileService.comb(combParam, getUserId());
        });
        params.setContainerType(Short.valueOf(params.getContainerCode().substring(0,2)));
        workService.emptyPlateIn(params.getDevNo(),params.getContainerCode(),params.getContainerType(), getUserId(),false);
        params.setContainerType(Short.valueOf(params.getContainerCode().substring(0, 2)));
        workService.emptyPlateIn(params.getDevNo(), params.getContainerCode(), params.getContainerType(), getUserId(), false);
        return R.ok("生成工作档成功");
    }
@@ -148,11 +152,11 @@
    @PostMapping("/pakin/empty/auth")
    @Synchronized
    @ManagerAuth(memo = "空板入库")
    public R pakinEmpty(@RequestBody AgvMobileStartParam params){
    public R pakinEmpty(@RequestBody AgvMobileStartParam params) {
        for (AgvMobileStartParam.Pda pda : params.getPad()) {
            pda.setContainerType(Short.valueOf(pda.getContainerCode().substring(0,2)));
            workService.emptyPlateIn(pda.getDevNo(),pda.getContainerCode(),pda.getContainerType(), getUserId(),false);
            pda.setContainerType(Short.valueOf(pda.getContainerCode().substring(0, 2)));
            workService.emptyPlateIn(pda.getDevNo(), pda.getContainerCode(), pda.getContainerType(), getUserId(), false);
        }
        return R.ok();
@@ -164,10 +168,10 @@
    @PostMapping("/pakout/empty/auth")
    @Synchronized
    @ManagerAuth(memo = "空板出库")
    public R pakoutEmpty(@RequestBody AgvMobileStartParam params){
    public R pakoutEmpty(@RequestBody AgvMobileStartParam params) {
        for (AgvMobileStartParam.Pda pda : params.getPad()) {
            workService.emptyPlateOut(pda.getDevNo(),pda.getContainerType(), getUserId());
            workService.emptyPlateOut(pda.getDevNo(), pda.getContainerType(), getUserId());
        }
        return R.ok();
@@ -177,7 +181,7 @@
    空板出库货架码选择
     */
    @PostMapping("/pakout/empty/container/selector/auth")
    public R containerType(@RequestBody HashMap<String,String> params){
    public R containerType(@RequestBody HashMap<String, String> params) {
        String devNo = params.get("devNo");
        AgvBasDevp agvBasDevp = agvBasDevpService.selectById(devNo);
@@ -185,12 +189,12 @@
        return R.ok(agvLocMastService.queryContainerTypeByLocType1(agvBasDevp.getLocType1()));
    }
    /*
    查询库存 入库订单与销售单号
     */
    @PostMapping("/query/locDetl/v1")
    public R queryAgvLocDetl(@RequestBody HashMap<String,String> params){
    public R queryAgvLocDetl(@RequestBody HashMap<String, String> params) {
        String orderNo = params.get("orderNo");
        String threeCode = params.get("threeCode");
@@ -212,7 +216,7 @@
        for (AgvLocDetl agvLocDetl : agvLocDetls) {
            AgvLocMast agvLocMast = new AgvLocMast();
            if (Cools.isEmpty(floor)) {
                agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", agvLocDetl.getLocNo()).notLike("loc_no","F1"));
                agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", agvLocDetl.getLocNo()).notLike("loc_no", "F1"));
            } else {
                // 如果是加工单 只在 lev1 = 1 查库存
                if ("JG".equals(orderNo.substring(0,2))) {
@@ -377,24 +381,23 @@
        AgvLocMast agvLocMastByContainerCode = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("barcode", containerCode));
        AgvLocMast agvLocMastByLocNo = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", locNo));
        String barcode1 =  agvLocMastByLocNo.getBarcode();
        String barcode1 = agvLocMastByLocNo.getBarcode();
        if((!Cools.eq("F",agvLocMastByLocNo.getLocSts())
                && !Cools.eq("D",agvLocMastByLocNo.getLocSts()))){
        if ((!Cools.eq("F", agvLocMastByLocNo.getLocSts())
                && !Cools.eq("D", agvLocMastByLocNo.getLocSts()))) {
            return R.error("库位状态不为F或者D,无法维护");
        }
        // -------------1-----------------------------
        //库位信息为空 货架信息不为空
        if(Cools.isEmpty(listByLocNo) && !Cools.isEmpty(listByContainerCode)){
        if (Cools.isEmpty(listByLocNo) && !Cools.isEmpty(listByContainerCode)) {
            //更新货架信息的库位为当前库位
            listByContainerCode.forEach(agvLocDetl -> {
                String sourceLoc = agvLocDetl.getLocNo();
                agvLocDetl.setLocNo(locNo);
                agvLocDetlService.updateLocNo(locNo,sourceLoc,agvLocDetl);
                agvLocDetlService.updateLocNo(locNo, sourceLoc, agvLocDetl);
            });
            agvLocMastByLocNo.setLocSts("F");