自动化立体仓库 - WMS系统
#
LSH
2022-11-25 7059a74b4213af5e3c6de691ef92564e3cb1c316
src/main/java/com/zy/asrs/controller/WrkMastController.java
@@ -10,10 +10,13 @@
import com.core.common.Cools;
import com.core.common.DateUtils;
import com.core.common.R;
import com.zy.asrs.entity.WrkMast;
import com.zy.asrs.service.WrkMastService;
import com.core.exception.CoolException;
import com.zy.asrs.entity.*;
import com.zy.asrs.entity.dto.WrkDetlWithCheck;
import com.zy.asrs.service.*;
import com.zy.common.web.BaseController;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.*;
import java.util.*;
@@ -23,6 +26,16 @@
    @Autowired
    private WrkMastService wrkMastService;
    @Autowired
    private WrkDetlService wrkDetlService;
    @Autowired
    private LocMastService locMastService;
    @Autowired
    private LocDetlService locDetlService;
    @Autowired
    private MatService matService;
    @Autowired
    private CheckRecordService checkRecordService;
    @RequestMapping(value = "/wrkMast/{id}/auth")
    @ManagerAuth
@@ -53,14 +66,15 @@
        return R.ok(wrkMastService.selectPage(new Page<>(curr, limit), wrapper));
    }
    private void convert(Map<String, Object> map, EntityWrapper wrapper){
    private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){
        for (Map.Entry<String, Object> entry : map.entrySet()){
            if (entry.getKey().endsWith(">")) {
                wrapper.ge(Cools.deleteChar(entry.getKey()), DateUtils.convert(String.valueOf(entry.getValue())));
            } else if (entry.getKey().endsWith("<")) {
                wrapper.le(Cools.deleteChar(entry.getKey()), DateUtils.convert(String.valueOf(entry.getValue())));
            String val = String.valueOf(entry.getValue());
            if (val.contains(RANGE_TIME_LINK)){
                String[] dates = val.split(RANGE_TIME_LINK);
                wrapper.ge(entry.getKey(), DateUtils.convert(dates[0]));
                wrapper.le(entry.getKey(), DateUtils.convert(dates[1]));
            } else {
                wrapper.like(entry.getKey(), String.valueOf(entry.getValue()));
                wrapper.eq(entry.getKey(), val);
            }
        }
    }
@@ -165,4 +179,250 @@
    }
    /********************************边锋新增**************************/
    @RequestMapping(value = "/wrkMast/red/wrk/mast")
    @ManagerAuth(memo = "维护工作档")
    public R redWrkMast(@RequestBody List<WrkMast> list) {
        if (list.isEmpty()) {
            return R.error("请至少选择一行数据");
        }
        StringBuilder logWrkMast= new StringBuilder();
        try{
            for (WrkMast entity : list){
                WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>().eq("wrk_no", entity.getWrkNo()));
                if (Cools.isEmpty(wrkMast)){
                    continue;
                }
                if (wrkMast.getIoType()==1 || wrkMast.getIoType()==10){//1.入库//10.空板入库
//                LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", wrkMast.getLocNo()));
//                if (Cools.isEmpty(locMast)){
//                    logWrkMast=logWrkMast+"工作号:"+wrkMast.getWrkNo()+"库位查询为无!"+"//n";
//                    continue;
//                }
//                if (wrkMast.getWrkSts()==9){//9.入库完成
//                    if (locMast.getLocSts().equals("F")){//F.在库
//                        over(wrkMast);
//                    }else if (locMast.getLocSts().equals("S")){//S.入库预约
//                        doIn(wrkMast,locMast);
//                    }
//                }
                    continue;
                }else if (wrkMast.getIoType()==53 || wrkMast.getIoType()==57){//53.拣料再入库//57.盘点再入库
                    continue;
                }else if (wrkMast.getIoType()==101 || wrkMast.getIoType()==110){//101.出库//110.空板出库
                    LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", wrkMast.getSourceLocNo()));
                    if (Cools.isEmpty(locMast)){
                        logWrkMast.append("工作号:").append(wrkMast.getWrkNo()).append("库位查询为无!").append("//n");
                        continue;
                    }
                    if (wrkMast.getWrkSts()==17){//17.出库完成
                        if (locMast.getLocSts().equals("O")){//O.空库位
                            logWrkMast.append("维护工作档:").append(wrkMast.getWrkNo()).append("//n");
                        }else if (locMast.getLocSts().equals("R")){//R.出库预约
                            doOut(wrkMast,locMast);
                            logWrkMast.append("维护工作档:").append(wrkMast.getWrkNo()).append("//n");
                        }else {
                            logWrkMast.append("工作号:").append(wrkMast.getWrkNo()).append(" 库位状态异常!").append("//n");
                            continue;
                        }
                        wrkMast.setWrkSts(18L);
                        wrkMastService.update(wrkMast,new EntityWrapper<WrkMast>().eq("wrk_no",wrkMast.getWrkNo()));
                    }
//                    else if (wrkMast.getWrkSts()==18){//18.出库更新完成
//                        if (locMast.getLocSts().equals("O")){//O.空库位
//                            over(wrkMast);
//                            logWrkMast.append("维护工作档:").append(wrkMast.getWrkNo()).append("//n");
//                        }else if (locMast.getLocSts().equals("R")){//R.出库预约
//                            doOut(wrkMast,locMast);
//                            over(wrkMast);
//                            logWrkMast.append("维护工作档:").append(wrkMast.getWrkNo()).append("//n");
//                        } else {
//                            logWrkMast.append("工作号:").append(wrkMast.getWrkNo()).append(" 库位状态异常!").append("//n");
//                            continue;
//                        }
//                        wrkMastService.delete(new EntityWrapper<WrkMast>().eq("wrk_no",wrkMast.getWrkNo()));
//                    }
                }else if (wrkMast.getIoType()==103 || wrkMast.getIoType()==107){//103.拣料出库//107.盘点出库
                    continue;
                }
            }
        }catch (Exception e){
            return R.error(logWrkMast+"操作失败");
        }
        return R.ok(logWrkMast+"操作成功");
    }
    private void doOut(WrkMast wrkMast,LocMast locMast){
        try{
            Date now = new Date();
            // 删除工作档源库位的库存明细
            if (!locDetlService.delete(new EntityWrapper<LocDetl>().eq("loc_no", wrkMast.getSourceLocNo()))) {
                throw new CoolException("删除库存明细失败:workNo="+wrkMast.getWrkNo()+"sourceLocNo="+wrkMast.getSourceLocNo());
            }
            // 修改源库位状态 R ===>> O
            if (locMast.getLocSts().equals("R")) {
                locMast.setLocSts("O");
                locMast.setBarcode("");
                locMast.setFrozen(0);
                locMast.setModiTime(now);
                locMast.setIoTime(now);
                locMast.setFrozenMemo("");
                if (!locMastService.updateById(locMast)) {
                    throw new CoolException("修改源库位状态失败:workNo="+wrkMast.getWrkNo()+"sourceLocNo="+wrkMast.getSourceLocNo());
                }
            }
        }catch (Exception e){
            throw new CoolException(e+"操作失败");
        }
    }
    private void doIn(WrkMast wrkMast,LocMast locMast){ }
    private void over(WrkMast wrkMast){
    }
    @GetMapping(value = "/wrkMast/checkDetl")
    public R pickDetl(String barcode) {
        WrkMast wrkMast = wrkMastService.selectByBarcode(barcode);
        if (Cools.isEmpty(wrkMast)) {
            return R.error("无法通过托盘码找到对应工作档");
        }
        if (wrkMast.getIoType() != 107) {
            return R.error("工作档非捡料任务");
        }
        if (wrkMast.getWrkSts() != 17){
            return R.error("盘点任务正在执行中,请等待设备运行结束后进行操作");
        }
        List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo());
        return R.ok(wrkDetls);
    }
    /**
     * 根据盘点修改库存
     * @return
     */
    @Transactional
    @PostMapping("/wrkMast/storeCheck")
    @ManagerAuth(memo = "根据盘点修改库存")
    public R storeCheck(@RequestBody List<WrkDetlWithCheck> wrkDetls){
        Date now = new Date();
        Integer confirmIsZero = 0;
        if (wrkDetls == null || wrkDetls.size() <= 0){
            return R.error("请传入数据");
        }
        if (Cools.isEmpty(wrkDetls.get(0).getBarcode())) {
            return R.error("托盘码[barcode]为空");
        }
        WrkMast wrkMast = wrkMastService.selectByBarcode(wrkDetls.get(0).getBarcode());
        for (WrkDetlWithCheck wrkDetl : wrkDetls) {
            if (Cools.isEmpty(wrkDetl.getBarcode())) {
                return R.error("托盘码[barcode]为空");
            }
            if (Cools.isEmpty(wrkDetl.getMatnr())) {
                return R.error("物料编码[matnr]为空");
            }
            Mat mat = matService.selectByMatnr(wrkDetl.getMatnr());
            if (Cools.isEmpty(mat)) {
                return R.error("物料编码[matnr]在物料档案找不到");
            }
            if (Cools.isEmpty(wrkDetl.getAnfme())) {
                return R.error("盘点前数量[anfme]为空");
            }
            if (wrkDetl.getConfirmQty() == null) {
                return R.error("盘点确认量[confirm]为空");
            }
            if (wrkDetl.getConfirmQty() == 0){
                confirmIsZero++;
            }
        }
        /**
         * 如果整个list里的confirmQty数量全是0, 表示整个库位无任何库存,删工作档, 库位改为O
         */
        if (confirmIsZero == wrkDetls.size()){
            locDetlService.delete(new EntityWrapper<LocDetl>()
                    .eq("loc_no",wrkMast.getSourceLocNo()));
            locMastService.updateLocSts(wrkMast.getSourceLocNo(),"O");
            wrkMastService.delete(new EntityWrapper<WrkMast>()
                    .eq("wrk_no",wrkMast.getWrkNo()));
            wrkDetlService.delete(new EntityWrapper<WrkDetl>()
                    .eq("wrk_no",wrkMast.getWrkNo()));
            return R.ok("库存清理成功");
        }else {
            locMastService.updateLocSts(wrkMast.getSourceLocNo(),"F");
            locDetlService.delete(new EntityWrapper<LocDetl>()
                    .eq("loc_no",wrkMast.getSourceLocNo()));
            for (WrkDetlWithCheck wrkDetl : wrkDetls) {
                LocDetl locDetl = new LocDetl();
                Mat mat = matService.selectByMatnr(wrkDetl.getMatnr());
                locDetl.sync(mat);
                locDetl.setZpallet(wrkMast.getBarcode());
                locDetl.setAnfme(wrkDetl.getConfirmQty());
                locDetl.setBatch(wrkDetl.getBatch());
                locDetl.setAppeTime(now);
                locDetl.setModiTime(now);
                locDetl.setAppeUser(getUserId());
                locDetl.setModiUser(getUserId());
                locDetl.setLocNo(wrkMast.getSourceLocNo());
                locDetlService.insert(locDetl);
                CheckRecord checkRecord = new CheckRecord();
                checkRecord.sync(mat);
                checkRecord.setAnfme(wrkDetl.getAnfme());
                checkRecord.setBarcode(wrkMast.getBarcode());
                checkRecord.setLocNo(wrkMast.getSourceLocNo());
                checkRecord.setCreateTime(now);
                checkRecord.setBatch(wrkDetl.getBatch());
                checkRecord.setConfirmQty(locDetl.getAnfme());
                checkRecordService.insert(checkRecord);
            }
        }
        return R.ok("库存更新已成功");
    }
    @GetMapping("/wrkMast/pickToFill")
    public R pickToFill(String barcode){
        Date now = new Date();
        if (Cools.isEmpty(barcode)) {
            return R.error("托盘码为空,请检查");
        }
        WrkMast wrkMast = wrkMastService.selectByBarcode(barcode);
        if (Cools.isEmpty(wrkMast)) {
            return R.error("无法通过托盘码找到该工作档,请检查托盘码是否正确");
        }
        if (wrkMast.getIoType() != 103) {
            return R.error("仅有捡料出库可以使用该功能");
        }
        if (wrkMast.getWrkSts() != 17) {
            return R.error("捡料出库未完成,请等待设备运行完成");
        }
        wrkMast.setIoType(101);
        wrkMast.setMemo("捡料转全板工作档");
        wrkMastService.update(wrkMast,new EntityWrapper<WrkMast>()
                .eq("wrk_no",wrkMast.getWrkNo()));
        wrkDetlService.deleteByWrkNo(wrkMast.getWrkNo());
        List<LocDetl> locDetls = locDetlService.selectByLocNo(wrkMast.getSourceLocNo());
        for (LocDetl locDetl : locDetls) {
            WrkDetl wrkDetl = new WrkDetl();
            wrkDetl.sync(locDetl);
            wrkDetl.setWrkNo(wrkMast.getWrkNo());
            wrkDetl.setIoTime(wrkMast.getIoTime());
            wrkDetl.setZpallet(wrkDetl.getBarcode());
            wrkDetl.setBarcode(wrkMast.getBarcode());
            wrkDetl.setAppeTime(now);
            wrkDetl.setModiTime(now);
            wrkDetl.setAppeUser(1L);
            wrkDetl.setModiUser(1L);
            wrkDetlService.insert(wrkDetl);
        }
        locMastService.updateLocSts(wrkMast.getSourceLocNo(),"R");
        return R.ok();
    }
}