#
Junjie
2024-05-30 7ce4419c34a54a968d4e9fe0e4f1b1a7595e868d
zy-asrs-common/src/main/java/com/zy/asrs/common/wms/service/impl/BasDevpServiceImpl.java
@@ -1,15 +1,24 @@
package com.zy.asrs.common.wms.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.zy.asrs.common.wms.entity.WrkMast;
import com.zy.asrs.common.wms.mapper.BasDevpMapper;
import com.zy.asrs.common.wms.entity.BasDevp;
import com.zy.asrs.common.wms.service.BasDevpService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.zy.asrs.common.wms.service.WrkMastService;
import com.zy.asrs.framework.exception.CoolException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.Collections;
import java.util.List;
@Service("basDevpService")
public class BasDevpServiceImpl extends ServiceImpl<BasDevpMapper, BasDevp> implements BasDevpService {
    @Autowired
    private WrkMastService wrkMastService;
    @Override
    public List<Integer> getAvailableInSite(Long hostId) {
@@ -26,4 +35,34 @@
        return this.baseMapper.getAvailableOutSite(typeNo, hostId);
    }
    @Override
    public List<Integer> getAvailableEmptyOutSite(Long hostId) {
        return this.baseMapper.getAvailableOutSite(110, hostId);
    }
    @Override
    public BasDevp checkSiteStatus(Integer devpNo, boolean pakin, Long hostId) {
        BasDevp station = this.getOne(new LambdaQueryWrapper<BasDevp>().eq(BasDevp::getDevNo, devpNo).eq(BasDevp::getHostId, hostId));
        if (station == null){
            throw new CoolException(devpNo + "站点不存在");
        }
        if (pakin) {
            if(station.getAutoing()==null || !station.getAutoing().equals("Y")) {
                throw new CoolException(devpNo + "站点不是自动状态");
            }
            if(station.getLoading()==null || !station.getLoading().equals("Y")) {
                throw new CoolException(devpNo + "站点无物");
            }
            if(station.getWrkNo()!=null && station.getWrkNo()>0 && station.getWrkNo() < 9990) {
                throw new CoolException(devpNo + "站点已有工作号");
            }
            if (wrkMastService.count(new LambdaQueryWrapper<WrkMast>()
                    .eq(WrkMast::getSourceStaNo, devpNo)
                    .in(WrkMast::getWrkSts, 1, 6)) > 0) {
                throw new CoolException(devpNo + "站点不能同时生成两笔入库工作档");
            }
        }
        return station;
    }
}