ScPdaService.java
15.6 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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
package com.huaheng.api.tv.service;
import com.aliyun.oss.ServiceException;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.huaheng.api.general.domain.ReceiptDomain;
import com.huaheng.api.general.domain.ShipmentDomain;
import com.huaheng.api.general.service.ReceiptApiService;
import com.huaheng.api.general.service.ShipmentApiService;
import com.huaheng.api.mes.domain.MesTask;
import com.huaheng.api.tv.domain.ScpPdaReceiptBean;
import com.huaheng.api.tv.domain.ScpPdaShipmentBean;
import com.huaheng.common.constant.QuantityConstant;
import com.huaheng.common.support.Convert;
import com.huaheng.common.utils.DateUtils;
import com.huaheng.common.utils.StringUtils;
import com.huaheng.common.utils.Wrappers;
import com.huaheng.common.utils.security.ShiroUtils;
import com.huaheng.framework.web.domain.AjaxResult;
import com.huaheng.pc.config.container.domain.Container;
import com.huaheng.pc.config.container.service.ContainerService;
import com.huaheng.pc.config.location.domain.Location;
import com.huaheng.pc.config.location.service.LocationService;
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.material.service.MaterialService;
import com.huaheng.pc.inventory.inventoryDetail.domain.InventoryDetail;
import com.huaheng.pc.inventory.inventoryDetail.service.InventoryDetailService;
import com.huaheng.pc.inventory.inventoryTransaction.domain.InventoryTransaction;
import com.huaheng.pc.inventory.inventoryTransaction.domain.InventoryTransactionReport;
import com.huaheng.pc.inventory.inventoryTransaction.service.InventoryTransactionService;
import com.huaheng.pc.receipt.receiptContainerHeader.domain.ReceiptContainerHeader;
import com.huaheng.pc.receipt.receiptContainerHeader.domain.ReceiptContainerView;
import com.huaheng.pc.receipt.receiptContainerHeader.service.ReceiptContainerBatchService;
import com.huaheng.pc.receipt.receiptContainerHeader.service.ReceiptContainerHeaderService;
import com.huaheng.pc.receipt.receiptDetail.domain.ReceiptDetail;
import com.huaheng.pc.receipt.receiptDetail.service.ReceiptDetailService;
import com.huaheng.pc.receipt.receiptHeader.domain.ReceiptHeader;
import com.huaheng.pc.receipt.receiptHeader.service.ReceiptHeaderService;
import com.huaheng.pc.report.excelReport.mapper.ExcelReportMapper;
import com.huaheng.pc.shipment.shipmentContainerHeader.domain.ShipmentCombinationModel;
import com.huaheng.pc.shipment.shipmentContainerHeader.domain.ShipmentContainerHeader;
import com.huaheng.pc.shipment.shipmentContainerHeader.service.ShipmentContainerHeaderService;
import com.huaheng.pc.shipment.shipmentDetail.domain.ShipmentDetail;
import com.huaheng.pc.shipment.shipmentDetail.service.ShipmentDetailService;
import com.huaheng.pc.shipment.shipmentHeader.domain.ShipmentHeader;
import com.huaheng.pc.shipment.shipmentHeader.service.ShipmentHeaderService;
import com.huaheng.pc.task.taskHeader.domain.TaskHeader;
import com.huaheng.pc.task.taskHeader.service.ReceiptTaskService;
import com.huaheng.pc.task.taskHeader.service.TaskHeaderService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import java.math.BigDecimal;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.util.*;
import java.util.stream.Collectors;
@Service
public class ScPdaService {
@Autowired
protected RedisTemplate<String, Object> redisTemplate;
private static final Logger logger = LoggerFactory.getLogger(ScPdaService.class);
@Resource
private TaskHeaderService taskHeaderService;
@Resource
private ContainerService containerService;
@Resource
private InventoryDetailService inventoryDetailService;
@Resource
private ShipmentContainerHeaderService shipmentContainerHeaderService;
@Resource
private ReceiptApiService receiptApiService;
@Resource
private ShipmentApiService shipmentApiService;
@Resource
private MaterialService materialService;
@Resource
private ReceiptContainerBatchService receiptContainerBatchService;
@Resource
private ReceiptContainerHeaderService receiptContainerHeaderService;
@Resource
private ReceiptTaskService receiptTaskService;
/**
* 创建主任务,定时任务创建agv任务
* @param shipmentBeans
* @return
*/
@Transactional
public AjaxResult createReceiptTask(List<ScpPdaReceiptBean> scpPdaReceiptBeans){
String containerCode = scpPdaReceiptBeans.get(0).getContainerCode();
String port = scpPdaReceiptBeans.get(0).getPort();
List<ReceiptDetail> receiptDetails=createReceiptSc(scpPdaReceiptBeans);
List<ReceiptContainerView> lists=new ArrayList<>();
for (ReceiptDetail receiptDetail : receiptDetails) {
ReceiptContainerView receiptContainerView = new ReceiptContainerView();
receiptContainerView.setReceiptCode(receiptDetail.getReceiptCode());
if(StringUtils.isNull(receiptDetail.getTaskQty())){
receiptDetail.setTaskQty(new BigDecimal(0));
}
receiptContainerView.setQty(receiptDetail.getQty().subtract(receiptDetail.getTaskQty()));
receiptContainerView.setContainerCode(containerCode);
receiptContainerView.setReceiptDetailId(receiptDetail.getId());
receiptContainerView.setMocodeFlag(0);
lists.add(receiptContainerView);
}
AjaxResult ajaxResult = receiptContainerBatchService.saveContainerList(lists);
if (ajaxResult.hasErr()) {
throw new ServiceException("pda入库任务:"+ajaxResult.getMsg());
}
//创建任务
LambdaQueryWrapper<ReceiptContainerHeader> lambdaQueryWrapper= Wrappers.lambdaQuery();
lambdaQueryWrapper.eq(ReceiptContainerHeader::getContainerCode,containerCode);
lambdaQueryWrapper.le(ReceiptContainerHeader::getStatus,10);
List<ReceiptContainerHeader> receiptContainerHeaders=receiptContainerHeaderService.list(lambdaQueryWrapper);
String ids2 = receiptContainerHeaders.get(0).getId().toString();
Integer[] idArray = Convert.toIntArray(ids2);
List<Integer> islist= Arrays.asList(idArray);
AjaxResult ajaxResult1=receiptTaskService.createReceiptTask(islist);
if (ajaxResult1.hasErr()) {
throw new ServiceException("pda入库任务:"+ajaxResult1.getMsg());
}
List<String> taskIds=(List<String>) ajaxResult1.getData();
// 将mes的任务号写入入库任务头表
TaskHeader taskHeaderTemp = new TaskHeader();
taskHeaderTemp.setPort(port);
taskHeaderTemp.setId(Integer.valueOf(taskIds.get(0)));
taskHeaderService.updateById(taskHeaderTemp);
return AjaxResult.success("pda入库任务创建成功");
}
public List<ReceiptDetail> createReceiptSc(List<ScpPdaReceiptBean> scpPdaReceiptBeans) {
// 创建入库单
ReceiptDomain receiptDomain = new ReceiptDomain();
ReceiptHeader receiptHeader = new ReceiptHeader();
String companyCode = "schuahengweld";
String erpcompanyCode = "SC";
String warehouseCode = QuantityConstant.WAREHOUSE_SC;
String receiptType="PPII";
receiptHeader.setReceiptType(receiptType);
receiptHeader.setWarehouseCode(warehouseCode);
receiptHeader.setCompanyCode(companyCode);
receiptHeader.setCreatedBy(ShiroUtils.getUser().getLoginName());
receiptHeader.setErpCompanyCode(erpcompanyCode);
receiptHeader.setUWarehouseCode("01");
receiptHeader.setErpWarehouseCode("SC01");
List<ReceiptDetail> receiptDetails = new ArrayList<>();
for (ScpPdaReceiptBean scpPdaReceiptBean : scpPdaReceiptBeans){
ReceiptDetail receiptDetail = new ReceiptDetail();
String materialCode = scpPdaReceiptBean.getMaterialCode();
if(materialCode==null){
throw new ServiceException("物料编码不能为空");
}
if(scpPdaReceiptBean.getQty().compareTo(BigDecimal.ZERO)==0){
throw new ServiceException("数量不能为空");
}
receiptDetail.setMaterialCode(materialCode);
Material material=materialService.getMaterialByCode(materialCode);
if(material==null){
throw new ServiceException("找不到该物料"+materialCode);
}
receiptDetail.setMaterialName(material.getName());
receiptDetail.setMaterialSpec(material.getSpec());
receiptDetail.setMaterialUnit(material.getUnit());
receiptDetail.setQty(scpPdaReceiptBean.getQty());
receiptDetail.setWarehouseCode(receiptHeader.getWarehouseCode());
receiptDetail.setUWarehouseCode(receiptHeader.getUWarehouseCode());
receiptDetail.setErpWarehouseCode(receiptHeader.getErpWarehouseCode());
receiptDetail.setInventorySts(QuantityConstant.DEFECTIVE);
receiptDetails.add(receiptDetail);
}
receiptDomain.setReceiptHeader(receiptHeader);
receiptDomain.setReceiptDetails(receiptDetails);
AjaxResult result = receiptApiService.receipt(receiptDomain);
if (result.hasErr()){
throw new ServiceException(result.getMsg());
}
return receiptDetails;
}
/**
* 创建主任务,定时任务创建agv任务
* @param shipmentBeans
* @return
*/
@Transactional
public AjaxResult createShipmentTaskSc(List<ScpPdaShipmentBean> shipmentBeans){
String warehouseCode = QuantityConstant.WAREHOUSE_SC;
String containerCode = shipmentBeans.get(0).getContainerCode();
String port = shipmentBeans.get(0).getPort();
Container container=containerService.getContainerByCode(containerCode,warehouseCode);
if(container==null){
throw new ServiceException("出库任务:找不到该容器"+containerCode);
}
if(container.getStatus()==QuantityConstant.STATUS_CONTAINER_LOCK){
throw new ServiceException("出库任务;容器"+containerCode+"已锁,不允许出库");
}
List<ShipmentDetail> shipmentDetails=createShipmentSc(shipmentBeans);
ShipmentContainerHeader shipmentContainerHeader=null;
for (ShipmentDetail shipmentDetail : shipmentDetails){
if(StringUtils.isEmpty(shipmentDetail.getUserDef1())){
throw new ServiceException("出库任务;请选择要出库的物料");
}
InventoryDetail inventoryDetail=inventoryDetailService.getById(shipmentDetail.getUserDef1());
if(inventoryDetail==null){
throw new ServiceException("出库任务:找不到该库存"+shipmentDetail.getUserDef1());
}
if(inventoryDetail.getQty().compareTo(shipmentDetail.getQty())<0){
throw new ServiceException("出库任务:物料"+inventoryDetail.getMaterialCode()+"库存不足");
}
List<ShipmentDetail> shipmentDetailList = new ArrayList<>();
shipmentDetailList.add(shipmentDetail);
ShipmentCombinationModel shipmentCombinationModel = new ShipmentCombinationModel();
shipmentCombinationModel.setShipmentDetailId(shipmentDetail.getId());
shipmentCombinationModel.setShipQty(shipmentDetail.getQty());
shipmentCombinationModel.setInventoryDetailId(inventoryDetail.getId());
shipmentContainerHeader = shipmentContainerHeaderService.combination(shipmentCombinationModel);
if (shipmentContainerHeader == null){
throw new ServiceException("出库任务;创建出库组盘失败!"+shipmentDetail.getMaterialCode());
}
}
List<Integer> idList = Arrays.asList(Convert.toIntArray(shipmentContainerHeader.getId().toString()));
AjaxResult result = shipmentContainerHeaderService.createTask(idList);
if (result.hasErr()){
throw new ServiceException(result.getMsg());
}
// 查询出库任务
LambdaQueryWrapper<TaskHeader> taskHeaderLambdaQueryWrapper = Wrappers.lambdaQuery();
taskHeaderLambdaQueryWrapper.eq(TaskHeader::getAllocationHeadId, shipmentContainerHeader.getId());
TaskHeader taskHeader = taskHeaderService.getOne(taskHeaderLambdaQueryWrapper);
if (taskHeader == null){
throw new RuntimeException("创建出库任务失败!");
}
TaskHeader taskHeaderTemp = new TaskHeader();
taskHeaderTemp.setId(taskHeader.getId());
taskHeaderTemp.setPort(port);
taskHeaderService.updateById(taskHeaderTemp);
return AjaxResult.success("出库任务创建成功");
}
public List<ShipmentDetail> createShipmentSc(List<ScpPdaShipmentBean> shipmentBeans) {
// 创建出库单
ShipmentDomain shipmentDomain = new ShipmentDomain();
ShipmentHeader shipmentHeader = new ShipmentHeader();
String companyCode = "schuahengweld";
String erpcompanyCode = "SC";
String warehouseCode = QuantityConstant.WAREHOUSE_SC;
String receiptType="PO";
shipmentHeader.setShipmentType(receiptType);
shipmentHeader.setCompanyCode(companyCode);
shipmentHeader.setWarehouseCode(warehouseCode);
shipmentHeader.setCompanyCode(companyCode);
shipmentHeader.setCreatedBy(ShiroUtils.getUser().getLoginName());
shipmentHeader.setErpCompanyCode(erpcompanyCode);
shipmentHeader.setUWarehouseCode("01");
shipmentHeader.setErpWarehouseCode("SC01");
List<ShipmentDetail> shipmentDetails = new ArrayList<>();
for (ScpPdaShipmentBean shipmentBean : shipmentBeans){
ShipmentDetail shipmentDetail = new ShipmentDetail();
String materialCode = shipmentBean.getMaterialCode();
if(StringUtils.isNull(shipmentBean.getInventoryId())){
throw new ServiceException("库存ID为空");
}
if(shipmentBean.getQty().compareTo(BigDecimal.ZERO)==0){
continue;
// throw new ServiceException("数量不能为空");
}
shipmentDetail.setMaterialCode(materialCode);
Material material=materialService.getMaterialByCode(materialCode);
if(material==null){
throw new ServiceException("找不到该物料"+materialCode);
}
shipmentDetail.setMaterialName(material.getName());
shipmentDetail.setMaterialSpec(material.getSpec());
shipmentDetail.setMaterialUnit(material.getUnit());
shipmentDetail.setQty(shipmentBean.getQty());
shipmentDetail.setCompanyCode(shipmentHeader.getCompanyCode());
shipmentDetail.setWarehouseCode(shipmentHeader.getWarehouseCode());
shipmentDetail.setUWarehouseCode(shipmentHeader.getUWarehouseCode());
shipmentDetail.setErpWarehouseCode(shipmentHeader.getErpWarehouseCode());
shipmentDetail.setInventorySts(QuantityConstant.DEFECTIVE);
shipmentDetail.setUserDef1(shipmentBean.getInventoryId().toString());
shipmentDetails.add(shipmentDetail);
}
shipmentDomain.setShipmentHeader(shipmentHeader);
shipmentDomain.setShipmentDetails(shipmentDetails);
AjaxResult result = shipmentApiService.shipment(shipmentDomain);
if (result.hasErr()){
throw new ServiceException(result.getMsg());
}
return shipmentDetails;
}
}