|
1
2
|
package com.huaheng.api.mes.controller;
|
|
3
4
|
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
|
|
5
6
7
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.huaheng.api.mes.dto.Detail;
|
|
8
|
import com.huaheng.api.mes.dto.GetOrderHistoryDTO;
|
|
9
|
import com.huaheng.api.mes.dto.Header;
|
|
10
|
import com.huaheng.api.mes.dto.ReceiptDTO;
|
|
11
|
import com.huaheng.api.mes.service.IMesService;
|
|
12
13
|
import com.huaheng.api.mes.utils.CallaMOM;
import com.huaheng.api.mes.utils.SqlServer;
|
|
14
|
import com.huaheng.api.mes.vo.InventoryVO;
|
|
15
|
import com.huaheng.api.mes.vo.InventoryTransactionVO;
|
|
16
|
import com.huaheng.common.constant.QuantityConstant;
|
|
17
|
import com.huaheng.common.exception.service.ServiceException;
|
|
18
|
import com.huaheng.common.utils.StringUtils;
|
|
19
|
import com.huaheng.common.utils.reflect.ReflectUtils;
|
|
20
|
import com.huaheng.framework.aspectj.lang.annotation.ApiLogger;
|
|
21
22
|
import com.huaheng.framework.aspectj.lang.annotation.Log;
import com.huaheng.framework.aspectj.lang.constant.BusinessType;
|
|
23
24
25
|
import com.huaheng.framework.web.controller.BaseController;
import com.huaheng.framework.web.domain.AjaxResult;
import com.huaheng.framework.web.domain.RetCode;
|
|
26
|
import com.huaheng.pc.config.material.domain.Material;
|
|
27
|
import com.huaheng.pc.config.material.service.MaterialService;
|
|
28
29
|
import com.huaheng.pc.inventory.inventoryDetail.domain.InventoryDetail;
import com.huaheng.pc.inventory.inventoryDetail.service.InventoryDetailService;
|
|
30
31
|
import com.huaheng.pc.inventory.inventoryTransaction.domain.InventoryTransaction;
import com.huaheng.pc.inventory.inventoryTransaction.service.InventoryTransactionService;
|
|
32
33
34
|
import com.huaheng.pc.momLog.domain.MomLog;
import com.huaheng.pc.momLog.mapper.MomLogMapper;
import com.huaheng.pc.momLog.service.IMomLogService;
|
|
35
36
37
38
39
40
41
42
|
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.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;
|
|
43
44
|
import com.huaheng.pc.task.taskDetail.domain.TaskDetail;
import com.huaheng.pc.task.taskDetail.service.TaskDetailService;
|
|
45
|
import io.swagger.annotations.Api;
|
|
46
47
|
import io.swagger.annotations.ApiOperation;
import org.apache.poi.ss.formula.functions.T;
|
|
48
49
|
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
|
|
50
|
import org.springframework.beans.BeanUtils;
|
|
51
|
import org.springframework.transaction.annotation.Transactional;
|
|
52
53
54
|
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
|
|
55
|
import java.io.UnsupportedEncodingException;
|
|
56
57
58
59
|
import java.sql.ResultSet;
import java.sql.SQLException;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
|
|
60
|
import java.util.*;
|
|
61
|
|
|
62
|
|
|
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
@RestController
@RequestMapping("/API/WMS/v2")
public class MesReceiptController extends BaseController {
@Resource
private ReceiptHeaderService receiptHeaderService;
@Resource
private ReceiptDetailService receiptDetailService;
@Resource
private ShipmentHeaderService shipmentHeaderService;
@Resource
private ShipmentDetailService shipmentDetailService;
@Resource
private InventoryDetailService inventoryDetailService;
|
|
82
83
84
|
@Resource
private TaskDetailService taskDetailService;
|
|
85
86
87
88
89
90
|
@Resource
private InventoryTransactionService inventoryTransactionService;
@Resource
private MaterialService materialService;
|
|
91
92
|
@Resource
private IMomLogService momLogService;
|
|
93
94
|
@Resource
private IMesService mesService;
|
|
95
|
|
|
96
|
private static Logger logger = LoggerFactory.getLogger(ReflectUtils.class);
|
|
97
|
|
|
98
99
100
101
|
@PostMapping("/receipt")
@ApiLogger(apiName = "添加入库单及其明细", from="ROBOT")
@ApiOperation("添加入库单及其明细")
public AjaxResult receipt(@RequestBody ReceiptDTO receiptDTO) {
|
|
102
103
104
105
106
|
AjaxResult ajaxResult = handleQuest("receipt", new MultiProcessListener() {
@Override
public AjaxResult doProcess() {
AjaxResult ajaxResult = mesService.receipt(receiptDTO);
return ajaxResult;
|
|
107
|
}
|
|
108
109
|
});
return ajaxResult;
|
|
110
111
|
}
|
|
112
|
|
|
113
114
115
116
117
118
119
120
121
|
/**
* 添加出库单及其明细
* @param receiptDTO
* @return
*/
@PostMapping("/shipment")
@ApiLogger(apiName = "添加出库单及其明细", from="ROBOT")
@ApiOperation("添加出库单及其明细")
public AjaxResult shipment(@RequestBody ReceiptDTO receiptDTO) {
|
|
122
123
124
125
126
|
AjaxResult ajaxResult = handleQuest("shipment", new MultiProcessListener() {
@Override
public AjaxResult doProcess() {
AjaxResult ajaxResult = mesService.shipment(receiptDTO);
return ajaxResult;
|
|
127
|
}
|
|
128
|
});
|
|
129
|
return ajaxResult;
|
|
130
131
|
}
|
|
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
|
private JSONObject getJsonObject(Header header, List<Detail> details) {
JSONObject data = new JSONObject();
JSONObject Rd_In_M = new JSONObject();
Rd_In_M.put("MGPK", header.getId());
Rd_In_M.put("cCode", header.getReferCode());
JSONArray Rd_In_S = new JSONArray();
details.forEach(detail -> {
JSONObject json = new JSONObject();
json.put("MGPK", header.getId());
json.put("SGPK", detail.getId());
json.put("cInvCode", detail.getMaterialCode());
Rd_In_S.add(json);
});
data.put("Requester", "WMS");
data.put("Rd_In_M", Rd_In_M);
data.put("Rd_In_S", Rd_In_S);
return data;
}
|
|
151
|
|
|
152
153
154
155
156
157
158
159
|
/**
* 入库单参数_判空处理
* @param ajaxResult
* @param shipmentHeader
* @param shipemtnDetails
*/
private boolean enterIsNull(AjaxResult ajaxResult, Header shipmentHeader, List<Detail> shipemtnDetails){
|
|
160
161
162
|
if (isNullData(ajaxResult, shipmentHeader, shipemtnDetails)){
return true;
}
|
|
163
164
165
166
167
168
169
|
if (StringUtils.isEmpty(shipmentHeader.getRefeCodeType())) {
ajaxResult.setCode(RetCode.FAIL).setMsg("单据类型不能为空!!!");
return true;
} else if (StringUtils.isEmpty(shipmentHeader.getReferCode())) {
ajaxResult.setCode(RetCode.FAIL).setMsg("单据单号不能为空!!!");
return true;
|
|
170
171
|
}else if (shipmentHeader.getTotalQty() == null || shipmentHeader.getTotalQty().intValue() <= 0) {
ajaxResult.setCode(RetCode.FAIL).setMsg("数量不能为空!!!");
|
|
172
173
174
175
176
|
}
shipemtnDetails.forEach(shipemtnDetail->{
if (StringUtils.isEmpty(shipemtnDetail.getMaterialCode())) {
ajaxResult.setCode(RetCode.FAIL).setMsg("物料编码不能为空!!!");
|
|
177
178
|
} else if (shipemtnDetail.getTotalQty() == null || shipemtnDetail.getQty().intValue() <= 0) {
ajaxResult.setCode(RetCode.FAIL).setMsg("数量不能为空!!!");
|
|
179
180
181
182
183
184
185
186
187
188
189
190
|
}
});
return StringUtils.isNotEmpty(ajaxResult.getMsg());
}
/**
* 出库单参数_判空处理
* @param ajaxResult
* @param shipmentHeader
* @param shipemtnDetails
*/
private boolean outIsNull (AjaxResult ajaxResult, Header shipmentHeader, List<Detail> shipemtnDetails){
|
|
191
192
193
|
if (isNullData(ajaxResult, shipmentHeader, shipemtnDetails)){
return true;
}
|
|
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
|
if (StringUtils.isEmpty(shipmentHeader.getReferCode())) {
ajaxResult.setCode(RetCode.FAIL).setMsg("单据单号不能为空!!!");
return true;
}
shipemtnDetails.forEach(shipemtnDetail->{
if (StringUtils.isEmpty(shipemtnDetail.getMaterialCode())) {
ajaxResult.setCode(RetCode.FAIL).setMsg("物料编码不能为空!!!");
}
});
return StringUtils.isNotEmpty(ajaxResult.getMsg());
}
/**
* 判空处理
*/
private boolean isNullData(AjaxResult ajaxResult, Header shipmentHeader, List<Detail> shipemtnDetails) {
if (shipmentHeader == null) {
ajaxResult.setCode(RetCode.FAIL).setMsg("出库单头表不能为空!!!");
return true;
} else if (shipemtnDetails == null || shipemtnDetails.size() < 1) {
ajaxResult.setCode(RetCode.FAIL).setMsg("出库单明细表集不能为空!!!");
return true;
}
return false;
}
/**
|
|
223
|
* 入库单单据取消
|
|
224
|
*/
|
|
225
226
|
@PostMapping("/cancelEnterWarehouse")
@ApiOperation("入库单单据取消")
|
|
227
|
@ApiLogger(apiName = "入库单单据取消", from="ROBOT")
|
|
228
|
public AjaxResult cancelEnterWarehouse(@RequestBody ReceiptDTO receiptDTO) {
|
|
229
230
231
232
233
|
AjaxResult ajaxResult = handleQuest("cancelEnterWarehouse", new MultiProcessListener() {
@Override
public AjaxResult doProcess() {
AjaxResult ajaxResult = mesService.cancelEnterWarehouse(receiptDTO);
return ajaxResult;
|
|
234
|
}
|
|
235
236
|
});
return ajaxResult;
|
|
237
238
239
240
241
242
243
244
|
}
/**
* 出库单单据取消
*/
@PostMapping("/cancelOutWarehouse")
@ApiOperation("出库单单据取消")
|
|
245
|
@ApiLogger(apiName = "出库单单据取消", from="ROBOT")
|
|
246
|
public AjaxResult cancelOutWarehouse(@RequestBody ReceiptDTO receiptDTO) {
|
|
247
248
249
250
251
|
AjaxResult ajaxResult = handleQuest("cancelOutWarehouse", new MultiProcessListener() {
@Override
public AjaxResult doProcess() {
AjaxResult ajaxResult = mesService.cancelOutWarehouse(receiptDTO);
return ajaxResult;
|
|
252
|
}
|
|
253
254
|
});
return ajaxResult;
|
|
255
256
257
258
259
260
261
262
263
264
|
}
private AjaxResult isNull(Header header, List<Detail> details) {
AjaxResult ajaxResult = new AjaxResult();
boolean isNull = outIsNull(ajaxResult, header, details);
details.forEach(detail -> {
if (detail.getTotalQty() == null || detail.getTotalQty().intValue() <= 0) {
ajaxResult.setCode(RetCode.FAIL).setMsg("总数量不能为空!!!");
}
});
|
|
265
266
267
|
if (isNull || StringUtils.isNotEmpty(ajaxResult.getMsg())){
return ajaxResult;
}
|
|
268
|
return ajaxResult;
|
|
269
270
271
272
273
274
275
276
277
278
279
280
|
}
/**
* 查询库存
*/
@PostMapping("/searchInventory")
@ApiLogger(apiName = "查询库存", from="ROBOT")
@ApiOperation("查询库存")
public AjaxResult searchInventory(@RequestBody Detail detailed) {
String materialName = detailed.getMaterialName();
String materialCode = detailed.getMaterialCode();
|
|
281
|
String containerCode = detailed.getContainerCode();
|
|
282
|
|
|
283
284
285
286
287
|
LambdaQueryWrapper<InventoryDetail> lambdaQueryWrapper = Wrappers.lambdaQuery();
// 物料编码
if (StringUtils.isNotEmpty(materialName)){
lambdaQueryWrapper.eq(InventoryDetail::getMaterialName, materialName);
}
|
|
288
|
// 物料名称
|
|
289
290
291
|
if (StringUtils.isNotEmpty(materialCode)){
lambdaQueryWrapper.eq(InventoryDetail::getMaterialCode, materialCode);
}
|
|
292
293
294
295
|
// 托盘号
if (StringUtils.isNotEmpty(containerCode)){
lambdaQueryWrapper.eq(InventoryDetail::getContainerCode, containerCode);
}
|
|
296
|
|
|
297
298
299
|
if (StringUtils.isEmpty(materialName) && StringUtils.isEmpty(containerCode) && StringUtils.isEmpty(containerCode)){
lambdaQueryWrapper.gt(InventoryDetail::getQty, 0);
}
|
|
300
|
List<InventoryDetail> detailList = inventoryDetailService.list(lambdaQueryWrapper);
|
|
301
|
|
|
302
303
304
305
306
|
List<InventoryVO> inventoryVOList = new ArrayList<>();
detailList.forEach(detail->{
InventoryVO inventoryVO = new InventoryVO();
BeanUtils.copyProperties(detail,inventoryVO);
inventoryVO.setWarehouse("035");
|
|
307
|
inventoryVOList.add(inventoryVO);
|
|
308
309
|
});
|
|
310
|
return AjaxResult.success(inventoryVOList);
|
|
311
312
313
314
|
}
/**
|
|
315
|
* 获取出入库单明细记录
|
|
316
317
318
|
* @return AjaxResult
*/
@PostMapping("/getShipmentDetail")
|
|
319
320
|
@ApiLogger(apiName = "获取出入库单明细记录", from="ROBOT")
@ApiOperation("获取出入库单明细记录")
|
|
321
322
323
324
325
|
public AjaxResult getShipmentDetail(@RequestBody GetOrderHistoryDTO getOrderHistoryDTO) {
if(StringUtils.isEmpty(getOrderHistoryDTO.getEndTime()) || StringUtils.isEmpty(getOrderHistoryDTO.getStartTime())){
return AjaxResult.error("开始时间和结束时间不能为空!!!");
}
|
|
326
|
LambdaQueryWrapper<InventoryTransaction> lambdaQueryWrapper = Wrappers.lambdaQuery();
|
|
327
|
lambdaQueryWrapper
|
|
328
329
330
331
332
333
334
335
336
337
|
.ge(InventoryTransaction::getCreated, getOrderHistoryDTO.getStartTime())
.le(InventoryTransaction::getCreated, getOrderHistoryDTO.getEndTime());
List<InventoryTransaction> list = inventoryTransactionService.list(lambdaQueryWrapper);
List<InventoryTransactionVO> inventoryTransactionVOList = new ArrayList<>();
list.forEach(inventoryTransaction -> {
InventoryTransactionVO inventoryTransactionVO = new InventoryTransactionVO();
BeanUtils.copyProperties(inventoryTransaction, inventoryTransactionVO);
inventoryTransactionVOList.add(inventoryTransactionVO);
});
return AjaxResult.success(inventoryTransactionVOList);
|
|
338
339
340
341
342
343
344
345
346
347
|
}
/**
* 获取sqlServer数据库中物料信息, 同步到本地数据库中
*/
@PostMapping("/getMaterial")
@ApiOperation("获取外部物料信息")
public List<Material> getMaterial(){
List<Material> materialList = new ArrayList<>();
try {
|
|
348
|
|
|
349
|
// String sql = "SELECT * FROM [dbo].[sys_user] WHERE createTime > (select DATEADD(HOUR,-3,getdate())) AND createTime <= (select GETDATE())";
|
|
350
351
|
// String sql = "SELECT * FROM [dbo].[base_material] WHERE MaterialName = 'SMLS Pipe'";
// 获取新增一天以内和修改两个小时以内的物料数据
|
|
352
|
String sql = "select a.cInvCode, a.cInvName, b.cidefine6, b.cidefine7, c.cComUnitName from [dbo].[Inventory] a left join [dbo].[Inventory_extradefine] b on a.cInvCode = b.cInvCode LEFT JOIN [dbo].[ComputationUnit] c ON a.cComUnitCode = c.cComunitCode WHERE (datediff(day,a.dSDate,getdate())=0 OR a.dModifyDate >= DATEADD(HOUR, -4, GETDATE())) and a.cDefWareHouse in ('035','003')";
|
|
353
|
ResultSet resultSet = SqlServer.find(sql);
|
|
354
355
356
357
|
if (resultSet == null){
return materialList;
}
while(resultSet.next()){
|
|
358
359
360
|
// 字段要与海王表一致
String code = resultSet.getString("cInvCode");
String name = resultSet.getString("cInvName");
|
|
361
|
String unit = resultSet.getString("cComUnitName");
|
|
362
363
364
|
String spec = resultSet.getString("cidefine6");
String high = resultSet.getString("cidefine7");
int isHigh = "高托".equals(high) ? 1 : 0;
|
|
365
366
|
Material material = new Material();
|
|
367
|
material.setCode(code);
|
|
368
369
|
material.setName(name);
material.setUnit(unit);
|
|
370
371
|
material.setSpec(spec);
material.setIsHigh(isHigh);
|
|
372
373
374
375
376
377
378
379
380
|
material.setWarehouseCode("CS0001");
material.setCompanyCode("BHF");
materialList.add(material);
}
// materialService.saveBatch(materialList);
} catch (SQLException throwable) {
throwable.printStackTrace();
}
|
|
381
|
logger.debug("******************************同步海王物料档案" + materialList.size() + "条数据!!!");
|
|
382
|
return materialList;
|
|
383
|
}
|
|
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
|
/** 当前时间向推几小时 */
public String dateRoll(int ihour) {
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
// 获取当前时间
LocalDateTime date = LocalDateTime.now();
// 获取当前时间的前几小时时间
LocalDateTime localDateTime = date.minusHours(ihour);
return dateTimeFormatter.format(localDateTime);
}
/**
* 查询站台任务明细列表
*/
@ApiLogger(apiName = "查询站台任务明细列表", from="ROBOT")
@PostMapping("/kanbanInfo")
|
|
401
|
@CrossOrigin
|
|
402
403
|
public AjaxResult kanbanInfo(@RequestBody TaskDetail taskDetail){
String fromLocation = taskDetail.getFromLocation();
|
|
404
|
if (StringUtils.isEmpty(fromLocation)) {
|
|
405
|
return AjaxResult.error("站台不能为空!!!");
|
|
406
|
}
|
|
407
408
409
410
411
412
413
|
LambdaQueryWrapper<TaskDetail> wrapper = Wrappers.lambdaQuery();
wrapper.eq(TaskDetail::getFromLocation, fromLocation)
.lt(TaskDetail::getStatus,"100");
List<TaskDetail> taskDetailList = taskDetailService.list(wrapper);
return AjaxResult.success(taskDetailList);
}
|
|
414
|
/**
|
|
415
|
* post调用E_Rd_In(MOM)入库成功接口
|
|
416
417
418
|
*/
@ApiLogger(apiName = "post调用E_Rd_In(MOM)入库接口", from="ROBOT")
@PostMapping("/postE_Rd_In")
|
|
419
420
|
public Boolean postE_Rd_In(@RequestBody ReceiptDetail receiptDetail){
ReceiptHeader receiptHeader = receiptHeaderService.getById(receiptDetail.getReceiptId()); //59
|
|
421
|
JSONObject Rd_In_M = new JSONObject();
|
|
422
423
|
Rd_In_M.put("mno", receiptHeader.getCode());
Rd_In_M.put("MGPK", receiptHeader.getMOMID());
|
|
424
425
426
|
Rd_In_M.put("cBusType", receiptHeader.getReceiptType());
Rd_In_M.put("TAID", receiptHeader.getTAID());
Rd_In_M.put("FAID", receiptHeader.getFAID());
|
|
427
|
Rd_In_M.put("UserNo", receiptHeader.getLastUpdatedBy());
|
|
428
|
Rd_In_M.put("warehouse", receiptHeader.getWarehouse());
|
|
429
|
|
|
430
|
JSONArray jsonArray = new JSONArray();
|
|
431
432
433
434
435
436
437
438
439
440
441
|
JSONObject Rd_In_S = new JSONObject();
Rd_In_S.put("MGPK", receiptHeader.getMOMID());
Rd_In_S.put("SGPK", receiptDetail.getMOMID());
Rd_In_S.put("SNNO", receiptDetail.getSNNO());
Rd_In_S.put("cInvCode", receiptDetail.getMaterialCode());
Rd_In_S.put("Iquantity", receiptDetail.getTaskQty());
Rd_In_S.put("iFQuantity", receiptDetail.getQty());
Rd_In_S.put("cwhcode", receiptDetail.getWarehouseCode());
Rd_In_S.put("MOCode", receiptDetail.getNoticeNo());
Rd_In_S.put("ISUrgent", receiptDetail.getIsUrgent());
Rd_In_S.put("receiptBarcode", receiptDetail.getReceiptBarcode());
|
|
442
443
444
445
446
447
|
Rd_In_S.put("warehouse", receiptHeader.getWarehouse());
Rd_In_S.put("warehouseName", receiptHeader.getWarehouseName());
Rd_In_S.put("creatorCode", receiptDetail.getLastUpdatedBy());
Rd_In_S.put("creatorName", receiptDetail.getLastUpdatedByName());
Rd_In_S.put("productionWorker", receiptHeader.getProductionWorker());
Rd_In_S.put("productionWorkerName", receiptHeader.getProductionWorkerName());
|
|
448
|
jsonArray.add(Rd_In_S);
|
|
449
450
451
452
453
|
JSONObject data = new JSONObject();
data.put("Rd_In_M", Rd_In_M);
data.put("Rd_In_S", jsonArray);
String action = "E_Rd_In";
|
|
454
|
JSONObject json = new JSONObject();
|
|
455
|
json.put("data", data);
|
|
456
457
458
459
|
return postMOM(action, json);
}
/**
|
|
460
|
* post调用E_Rd_In(MOM)出库成功接口
|
|
461
462
463
|
*/
@ApiLogger(apiName = "post调用E_Rd_Out(MOM)出库接口", from="ROBOT")
@PostMapping("/postE_Rd_Out")
|
|
464
|
public Boolean postE_Rd_Out(@RequestBody ShipmentHeader shipmentHeader){
|
|
465
|
// ShipmentHeader shipmentHeader = shipmentHeaderService.getById(shipmentHeaderID.getId());
|
|
466
467
468
|
// 返回MOM,并记录在数据库
MomLog momLog = new MomLog();
StringBuffer keyField = new StringBuffer();
|
|
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
|
JSONArray dataArray = new JSONArray();
// 如果订单为合并类型
if ("merge".equals(shipmentHeader.getShipmentType())){
// 查询所有子表
LambdaQueryWrapper<ShipmentDetail> shipmentDetailWrapper = Wrappers.lambdaQuery();
shipmentDetailWrapper.eq(ShipmentDetail::getShipmentId, shipmentHeader.getId());
List<ShipmentDetail> shipmentDetailList = shipmentDetailService.list(shipmentDetailWrapper);
// 查询所有合并前的头表
String ids = shipmentHeader.getRecordID();
String [] headerIdArr = ids.split(",");
LambdaQueryWrapper<ShipmentHeader> headerWrapper = Wrappers.lambdaQuery();
headerWrapper.in(ShipmentHeader::getId, headerIdArr);
List<ShipmentHeader> shipmentHeaderList = shipmentHeaderService.list(headerWrapper);
// 根据合并前的头表id分组
Map<Integer,List<ShipmentDetail>> map = new HashMap<>();
for (ShipmentDetail detail : shipmentDetailList){
Integer key = detail.getRecordID();
if(map.containsKey(key)) {
map.get(key).add(detail);
}else {
List<ShipmentDetail> list = new ArrayList<>();
list.add(detail);
map.put(key, list);
}
}
|
|
494
|
|
|
495
496
497
498
499
500
501
502
503
504
|
for (Integer key : map.keySet()) {
JSONObject data = new JSONObject();
// 合并前的头表
ShipmentHeader header = new ShipmentHeader();
// 合并前头表对应的子表
List<ShipmentDetail> detailList = new ArrayList<>();
for(ShipmentHeader SH : shipmentHeaderList){
if (key.equals(SH.getId())){
header = SH;
detailList = map.get(key);
|
|
505
|
break;
|
|
506
507
508
509
510
511
512
513
|
}
}
// 查询出库单据表头
JSONObject Rd_Out_M = getRd_Out_M(header);
JSONArray jsonArray = getRd_Out_S(header, detailList);
data.put("Rd_Out_M", Rd_Out_M);
data.put("Rd_Out_S", jsonArray);
dataArray.add(data);
|
|
514
|
|
|
515
516
517
518
519
|
}
}else {
// 查询出库单据表头
JSONObject Rd_Out_M = getRd_Out_M(shipmentHeader);
// 查询出库单据明细
|
|
520
521
522
523
|
LambdaQueryWrapper<ShipmentDetail> shipmentDetailWrapper = Wrappers.lambdaQuery();
shipmentDetailWrapper.eq(ShipmentDetail::getShipmentId, shipmentHeader.getId());
List<ShipmentDetail> shipmentDetailList = shipmentDetailService.list(shipmentDetailWrapper);
JSONArray jsonArray = getRd_Out_S(shipmentHeader,shipmentDetailList);
|
|
524
525
526
527
|
JSONObject data = new JSONObject();
data.put("Rd_Out_M", Rd_Out_M);
data.put("Rd_Out_S", jsonArray);
dataArray.add(data);
|
|
528
|
|
|
529
530
531
532
533
|
}
String action = "E_Rd_Out";
JSONObject json = new JSONObject();
json.put("data", dataArray);
|
|
534
535
|
momLog.setType("2"); // (入:1 出:2)
momLog.setMomData(json.toJSONString());
|
|
536
|
momLog.setCreated(new Date());
|
|
537
|
momLogService.save(momLog);
|
|
538
539
540
541
542
543
544
545
546
547
|
boolean success = postMOM(action, json);
if(success) {
shipmentHeader.setFirstStatus(QuantityConstant.SHIPMENT_HEADER_RETURN);
shipmentHeader.setLastStatus(QuantityConstant.SHIPMENT_HEADER_RETURN);
success = shipmentHeaderService.updateById(shipmentHeader);
if(!success) {
throw new ServiceException("更新出库单失败");
}
}
return success;
|
|
548
549
550
|
}
|
|
551
|
public JSONArray getRd_Out_S(ShipmentHeader shipmentHeader, List<ShipmentDetail> shipmentDetailList) {
|
|
552
|
JSONArray jsonArray = new JSONArray();
|
|
553
|
shipmentDetailList.forEach(shipmentDetail->{
|
|
554
|
JSONObject Rd_Out_S = new JSONObject();
|
|
555
556
|
Rd_Out_S.put("MGPK", shipmentHeader.getMOMID());
Rd_Out_S.put("SGPK", shipmentDetail.getMOMID());
|
|
557
|
Rd_Out_S.put("SNNO", shipmentDetail.getSNNO());
|
|
558
|
Rd_Out_S.put("cInvCode", shipmentDetail.getMaterialCode());
|
|
559
560
561
562
|
// 实际入库数量
Rd_Out_S.put("Iquantity", shipmentDetail.getTaskQty());
// MOM传入的入库数量
Rd_Out_S.put("iFQuantity", shipmentDetail.getQty());
|
|
563
|
Rd_Out_S.put("cwhcode", shipmentDetail.getWarehouseCode());
|
|
564
|
Rd_Out_S.put("MOCode", shipmentDetail.getNoticeNo());
|
|
565
|
Rd_Out_S.put("ISUrgent", shipmentDetail.getIsUrgent());
|
|
566
|
Rd_Out_S.put("updatedBy", shipmentDetail.getLastUpdatedBy());
|
|
567
568
569
570
571
|
Rd_Out_S.put("warehouse", shipmentHeader.getWarehouse());
Rd_Out_S.put("warehouseName", shipmentHeader.getWarehouseName());
Rd_Out_S.put("creatorCode", shipmentDetail.getLastUpdatedBy());
Rd_Out_S.put("creatorName", shipmentDetail.getLastUpdatedByName());
Rd_Out_S.put("requestedStartDate", shipmentHeader.getRequestedStartDate());
|
|
572
573
|
jsonArray.add(Rd_Out_S);
});
|
|
574
575
|
return jsonArray;
}
|
|
576
|
|
|
577
|
public JSONObject getRd_Out_M(@RequestBody ShipmentHeader shipmentHeader) {
|
|
578
579
580
581
582
583
584
|
JSONObject Rd_Out_M = new JSONObject();
Rd_Out_M.put("mno", shipmentHeader.getCode());
Rd_Out_M.put("MGPK", shipmentHeader.getMOMID());
Rd_Out_M.put("cBusType", shipmentHeader.getShipmentType());
Rd_Out_M.put("TAID", shipmentHeader.getTAID());
Rd_Out_M.put("FAID", shipmentHeader.getFAID());
Rd_Out_M.put("UserNo", shipmentHeader.getLastUpdatedBy());
|
|
585
|
Rd_Out_M.put("warehouse", shipmentHeader.getWarehouse());
|
|
586
587
|
Rd_Out_M.put("cDepCode", "01030101");//部门编码
Rd_Out_M.put("cWhCode", shipmentHeader.getWarehouse());//仓库编码
|
|
588
|
return Rd_Out_M;
|
|
589
590
|
}
|
|
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
|
/** utf-8 转 GB2312 */
public String getGB(String action){
byte [] Rd_Out; //中间用ISO-8859-1过渡
String data = null;
try {
Rd_Out = action.getBytes("8859_1");
data = new String(Rd_Out, "GB2312"); //转换成GB2312字符
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return data;
}
/**
* @param action MOM行为
* @param JObject 行为参数
* @return
*/
|
|
610
|
public Boolean postMOM(String action, JSONObject JObject){
|
|
611
|
return CallaMOM.getMsg(action, JObject);
|
|
612
|
}
|
|
613
|
|
|
614
|
|
|
615
|
}
|