package com.zy.asrs.service.impl;
|
|
import com.baomidou.mybatisplus.mapper.EntityWrapper;
|
import com.baomidou.mybatisplus.mapper.Wrapper;
|
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
|
import com.core.common.Cools;
|
import com.zy.asrs.entity.*;
|
import com.zy.asrs.mapper.AgvBasDevpMapper;
|
import com.zy.asrs.service.*;
|
import com.zy.common.model.AgvBasDevpDto;
|
import org.springframework.beans.BeanUtils;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
import org.springframework.transaction.annotation.Transactional;
|
|
import java.util.*;
|
import java.util.stream.Collectors;
|
|
@Service
|
@Transactional
|
public class AgvBasDevpServiceImpl extends ServiceImpl<AgvBasDevpMapper, AgvBasDevp> implements AgvBasDevpService {
|
|
@Autowired
|
AgvBasDevpMapper agvBasDevpMapper;
|
@Autowired
|
AgvWrkMastService agvWrkMastService;
|
@Autowired
|
AgvWrkDetlService agvWrkDetlService;
|
@Autowired
|
AgvWaitPakinService agvWaitPakinService;
|
@Autowired
|
AgvLocDetlService agvLocDetlService;
|
|
public void clearBasDevp(){
|
agvBasDevpMapper.deleteAll();
|
}
|
|
public void initBasDevp(){
|
|
//初始化1楼缓存货架站点 2排5列3层
|
this.insertBatch(getCacheBasDevpList(1,2,1,5,1,3,1));
|
//初始化3楼缓存货架站点 3排5列3层
|
this.insertBatch(getCacheBasDevpList(5,9,1,5,1,3,3));
|
//初始化3楼输送线工作站点 4个站点
|
this.insertBatch(getLineBasDevpList());
|
|
}
|
|
private List<AgvBasDevp> getLineBasDevpList(){
|
List<AgvBasDevp> agvBasDevpList = new ArrayList<>();
|
Date now = new Date();
|
for(int row=1; row<=4; row++){
|
agvBasDevpList.add(getAgvBasDevp(row,1,1,3,"N",now));
|
}
|
return agvBasDevpList;
|
}
|
|
//根据排列层获取AGV缓存货架站点列表
|
private List<AgvBasDevp> getCacheBasDevpList(int rowIndex, int rowMax, int bayIndex, int bayMax, int levIndex, int levMax, int floor){
|
List<AgvBasDevp> agvBasDevpList = new ArrayList<>();
|
Date now = new Date();
|
for(int row=rowIndex; row<=rowMax; row++){
|
for(int bay=bayIndex; bay<=bayMax; bay++){
|
for(int lev=levIndex; lev<=levMax; lev++){
|
agvBasDevpList.add(getAgvBasDevp(row,bay,lev,floor,"Y",now));
|
}
|
}
|
}
|
|
return agvBasDevpList;
|
}
|
|
private AgvBasDevp getAgvBasDevp(int row, int bay, int lev, int floor, String cacheShelves, Date now){
|
AgvBasDevp agvBasDevp = new AgvBasDevp();
|
String devNo = "CS-" + floor + "0" + row + "-00" + bay + "-0" + lev + "@" + floor;
|
String stationCode = "CS-" + floor + "0" + row;
|
agvBasDevp.setDevNo(devNo);
|
agvBasDevp.setStationCode(stationCode);
|
agvBasDevp.setLocSts("O");
|
agvBasDevp.setCacheShelves(cacheShelves);
|
agvBasDevp.setFloor(floor);
|
agvBasDevp.setModiTime(now);
|
agvBasDevp.setAppeTime(now);
|
return agvBasDevp;
|
}
|
|
public void updateLocStsAndBarcodeByDevNo(String devNo, String locSts, String barcode){
|
|
AgvBasDevp agvBasDevp = this.selectById(devNo);
|
agvBasDevp.setLocSts(locSts);
|
agvBasDevp.setBarcode(barcode);
|
this.updateById(agvBasDevp);
|
}
|
|
public Map<String, Object> getAgvBasDevpDtoByStationCode(String stationCode) {
|
|
List<Map<String, Object>> body = new ArrayList<>();
|
for(int i=3; i>=1; i--){
|
Wrapper<AgvBasDevp> wrapper = new EntityWrapper<AgvBasDevp>()
|
.eq("station_code", stationCode)
|
.like("dev_no", "0" + i + "@");
|
|
List<String> list = this.selectCacheShelvesStationCodeByFloor(3);
|
if(list.contains(stationCode)){
|
if(Cools.eq(stationCode,"CS-305") || Cools.eq(stationCode,"CS-306") || Cools.eq(stationCode,"CS-307")){
|
wrapper.orderBy("dev_no",false);
|
}
|
}
|
|
List<AgvBasDevp> agvBasDevpList = this.selectList(wrapper);
|
|
Map<String, Object> map = new HashMap<>();
|
|
List<AgvBasDevpDto> agvBasDevpDtoList = agvBasDevpList.stream().map(agvBasDevp -> {
|
AgvBasDevpDto agvBasDevpDto = new AgvBasDevpDto();
|
BeanUtils.copyProperties(agvBasDevp, agvBasDevpDto);
|
|
//如果工作位状态为0.空库位,则直接返回
|
if("O".equals(agvBasDevpDto.getLocSts())){
|
return agvBasDevpDto;
|
}
|
|
List<AgvWrkMast> agvWrkMasts = agvWrkMastService.selectList(new EntityWrapper<AgvWrkMast>()
|
.eq("loc_no", agvBasDevpDto.getDevNo())
|
.or().eq("source_loc_no",agvBasDevpDto.getDevNo()));
|
|
AgvWrkMast agvWrkMast = null;
|
for (AgvWrkMast wrkMast : agvWrkMasts){
|
if(Cools.isEmpty(agvWrkMast)){
|
agvWrkMast = wrkMast;
|
}else {
|
if(agvWrkMast.getWrkSts() < wrkMast.getWrkSts()){
|
agvWrkMast = wrkMast;
|
}
|
}
|
}
|
|
agvBasDevpDto.setAgvWrkMast(agvWrkMast);
|
|
if("F".equals(agvBasDevpDto.getLocSts()) || "R".equals(agvBasDevpDto.getLocSts())){
|
AgvWaitPakin agvWaitPakin = agvWaitPakinService.selectOne(new EntityWrapper<AgvWaitPakin>()
|
.eq("supp_code", agvBasDevpDto.getBarcode()));
|
|
agvBasDevpDto.setAgvWaitPakin(agvWaitPakin);
|
|
if(Cools.isEmpty(agvWaitPakin)){
|
AgvWrkDetl agvWrkDetl = agvWrkDetlService.selectOne(new EntityWrapper<AgvWrkDetl>().
|
eq("wrk_no",agvWrkMast.getWrkNo()));
|
//agv站点可视化管理中的结余数量显示
|
agvWrkDetl.setVolume(0.0);
|
if(agvWrkMast.getIoType() == 103){
|
AgvLocDetl agvLocDetl = agvLocDetlService.selectByLocNo(agvWrkMast.getSourceLocNo());
|
agvWrkDetl.setVolume(agvLocDetl.getAnfme() - agvWrkDetl.getAnfme());
|
}
|
if(agvWrkMast.getIoType() == 53){
|
AgvLocDetl agvLocDetl = agvLocDetlService.selectByLocNo(agvWrkMast.getLocNo());
|
agvWrkDetl.setVolume(agvLocDetl.getAnfme());
|
//agvWrkDetl.setAnfme(agvLocDetl.getAnfme() - agvWrkDetl.getAnfme());
|
}
|
agvBasDevpDto.setAgvWrkDetl(agvWrkDetl);
|
}
|
}
|
|
if(!Cools.isEmpty(agvWrkMast)){
|
setFlagForAgvBasDevpDto(agvWrkMast,agvBasDevpDto);
|
}
|
|
return agvBasDevpDto;
|
|
}).collect(Collectors.toList());
|
|
map.put("loc",agvBasDevpDtoList);
|
body.add(map);
|
}
|
|
Map<String, Object> result = new HashMap<>();
|
result.put("body", body);
|
|
return result;
|
}
|
|
private void setFlagForAgvBasDevpDto(AgvWrkMast agvWrkMast, AgvBasDevpDto agvBasDevpDto){
|
//当工作档类型为101.出库 并且 工作位状态为F.在库时,显示容器离场按钮
|
if(agvWrkMast.getIoType() == 101 && "F".equals(agvBasDevpDto.getLocSts())){
|
agvBasDevpDto.setContainerMoveOutFlag(true);
|
}
|
|
//当工作档类型为101.出库 并且 工作位状态为F.在库时,显示容器离场按钮
|
if(agvWrkMast.getIoType() == 110 && "D".equals(agvBasDevpDto.getLocSts())){
|
agvBasDevpDto.setContainerMoveOutFlag(true);
|
}
|
|
//当工作档类型为103.拣料出库 并且 工作位状态为F.在库时,显示拣料/盘点入库按钮
|
if(agvWrkMast.getIoType() == 103 && "F".equals(agvBasDevpDto.getLocSts())){
|
agvBasDevpDto.setPickInFlag(true);
|
}
|
//当工作档类型为107.盘点出库 并且 工作位状态为F.在库时,显示拣料/盘点入库按钮
|
if(agvWrkMast.getIoType() == 107 && "F".equals(agvBasDevpDto.getLocSts())){
|
agvBasDevpDto.setPickInFlag(true);
|
}
|
}
|
|
public List<String> getAvailableEmptyInSite() {
|
return this.baseMapper.getAvailableEmptyInSite();
|
}
|
|
public AgvBasDevp getByDevNo(String devNo) {
|
return this.selectOne(new EntityWrapper<AgvBasDevp>().eq("dev_no",devNo));
|
}
|
|
@Override
|
public AgvBasDevp selectEmptyDevpByStation(String stationCode) {
|
return this.selectOne(new EntityWrapper<AgvBasDevp>()
|
.eq("station_code", stationCode)
|
.eq("loc_sts", "O"));
|
}
|
|
@Override
|
public List<AgvBasDevp> getBasDevpByNoCacheShelves() {
|
return this.selectList(new EntityWrapper<AgvBasDevp>().eq("cache_shelves","N"));
|
}
|
|
@Override
|
public List<String> selectCacheShelvesStationCodeByFloor(int floor) {
|
//Object o = this.selectList(new EntityWrapper<AgvBasDevp>().setSqlSelect("station_code").eq("floor",floor).eq("cache_shelves","Y").groupBy("station_code"));
|
return this.baseMapper.selectCacheShelvesStationCodeByFloor(floor);
|
}
|
|
public List<Map<String,Object>> selectDevNoAndNumBystationCode(String stationCode){
|
return this.baseMapper.selectDevNoAndNumBystationCode(stationCode);
|
}
|
|
@Override
|
public List<String> selectAllStationCode() {
|
return this.baseMapper.selectAllStationCode();
|
}
|
|
}
|