ZarshLocationService.java
3.38 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package com.huaheng.pc.sap.service;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.huaheng.api.utils.SAPUtils;
import com.huaheng.common.constant.QuantityConstant;
import com.huaheng.framework.web.domain.AjaxResult;
import com.huaheng.framework.web.service.ConfigService;
import com.huaheng.pc.config.location.domain.Location;
import com.huaheng.pc.config.location.service.LocationService;
import com.huaheng.pc.sap.domain.Zarsh;
import com.huaheng.pc.sap.mapper.ZarshMapper;
import com.huaheng.pc.task.taskHeader.domain.TaskHeader;
import com.huaheng.pc.task.taskHeader.service.TaskHeaderService;
/**
* Created by Enzo Cotter on 2022/5/11.
* @author zhouhong
*/
@Service
public class ZarshLocationService extends ServiceImpl<ZarshMapper, Zarsh> {
@Resource
private ZarsiService zarsiService;
@Resource
private TaskHeaderService taskHeaderService;
@Resource
private LocationService locationService;
@Resource
private ConfigService configService;
/**
* 配料仓中间仓查询任务表有几个未分配库位,库位表有无库位,预留2个库位
* 成品仓有方向标的查询任务表有几个未分配库位,库位表有无库位
* @param zarsh
* @param area
* @return
*/
public AjaxResult checkEmptyLocationCount(Zarsh zarsh, String area) {
// TODO 校验库位是否足够。
// TODO 换站任务校验跨站库区的库位数量。
// SAP入库站台编码
String fromPos = zarsh.getFromPos();
// 0 空托 1 有料
Integer inKind = zarsh.getInKind();
// 单独判断2E07和2E09这两个站台的空托盘入库
String zoneCode = SAPUtils.getZoneCode(zarsh);
if(inKind == 0){
switch (fromPos) {
case "2E07":
case "2E09":
area = "4";
zoneCode = "D";
break;
default:
}
}
LambdaQueryWrapper<TaskHeader> lambdaQuery = Wrappers.lambdaQuery();
lambdaQuery.eq(TaskHeader::getZoneCode, zoneCode)
.eq(TaskHeader::getInternalTaskType, QuantityConstant.TASK_INTENERTYPE_RECEIPT)
.eq(TaskHeader::getToLocation, "")
.lt(TaskHeader::getStatus, QuantityConstant.TASK_STATUS_COMPLETED);
// 查询未分配库位的任务数量
Integer noLocationTaskCount = taskHeaderService.count(lambdaQuery);
LambdaQueryWrapper<Location> localLambdaQuery = Wrappers.lambdaQuery();
localLambdaQuery.eq(Location::getZoneCode, zoneCode)
.eq(Location::getStatus, QuantityConstant.STATUS_LOCATION_EMPTY)
.eq(Location::getContainerCode, "");
Integer emptyLocationCount = locationService.count(localLambdaQuery);
// 空闲库位数量减去未分配的任务数量,如果空闲库位数量小于2,任务下发失败。
if ((emptyLocationCount.intValue() - noLocationTaskCount.intValue()) <= 2) {
return AjaxResult.error(zoneCode.concat("库区排除未分配库位的入库任务,剩余空闲库位小于2个。"));
}
return AjaxResult.success();
}
}