|  |  |  | 
|---|
|  |  |  | 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() { | 
|---|
|  |  |  | return this.baseMapper.getAvailableInSite(1); | 
|---|
|  |  |  | public List<Integer> getAvailableInSite(Long hostId) { | 
|---|
|  |  |  | return this.baseMapper.getAvailableInSite(1, hostId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Integer> getAvailableEmptyInSite() { | 
|---|
|  |  |  | return this.baseMapper.getAvailableInSite(10); | 
|---|
|  |  |  | public List<Integer> getAvailableEmptyInSite(Long hostId) { | 
|---|
|  |  |  | return this.baseMapper.getAvailableInSite(10, hostId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Integer> getAvailableOutSite(Integer typeNo) { | 
|---|
|  |  |  | return this.baseMapper.getAvailableOutSite(typeNo); | 
|---|
|  |  |  | public List<Integer> getAvailableOutSite(Integer typeNo, Long hostId) { | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|