自动化立体仓库 - WMS系统
#
zyx
2024-04-23 c7bf4b8773f888fd5be613b7bb6fb8ae4a47b028
src/main/java/com/zy/asrs/controller/MobileController.java
@@ -1,6 +1,5 @@
package com.zy.asrs.controller;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
@@ -14,6 +13,7 @@
import com.zy.asrs.entity.result.MobileAdjustResult;
import com.zy.asrs.mapper.ManLocDetlMapper;
import com.zy.asrs.service.*;
import com.zy.asrs.utils.SaasUtils;
import com.zy.common.model.WrkDto;
import com.zy.common.web.BaseController;
import com.zy.system.entity.User;
@@ -56,6 +56,8 @@
    private ManLocDetlMapper manLocDetlMapper;
    @Autowired
    private PlaService plaService;
    @Autowired
    private NodeService nodeService;
    // 商品上架
@@ -427,8 +429,9 @@
        JSONArray jsonArray = JSONArray.parseArray(json.getJSONArray("pla").toJSONString());
        for (Object o : jsonArray){
            JSONObject jsonObject = (JSONObject)o;
            String brand = jsonObject.get("brand").toString();
            String batch = jsonObject.get("batch").toString();
            String packageNo = jsonObject.get("packageNo").toString();
            Integer packageNo = Integer.parseInt(jsonObject.get("packageNo").toString());
            if(Cools.isEmpty(locNo) || Cools.isEmpty(batch) || Cools.isEmpty(packageNo)){
                return R.error("有参数为空,无法入库");
            }
@@ -436,7 +439,7 @@
            if(true){
                User user = new User();
                user.setUsername("test");
                mobileService.plaPakin(locNo,batch,packageNo,user);
                mobileService.plaPakin(brand,locNo,batch,packageNo,user);
            }
        }
        return R.ok("入库成功");
@@ -446,18 +449,20 @@
//    @ManagerAuth(memo="pla出库")
    public R plaPackOut1(@RequestBody JSONObject json){
        String locNo = json.get("locNo").toString();
        String brand = json.get("brand").toString();
        String batch = json.get("batch").toString();
        String packageNo = json.get("packageNo").toString();
        Integer packageNo = Integer.parseInt(json.get("packageNo").toString());
        String orderNo = json.get("orderNo").toString();
        String orderDetlId = json.get("orderDetlId").toString();
        String wrkNo = json.get("wrkNo").toString();
        Double anfme = Double.parseDouble(json.get("anfme").toString());
        boolean isReplace = Cools.eq(json.get("replace").toString(),"y");
        if(Cools.isEmpty(locNo) || Cools.isEmpty(batch) || Cools.isEmpty(packageNo)){
            return R.error("有参数为空,无法入库");
        }
        mobileService.plaPakout(locNo,batch,packageNo,orderNo,orderDetlId,wrkNo,anfme);
        mobileService.plaPakout(brand,locNo,batch,packageNo,orderNo,orderDetlId,wrkNo,anfme,isReplace);
        return R.ok();
    }
