ZarshLocationService.java
4.41 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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
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 换站任务校验跨站库区的库位数量。
// P4004通道堵塞 TRUE为堵塞 FALSE为正常
boolean isBlock = false;
// 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":
LambdaQueryWrapper<TaskHeader> query = Wrappers.lambdaQuery();
query.eq(TaskHeader::getTaskType, QuantityConstant.TASK_TYPE_EMPTYRECEIPT)
.eq(TaskHeader::getZoneCode, "D")
.eq(TaskHeader::getPort, "P4004")
.lt(TaskHeader::getStatus, QuantityConstant.TASK_STATUS_COMPLETED);
int count = taskHeaderService.count(query);
if (count >= 4){
isBlock = true;
area = "5";
zoneCode = "E";
}else{
area = "4";
zoneCode = "D";
}
break;
default:
}
}
switch (zoneCode){
case "DX":
return AjaxResult.success();
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) {
if(isBlock){
return AjaxResult.error("配料仓空闲库位不够两个并且P4004通道堵塞,请等待通道恢复。");
}
return AjaxResult.error(zoneCode.concat("库区排除未分配库位的入库任务,剩余空闲库位小于2个。"));
}
return AjaxResult.success();
}
}