|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
package com.huaheng.pc.task.taskHeader.service;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.huaheng.common.constant.QuantityConstant;
import com.huaheng.common.exception.service.ServiceException;
import com.huaheng.common.utils.StringUtils;
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;
|
|
15
16
17
18
19
|
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.material.service.MaterialService;
import com.huaheng.pc.config.materialMultiple.domain.MaterialMultiple;
import com.huaheng.pc.config.materialMultiple.service.MaterialMultipleServiceImpl;
import com.huaheng.pc.config.materialUnit.domain.MaterialUnit;
|
|
20
21
22
|
import com.huaheng.pc.config.materialWarnning.domain.MaterialWarning;
import com.huaheng.pc.config.materialWarnning.service.IMaterialWarningService;
import com.huaheng.pc.config.materialWarnning.service.impl.MaterialWarningServiceImpl;
|
|
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
|
import com.huaheng.pc.inventory.inventoryDetail.domain.InventoryDetail;
import com.huaheng.pc.inventory.inventoryDetail.service.InventoryDetailService;
import com.huaheng.pc.inventory.inventoryHeader.domain.InventoryHeader;
import com.huaheng.pc.inventory.inventoryHeader.service.InventoryHeaderService;
import com.huaheng.pc.inventory.inventoryTransaction.domain.InventoryTransaction;
import com.huaheng.pc.inventory.inventoryTransaction.service.InventoryTransactionService;
import com.huaheng.pc.receipt.receiptContainerDetail.domain.ReceiptContainerDetail;
import com.huaheng.pc.receipt.receiptContainerDetail.service.ReceiptContainerDetailService;
import com.huaheng.pc.receipt.receiptContainerHeader.domain.ReceiptContainerHeader;
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.task.taskDetail.domain.TaskDetail;
import com.huaheng.pc.task.taskDetail.service.TaskDetailService;
import com.huaheng.pc.task.taskHeader.domain.TaskHeader;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import java.math.BigDecimal;
import java.util.List;
/**
* 入库任务创建和完成
|
|
49
|
* @author mahua
|
|
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
|
* @date 2020/7/6
*/
@Service
public class ReceiptTaskService {
@Resource
private TaskHeaderService taskHeaderService;
@Resource
private TaskDetailService taskDetailService;
@Resource
private InventoryHeaderService inventoryHeaderService;
@Resource
private InventoryDetailService inventoryDetailService;
@Resource
private InventoryTransactionService inventoryTransactionService;
@Resource
private ReceiptHeaderService receiptHeaderService;
@Resource
private ReceiptDetailService receiptDetailService;
@Resource
private ReceiptContainerDetailService receiptContainerDetailService;
@Resource
private ReceiptContainerHeaderService receiptContainerHeaderService;
@Resource
private ContainerService containerService;
@Resource
private LocationService locationService;
|
|
77
78
79
80
|
@Resource
private MaterialService materialService;
@Resource
private MaterialMultipleServiceImpl materialMultipleService;
|
|
81
82
|
@Resource
private IMaterialWarningService materialWarningService;
|
|
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
|
/**
* 创建入库任务(整盘入库、补充入库)
*
* @param ids 入库组盘头表id
* @return
*/
@Transactional(rollbackFor = Exception.class)
public AjaxResult createReceiptTask(List<Integer> ids) {
for (Integer id : ids) {
ReceiptContainerHeader receiptContainerHeader = receiptContainerHeaderService.getById(id);
if (receiptContainerHeader == null) {
throw new ServiceException("id:" + id + "的入库组盘不存在!");
}
if (!receiptContainerHeader.getWarehouseCode().equals(ShiroUtils.getWarehouseCode())) {
throw new ServiceException("id:" + id + "的入库组盘不能在" + ShiroUtils.getWarehouseCode() + "仓库操作");
}
//锁定容器
Container container = new Container();
container.setStatus("lock");
LambdaUpdateWrapper<Container> containerUpdateWrapper = Wrappers.lambdaUpdate();
containerUpdateWrapper.eq(Container::getCode, receiptContainerHeader.getContainerCode());
containerService.update(container, containerUpdateWrapper);
//查询入库组盘明细
LambdaQueryWrapper<ReceiptContainerDetail> containerDetailLambda = Wrappers.lambdaQuery();
containerDetailLambda.eq(ReceiptContainerDetail::getReceiptContainerId, id);
List<ReceiptContainerDetail> list = receiptContainerDetailService.list(containerDetailLambda);
if (list.isEmpty()) {
throw new ServiceException("id:" + id + "的入库组盘,没有组盘明细,请先组盘!");
}
if (receiptContainerHeader.getStatus() == QuantityConstant.RECEIPT_CONTAINER_BUILD.intValue()) {
if (receiptContainerHeader.getStatus() < QuantityConstant.RECEIPT_CONTAINER_TASK) {
receiptContainerHeader.setStatus(QuantityConstant.RECEIPT_CONTAINER_TASK);
receiptContainerHeaderService.updateById(receiptContainerHeader);
}
//添加任务主表
TaskHeader task = new TaskHeader();
task.setAllocationHeadId(receiptContainerHeader.getId());
task.setInternalTaskType(QuantityConstant.TASK_INTENERTYPE_SHELF);
task.setWarehouseCode(receiptContainerHeader.getWarehouseCode());
task.setCompanyCode(receiptContainerHeader.getCompanyCode());
task.setTaskType(receiptContainerHeader.getTaskType());
task.setFromLocation(receiptContainerHeader.getFromLocation());
task.setToLocation(receiptContainerHeader.getToLocation());
task.setContainerCode(receiptContainerHeader.getContainerCode());
task.setRecvDock(receiptContainerHeader.getRecvDock());
if (taskHeaderService.save(task)) {
//添加任务明细表
for (ReceiptContainerDetail item : list) {
TaskDetail taskDetail = new TaskDetail();
taskDetail.setTaskId(task.getId());
taskDetail.setTaskType(task.getTaskType());
taskDetail.setInternalTaskType(QuantityConstant.TASK_INTENERTYPE_SHELF);
taskDetail.setWarehouseCode(task.getWarehouseCode());
taskDetail.setAllocationId(item.getId());
taskDetail.setCompanyCode(task.getCompanyCode());
taskDetail.setMaterialCode(item.getMaterialCode());
taskDetail.setMaterialName(item.getMaterialName());
taskDetail.setMaterialSpec(item.getMaterialSpec());
taskDetail.setMaterialUnit(item.getMaterialUnit());
taskDetail.setBillCode(item.getReceiptCode());
taskDetail.setBillDetailId(item.getReceiptDetailId());
taskDetail.setQty(item.getQty());
taskDetail.setContainerCode(task.getContainerCode());
taskDetail.setFromLocation(task.getFromLocation());
taskDetail.setToLocation(task.getToLocation());
taskDetail.setBatch(item.getBatch());
taskDetail.setProjectNo(item.getProjectNo());
if (!taskDetailService.save(taskDetail)) {
throw new ServiceException("生成任务明细失败");
}
//更新入库组盘明细状态
item.setStatus(QuantityConstant.RECEIPT_CONTAINER_TASK);
if (!receiptContainerDetailService.updateById(item)) {
throw new ServiceException("更新入库组盘明细状态出错");
}
/**
* 修改明细状态为上架
*/
ReceiptDetail receiptDetail = receiptDetailService.getById(item.getReceiptDetailId());
receiptDetail.setProcessStamp(String.valueOf(QuantityConstant.RECEIPT_HEADER_SHELF));
if (!receiptDetailService.updateById(receiptDetail)) {
throw new ServiceException("更新入库单详情失败");
}
//更新头表状态
receiptDetailService.updateReceiptHeaderLastStatus(receiptDetail.getReceiptId());
}
} else {
throw new ServiceException("任务生成失败");
}
}
}
return AjaxResult.success("生成上架任务成功");
}
/**
* 完成入库任务
*
* @param task
* @return
*/
@Transactional(rollbackFor = Exception.class)
public AjaxResult completeReceiptTask(TaskHeader task) {
|
|
194
|
/* 判断任务状态*/
|
|
195
196
197
|
if (task.getStatus().equals(QuantityConstant.TASK_STATUS_COMPLETED)) {
return AjaxResult.error("任务已完成");
}
|
|
198
199
|
BigDecimal totalQty = BigDecimal.ZERO;
List<TaskDetail> taskDetailList = taskDetailService.findByTaskId(task.getId());
|
|
200
201
202
|
if (taskDetailList.isEmpty()) {
throw new ServiceException("任务明细为空");
}
|
|
203
|
/* 遍历任务明细,修改关联的入库组盘、入库单状态、添加库存*/
|
|
204
205
|
for (TaskDetail taskDetail : taskDetailList) {
if (taskDetail.getStatus() < QuantityConstant.TASK_STATUS_COMPLETED) {
|
|
206
207
|
totalQty = totalQty.add(taskDetail.getQty());
/*查询入库单明细*/
|
|
208
209
210
211
212
213
214
|
ReceiptDetail receiptDetail = receiptDetailService.getById(taskDetail.getBillDetailId());
if (StringUtils.isNotNull(receiptDetail)) {
LambdaQueryWrapper<InventoryHeader> inventoryHeaderLambdaQueryWrapper = Wrappers.lambdaQuery();
inventoryHeaderLambdaQueryWrapper.eq(InventoryHeader::getWarehouseCode, ShiroUtils.getWarehouseCode())
.eq(InventoryHeader::getLocationCode, task.getToLocation())
.eq(InventoryHeader::getContainerCode, task.getContainerCode());
InventoryHeader inventoryHeader = inventoryHeaderService.getOne(inventoryHeaderLambdaQueryWrapper);
|
|
215
|
/* 如果库存 头明细不存在则新增库存头表记录*/
|
|
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
|
if (StringUtils.isNull(inventoryHeader)) {
inventoryHeader = new InventoryHeader();
inventoryHeader.setWarehouseCode(receiptDetail.getWarehouseCode());
inventoryHeader.setLocationCode(task.getToLocation());
inventoryHeader.setContainerCode(task.getContainerCode());
inventoryHeader.setContainerStatus("some");
inventoryHeader.setCompanyCode(receiptDetail.getCompanyCode());
inventoryHeader.setTotalWeight(task.getWeight());
inventoryHeader.setTotalQty(new BigDecimal(0));
inventoryHeader.setTotalLines(0);
inventoryHeader.setLocking(1);
inventoryHeader.setEnable(1);
if (!inventoryHeaderService.save(inventoryHeader)) {
throw new ServiceException("添加库存单失败");
}
|
|
231
|
inventoryHeader = inventoryHeaderService.getOne(inventoryHeaderLambdaQueryWrapper);
|
|
232
|
}
|
|
233
|
totalQty = this.addInventoryDetail(taskDetail, receiptDetail, inventoryHeader);
|
|
234
|
//修改组盘表状态为完成
|
|
235
|
ReceiptContainerDetail receiptContainerDetail = new ReceiptContainerDetail();
|
|
236
|
receiptContainerDetail.setStatus(QuantityConstant.RECEIPT_CONTAINER_FINISHED);
|
|
237
238
239
240
241
242
243
244
245
246
247
248
|
LambdaUpdateWrapper<ReceiptContainerDetail> receiptContainerDetailLambdaUpdateWrapper = Wrappers.lambdaUpdate();
receiptContainerDetailLambdaUpdateWrapper.eq(ReceiptContainerDetail::getId, taskDetail.getAllocationId());
if (!receiptContainerDetailService.update(receiptContainerDetail, receiptContainerDetailLambdaUpdateWrapper)){
throw new ServiceException("更新组盘状态失败");
}
} else {
throw new ServiceException("未找到id:" + taskDetail.getBillDetailId() + "入库单明细");
}
receiptDetail.setProcessStamp(String.valueOf(QuantityConstant.RECEIPT_HEADER_POSTING));
receiptDetailService.updateById(receiptDetail);
receiptDetailService.updateReceiptHeaderLastStatus(receiptDetail.getReceiptId());
|
|
249
|
materialWarningService.materialWarning(taskDetail.getMaterialCode(), taskDetail.getCompanyCode());
|
|
250
251
|
}
}
|
|
252
253
254
255
256
257
258
259
260
261
262
263
|
LambdaQueryWrapper<InventoryHeader> inventoryHeaderLambdaQueryWrapper = Wrappers.lambdaQuery();
inventoryHeaderLambdaQueryWrapper.eq(InventoryHeader::getWarehouseCode, ShiroUtils.getWarehouseCode())
.eq(InventoryHeader::getLocationCode, task.getToLocation())
.eq(InventoryHeader::getContainerCode, task.getContainerCode());
InventoryHeader inventoryHeader = inventoryHeaderService.getOne(inventoryHeaderLambdaQueryWrapper);
if (StringUtils.isNull(inventoryHeader)) {
throw new ServiceException("库存添加失败");
} else {
inventoryHeader.setTotalQty(inventoryHeader.getTotalQty().add(totalQty));
inventoryHeader.setTotalLines(inventoryHeader.getTotalLines()+taskDetailList.size());
inventoryHeaderService.updateById(inventoryHeader);
}
|
|
264
265
266
267
268
269
270
|
//修改任务主表状态,因为立库任务表单头只对应一个货箱,表单详情的任务会同时完成
task.setStatus(QuantityConstant.TASK_STATUS_COMPLETED);
LambdaUpdateWrapper<TaskHeader> taskHeaderLambdaUpdateWrapper = Wrappers.lambdaUpdate();
taskHeaderLambdaUpdateWrapper.eq(TaskHeader::getId, task.getId());
if (!taskHeaderService.update(task, taskHeaderLambdaUpdateWrapper)){
throw new ServiceException("更新任务主表失败");
}
|
|
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
|
//修改库位状态和对应的容器
Location location = new Location();
location.setContainerCode(task.getContainerCode());
location.setStatus("empty");
LambdaUpdateWrapper<Location> locationLambdaUpdateWrapper = Wrappers.lambdaUpdate();
locationLambdaUpdateWrapper.eq(Location::getCode, task.getToLocation());
if (!locationService.update(location, locationLambdaUpdateWrapper)){
throw new ServiceException("更新库位失败");
}
//修改容器状态和对应的库位
Container container = new Container();
container.setLocationCode(task.getToLocation());
container.setStatus("some");
LambdaUpdateWrapper<Container> containerLambdaUpdateWrapper = Wrappers.lambdaUpdate();
containerLambdaUpdateWrapper.eq(Container::getCode, task.getContainerCode());
if (!containerService.update(container, containerLambdaUpdateWrapper)) {
throw new ServiceException("更新容器失败");
}
//修改入库组盘头表状态
ReceiptContainerHeader receiptContainerHeader = new ReceiptContainerHeader();
receiptContainerHeader.setId(task.getAllocationHeadId());
receiptContainerHeader.setStatus(QuantityConstant.RECEIPT_CONTAINER_FINISHED);
if (!receiptContainerHeaderService.updateById(receiptContainerHeader)) {
throw new ServiceException("更新入库组盘头表状态失败");
}
return AjaxResult.success();
}
/**
* 添加库存明细与库存交易记录
* @param taskDetail 任务明细
* @param receiptDetail 入库单明细
* @param inventoryHeader 库存头表
|
|
306
|
* @return 任务数量
|
|
307
|
*/
|
|
308
|
private BigDecimal addInventoryDetail(TaskDetail taskDetail, ReceiptDetail receiptDetail, InventoryHeader inventoryHeader) {
|
|
309
|
/*该入库明细是否已存在库存明细记录,已存在更新数量、不存在新增记录*/
|
|
310
311
312
313
314
315
316
317
|
LambdaQueryWrapper<InventoryDetail> inventory = Wrappers.lambdaQuery();
inventory.eq(InventoryDetail::getWarehouseCode, taskDetail.getWarehouseCode())
.eq(InventoryDetail::getLocationCode, inventoryHeader.getLocationCode())
.eq(InventoryDetail::getMaterialCode, taskDetail.getMaterialCode())
.eq(InventoryDetail::getContainerCode, inventoryHeader.getContainerCode())
.eq(InventoryDetail::getCompanyCode, taskDetail.getCompanyCode())
.eq(InventoryDetail::getReceiptDetailId, taskDetail.getBillDetailId());
InventoryDetail inventoryDetail = inventoryDetailService.getOne(inventory);
|
|
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
|
Material material = materialService.findAllByCode(receiptDetail.getMaterialCode());
/*单位换算*/
BigDecimal receiptQty = taskDetail.getQty();
if (StringUtils.isNotEmpty(receiptDetail.getMaterialUnit()) &&
StringUtils.isNotEmpty(material.getUnit()) &&
!receiptDetail.getMaterialUnit().equals(material.getUnit())) {
LambdaQueryWrapper<MaterialMultiple> queryWrapper = Wrappers.lambdaQuery();
queryWrapper.eq(MaterialMultiple::getMaterialCode, receiptDetail.getMaterialCode())
.eq(MaterialMultiple::getUnitId1, receiptDetail.getMaterialUnit())
.eq(MaterialMultiple::getUnitId2, material.getUnit());
MaterialMultiple materialMultiple = materialMultipleService.getOne(queryWrapper);
if (StringUtils.isNull(materialMultiple)) {
throw new ServiceException("入库单单位与物料绑定主单位不一致且单位换算不存在");
} else {
receiptQty = receiptQty.multiply(materialMultiple.getMultiple());
}
}
|
|
335
336
337
338
339
340
341
342
343
344
345
346
347
348
|
if (StringUtils.isNotNull(inventoryDetail)) {
inventoryDetail.setQty(inventoryDetail.getQty().add(taskDetail.getQty()));
}
else {
ReceiptHeader receiptHeader = receiptHeaderService.getById(receiptDetail.getReceiptId());
inventoryDetail = new InventoryDetail();
inventoryDetail.setInventoryHeaderId(inventoryHeader.getId());
inventoryDetail.setWarehouseCode(taskDetail.getWarehouseCode());
inventoryDetail.setCompanyCode(taskDetail.getCompanyCode());
inventoryDetail.setLocationCode(taskDetail.getToLocation());
inventoryDetail.setContainerCode(taskDetail.getContainerCode());
inventoryDetail.setMaterialCode(taskDetail.getMaterialCode());
inventoryDetail.setMaterialName(taskDetail.getMaterialName());
inventoryDetail.setMaterialSpec(taskDetail.getMaterialSpec());
|
|
349
350
|
inventoryDetail.setMaterialUnit(material.getUnit());
inventoryDetail.setQty(receiptQty);
|
|
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
|
inventoryDetail.setTaskQty(new BigDecimal(0));
inventoryDetail.setLockedQty(new BigDecimal(0));
inventoryDetail.setInventorySts(taskDetail.getInventorySts());
inventoryDetail.setSupplierCode(receiptDetail.getSupplierCode());
inventoryDetail.setReferCode(receiptDetail.getReferCode());
inventoryDetail.setReferDetailId(receiptDetail.getReferLineNum());
inventoryDetail.setBatch(receiptDetail.getBatch());
inventoryDetail.setLot(receiptDetail.getLot());
inventoryDetail.setProjectNo(receiptDetail.getProjectNo());;
inventoryDetail.setManufactureDate(receiptDetail.getManufactureDate());
inventoryDetail.setExpirationDate(receiptDetail.getExpirationDate());
inventoryDetail.setAgingDate(receiptDetail.getAgingDate());
inventoryDetail.setAttribute1(receiptDetail.getAttribute1());
inventoryDetail.setAttribute2(receiptDetail.getAttribute2());
inventoryDetail.setAttribute3(receiptDetail.getAttribute3());
inventoryDetail.setReceiptCode(receiptHeader.getCode());
inventoryDetail.setReceiptDetailId(receiptDetail.getId());
if (!inventoryDetailService.save(inventoryDetail)) {
throw new ServiceException("保存库存明细失败");
}
}
//记录库存交易记录
InventoryTransaction inventoryTransaction = new InventoryTransaction();
inventoryTransaction.setTransactionType(QuantityConstant.INVENTORY_TRANSACTION_RECEIPT);
inventoryTransaction.setWarehouseCode(taskDetail.getWarehouseCode());
inventoryTransaction.setCompanyCode(taskDetail.getCompanyCode());
inventoryTransaction.setLocationCode(inventoryHeader.getLocationCode());
inventoryTransaction.setContainerCode(inventoryHeader.getContainerCode());
inventoryTransaction.setMaterialCode(taskDetail.getMaterialCode());
inventoryTransaction.setMaterialName(taskDetail.getMaterialName());
inventoryTransaction.setMaterialSpec(taskDetail.getMaterialSpec());
|
|
382
|
inventoryTransaction.setMaterialUnit(material.getUnit());
|
|
383
384
385
386
387
|
inventoryTransaction.setBillCode(taskDetail.getBillCode());
inventoryTransaction.setBillDetailId(taskDetail.getBillDetailId());
inventoryTransaction.setBatch(receiptDetail.getBatch());
inventoryTransaction.setLot(receiptDetail.getLot());
inventoryTransaction.setInventorySts(receiptDetail.getInventorySts());
|
|
388
|
inventoryTransaction.setTaskQty(receiptQty);
|
|
389
390
391
|
if (!inventoryTransactionService.save(inventoryTransaction)) {
throw new ServiceException("新增库存记录失败");
}
|
|
392
|
return receiptQty;
|
|
393
394
|
}
}
|