@@ -465,48 +470,146 @@
//    @ManagerAuth(memo="pla出库")
    public R plaPackOut(@RequestBody JSONObject json){
        String locNo = json.get("locNo").toString();
        String brand = json.get("brand").toString();
        String batch = json.get("batch").toString();
        String packageNo = json.get("packageNo").toString();
        Integer packageNo = Integer.parseInt(json.get("packageNo").toString());
        String orderNo = json.get("orderNo").toString();
        String orderDetlId = json.get("orderDetlId").toString();
        String plaQtyId = json.get("orderDetlId").toString();
        String wrkNo = json.get("wrkNo").toString();
        Double anfme = Double.parseDouble(json.get("anfme").toString());
        boolean isReplace = !Cools.isEmpty(json.get("replace")) && Cools.eq(json.get("replace").toString(),"y");
        if(Cools.isEmpty(locNo) || Cools.isEmpty(batch) || Cools.isEmpty(packageNo)){
            return R.error("有参数为空,无法入库");
        }
        mobileService.plaPakout(locNo,batch,packageNo,orderNo,orderDetlId,wrkNo,anfme);
        mobileService.plaPakout(brand,locNo,batch,packageNo,orderNo,plaQtyId,wrkNo,anfme,isReplace);
        return R.ok();
    }
    /*
    无订单拣货出库
     */
    @RequestMapping("/plaDetl/packout/noOrder/v1")
    //@ManagerAuth(memo="pla手动出库")
    public R plaPackOutWithoutOrder(@RequestBody List<PlaParam> params){
        for (PlaParam param : params){
            mobileService.plaPackOutWithoutOrder(param.getBrand(),param.getBatch(),param.getPackageNo(),param.getAnfme());
        }
        return R.ok();
    }
    @RequestMapping("/plaDetl/check/v1")
    public R plaDetlCheck(@RequestBody JSONObject json){
        String brand = json.get("brand").toString();
        String batch = json.get("batch").toString();
        String packageNo = json.get("packageNo").toString();
        Integer packageNo = Integer.parseInt(json.get("packageNo").toString());
        Integer type = Integer.parseInt(json.get("type").toString());
        if(Cools.isEmpty(batch) || Cools.isEmpty(packageNo)){
            return R.error("有参数为空,无法入库");
        }
        Pla pla = plaService.selectByBatchAndPackageNo(batch, packageNo);
        Pla pla = plaService.selectByBatchAndPackageNo(batch, packageNo,brand);
        if ((Cools.isEmpty(pla))){
            return R.error("该包物料未录入,无法查询到相关信息");
        }
        if(!Cools.eq(pla.getStatus(), GlobleParameter.PLA_STATUS_0)){
        if(!(Cools.eq(pla.getStatus(), GlobleParameter.PLA_STATUS_0) || Cools.eq(pla.getStatus(), GlobleParameter.PLA_STATUS_00)) && type != 2){
            return R.error("该包物料不为待入库状态,无法进行入库操作");
        }
        return R.ok(pla);
    }
    /*
    pla移库
     */
    @RequestMapping("/plaDetl/move/v1")
    @ManagerAuth
    public R plaDetlMove(@RequestBody PlaMoveParam param){
        String locNo = param.getLocNo();
        Node node = nodeService.selectByUuid(locNo);
        if(Cools.isEmpty(node)){
            throw new CoolException("库位信息不正确");
        }
        List<PlaMoveParam.PlaMove> plas = param.getPlas();
        param.getPlas().forEach(p -> {
            String brand = p.getBrand();
            String batch = p.getBatch();
            Integer packageNo = p.getPackageNo();
            if(Cools.isEmpty(batch) || Cools.isEmpty(packageNo)){
                throw new CoolException("有参数为空,无法入库");
            }
            Pla pla = plaService.selectByBatchAndPackageNo(batch, packageNo,brand);
            if ((Cools.isEmpty(pla))){
                throw new CoolException("该包物料未录入,无法查询到相关信息");
            }
            if(!Cools.eq(pla.getStatus(),GlobleParameter.PLA_STATUS_1) && !Cools.eq(pla.getStatus(),GlobleParameter.PLA_STATUS_3)){
                throw new CoolException("该包物料状态不为入库状态,无法转移");
            }
            String sourceLocNo = pla.getLocNo();
            pla.setLocNo(locNo);
            pla.setStash(node.getParentName());
            pla.setModifyTime(new Date());
            plaService.updateById(pla);
            SaasUtils.insertLog(2,sourceLocNo,pla.getBrand(),pla.getWeightAnfme(),getUser().getUsername(),
                    locNo,pla.getBatch(),pla.getPackageNo(),pla.getOwner(),pla.getWorkshop());
        });
        return R.ok("移库成功");
    }
    /*
    根据拣货单出库 ------> 获取拣货单
     */
    @RequestMapping("/manpakout/check/v1")
    public R getManPakout (@RequestBody JSONObject json){
        String orderNo = json.get("orderNo").toString();
        return R.ok(mobileService.getManPakoutByOrderNo(orderNo));
    }
    @RequestMapping("/manpakout/pakout/v1")
    public R pakout(@RequestBody JSONObject json){
        String batch = json.get("batch").toString();
        Integer packageNo = Integer.parseInt(json.get("packageNo").toString());
        String orderNo = json.get("orderNo").toString();
        return R.ok();
    }
    @RequestMapping("select/mat/information/v1")
    @ManagerAuth
    public R pdaSelectInformation(@RequestParam String barcode){
        List<Pla> locDetls = mobileService.pdaSelectInfmt(barcode);
        return R.ok(locDetls);
    }
    public static void main(String[] args) {
        String aa = "[{\"batch\":\"2023090304\",\"packageNo\":\"8\"},{\"batch\":\"2023090304\",\"packageNo\":\"8\"}]";
        JSONArray jsonArray = JSON.parseArray(aa);
        Object o = jsonArray.get(0);
        System.out.println(o.toString());
        JSONObject jsonObject = (JSONObject)o;
        System.out.println(jsonObject);
//        String aa = "[{\"batch\":\"2023090304\",\"packageNo\":\"8\"},{\"batch\":\"2023090304\",\"packageNo\":\"8\"}]";
//        JSONArray jsonArray = JSON.parseArray(aa);
//        Object o = jsonArray.get(0);
//        System.out.println(o.toString());
//        JSONObject jsonObject = (JSONObject)o;
//        System.out.println(jsonObject);
        String s = "2024010502";
        System.out.println(s.substring(8,10));
        Object s1 = "8";
        System.out.println(Integer.parseInt(s1.toString()));
    }
}