Commit 49afef05cb0f54a8b2c849cdb062c09f5f80afbf
1 parent
8c1d5d4c
修复一些状态细节
Showing
9 changed files
with
69 additions
and
46 deletions
ant-design-vue-jeecg/src/views/system/config/ContainerList.vue
@@ -21,7 +21,7 @@ | @@ -21,7 +21,7 @@ | ||
21 | show-search | 21 | show-search |
22 | placeholder="请选择容器类型" | 22 | placeholder="请选择容器类型" |
23 | option-filter-prop="children" | 23 | option-filter-prop="children" |
24 | - | 24 | + |
25 | v-model="queryParam.containerTypeCode"> | 25 | v-model="queryParam.containerTypeCode"> |
26 | <a-select-option v-for="item in containerTypeList" :key="item.name" :value="item.code">{{ | 26 | <a-select-option v-for="item in containerTypeList" :key="item.name" :value="item.code">{{ |
27 | item.name | 27 | item.name |
@@ -55,11 +55,11 @@ | @@ -55,11 +55,11 @@ | ||
55 | <div class="table-operator"> | 55 | <div class="table-operator"> |
56 | <a-button @click="handleAdd" v-has="'container:add'" type="primary" icon="plus">新增</a-button> | 56 | <a-button @click="handleAdd" v-has="'container:add'" type="primary" icon="plus">新增</a-button> |
57 | <a-button v-has="'container:export'" type="primary" icon="download" @click="handleExportXls('容器管理')">导出</a-button> | 57 | <a-button v-has="'container:export'" type="primary" icon="download" @click="handleExportXls('容器管理')">导出</a-button> |
58 | - <a-upload v-has="'container:import'" name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" | 58 | + <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" |
59 | @change="handleImportExcel"> | 59 | @change="handleImportExcel"> |
60 | - <a-button type="primary" icon="import">导入</a-button> | ||
61 | - <a-button v-has="'container:print'" @click="batchPrint()" type="primary">打印</a-button> | 60 | + <a-button v-has="'container:import'" type="primary" icon="import">导入</a-button> |
62 | </a-upload> | 61 | </a-upload> |
62 | + <a-button v-has="'container:print'" @click="batchPrint()" type="primary">打印</a-button> | ||
63 | <a-dropdown v-if="selectedRowKeys.length > 0"> | 63 | <a-dropdown v-if="selectedRowKeys.length > 0"> |
64 | <a-menu slot="overlay" v-has="'container:deleteBatch'"> | 64 | <a-menu slot="overlay" v-has="'container:deleteBatch'"> |
65 | <a-menu-item key="1" @click="batchDel"> | 65 | <a-menu-item key="1" @click="batchDel"> |
ant-design-vue-jeecg/src/views/system/config/LocationList.vue
@@ -25,7 +25,7 @@ | @@ -25,7 +25,7 @@ | ||
25 | show-search | 25 | show-search |
26 | placeholder="请选择库位类型" | 26 | placeholder="请选择库位类型" |
27 | option-filter-prop="children" | 27 | option-filter-prop="children" |
28 | - | 28 | + |
29 | v-model="queryParam.locationTypeCode"> | 29 | v-model="queryParam.locationTypeCode"> |
30 | <a-select-option v-for="item in locationTypeList" :key="item.name" :value="item.code"> | 30 | <a-select-option v-for="item in locationTypeList" :key="item.name" :value="item.code"> |
31 | {{item.name}} | 31 | {{item.name}} |
@@ -40,7 +40,7 @@ | @@ -40,7 +40,7 @@ | ||
40 | show-search | 40 | show-search |
41 | placeholder="请选择库区编码" | 41 | placeholder="请选择库区编码" |
42 | option-filter-prop="children" | 42 | option-filter-prop="children" |
43 | - | 43 | + |
44 | v-model="queryParam.zoneCode"> | 44 | v-model="queryParam.zoneCode"> |
45 | <a-select-option v-for="item in zoneList" :key="item.name" :value="item.code"> | 45 | <a-select-option v-for="item in zoneList" :key="item.name" :value="item.code"> |
46 | {{item.name}} | 46 | {{item.name}} |
@@ -107,8 +107,8 @@ | @@ -107,8 +107,8 @@ | ||
107 | <a-upload v-has="'location:import'" name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" | 107 | <a-upload v-has="'location:import'" name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" |
108 | @change="handleImportExcel"> | 108 | @change="handleImportExcel"> |
109 | <a-button type="primary" icon="import">导入</a-button> | 109 | <a-button type="primary" icon="import">导入</a-button> |
110 | - <a-button v-has="'material:print'" @click="batchPrint()" type="primary">打印</a-button> | ||
111 | </a-upload> | 110 | </a-upload> |
111 | + <a-button v-has="'material:print'" @click="batchPrint()" type="primary">打印</a-button> | ||
112 | <a-dropdown v-if="selectedRowKeys.length > 0"> | 112 | <a-dropdown v-if="selectedRowKeys.length > 0"> |
113 | <a-menu slot="overlay" v-has="'location:deleteBatch'"> | 113 | <a-menu slot="overlay" v-has="'location:deleteBatch'"> |
114 | <a-menu-item key="1" @click="batchDel"> | 114 | <a-menu-item key="1" @click="batchDel"> |
ant-design-vue-jeecg/src/views/system/inventory/InventoryHeaderList.vue
@@ -122,7 +122,7 @@ | @@ -122,7 +122,7 @@ | ||
122 | <span slot="action" slot-scope="text, record"> | 122 | <span slot="action" slot-scope="text, record"> |
123 | <a v-has="'inventoryHeader:edit'" @click="handleEdit(record)">编辑<a-divider type="vertical"/></a> | 123 | <a v-has="'inventoryHeader:edit'" @click="handleEdit(record)">编辑<a-divider type="vertical"/></a> |
124 | <a-dropdown> | 124 | <a-dropdown> |
125 | - <a class="ant-dropdown-link">更多 <a-icon type="down"/></a> | 125 | +<!-- <a class="ant-dropdown-link" >更多 <a-icon type="down"/></a>--> |
126 | <a-menu slot="overlay" v-has="'inventoryHeader:delete'"> | 126 | <a-menu slot="overlay" v-has="'inventoryHeader:delete'"> |
127 | <a-menu-item> | 127 | <a-menu-item> |
128 | <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)"> | 128 | <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)"> |
huaheng-wms-core/src/main/java/org/jeecg/modules/wms/inventory/inventoryHeader/entity/InventoryDetail.java
1 | package org.jeecg.modules.wms.inventory.inventoryHeader.entity; | 1 | package org.jeecg.modules.wms.inventory.inventoryHeader.entity; |
2 | 2 | ||
3 | import java.io.Serializable; | 3 | import java.io.Serializable; |
4 | +import java.util.Date; | ||
5 | + | ||
6 | +import org.jeecg.common.aspect.annotation.Dict; | ||
7 | +import org.jeecgframework.poi.excel.annotation.Excel; | ||
8 | + | ||
4 | import com.baomidou.mybatisplus.annotation.IdType; | 9 | import com.baomidou.mybatisplus.annotation.IdType; |
5 | import com.baomidou.mybatisplus.annotation.TableId; | 10 | import com.baomidou.mybatisplus.annotation.TableId; |
6 | import com.baomidou.mybatisplus.annotation.TableName; | 11 | import com.baomidou.mybatisplus.annotation.TableName; |
7 | -import org.jeecg.common.aspect.annotation.Dict; | ||
8 | -import lombok.Data; | ||
9 | -import com.fasterxml.jackson.annotation.JsonFormat; | ||
10 | -import org.springframework.format.annotation.DateTimeFormat; | ||
11 | -import org.jeecgframework.poi.excel.annotation.Excel; | ||
12 | -import java.util.Date; | 12 | + |
13 | import io.swagger.annotations.ApiModel; | 13 | import io.swagger.annotations.ApiModel; |
14 | import io.swagger.annotations.ApiModelProperty; | 14 | import io.swagger.annotations.ApiModelProperty; |
15 | -import java.io.UnsupportedEncodingException; | 15 | +import lombok.Data; |
16 | 16 | ||
17 | /** | 17 | /** |
18 | * @Description: 库存详情 | 18 | * @Description: 库存详情 |
@@ -49,6 +49,11 @@ public class InventoryDetail implements Serializable { | @@ -49,6 +49,11 @@ public class InventoryDetail implements Serializable { | ||
49 | @Excel(name = "容器编码", width = 15) | 49 | @Excel(name = "容器编码", width = 15) |
50 | @ApiModelProperty(value = "容器编码") | 50 | @ApiModelProperty(value = "容器编码") |
51 | private String containerCode; | 51 | private String containerCode; |
52 | + /** 容器状态 */ | ||
53 | + @Excel(name = "容器状态", width = 15, dicCode = "container_status") | ||
54 | + @Dict(dicCode = "container_status") | ||
55 | + @ApiModelProperty(value = "容器状态") | ||
56 | + private String containerStatus; | ||
52 | /** 库位编码 */ | 57 | /** 库位编码 */ |
53 | @Excel(name = "库位编码", width = 15) | 58 | @Excel(name = "库位编码", width = 15) |
54 | @ApiModelProperty(value = "库位编码") | 59 | @ApiModelProperty(value = "库位编码") |
huaheng-wms-core/src/main/java/org/jeecg/modules/wms/inventory/inventoryHeader/service/impl/InventoryHeaderServiceImpl.java
@@ -2,14 +2,17 @@ package org.jeecg.modules.wms.inventory.inventoryHeader.service.impl; | @@ -2,14 +2,17 @@ package org.jeecg.modules.wms.inventory.inventoryHeader.service.impl; | ||
2 | 2 | ||
3 | import java.io.Serializable; | 3 | import java.io.Serializable; |
4 | import java.util.Collection; | 4 | import java.util.Collection; |
5 | +import java.util.List; | ||
5 | 6 | ||
6 | import javax.annotation.Resource; | 7 | import javax.annotation.Resource; |
7 | 8 | ||
8 | import org.jeecg.modules.wms.config.container.entity.Container; | 9 | import org.jeecg.modules.wms.config.container.entity.Container; |
9 | import org.jeecg.modules.wms.config.container.service.IContainerService; | 10 | import org.jeecg.modules.wms.config.container.service.IContainerService; |
11 | +import org.jeecg.modules.wms.inventory.inventoryHeader.entity.InventoryDetail; | ||
10 | import org.jeecg.modules.wms.inventory.inventoryHeader.entity.InventoryHeader; | 12 | import org.jeecg.modules.wms.inventory.inventoryHeader.entity.InventoryHeader; |
11 | import org.jeecg.modules.wms.inventory.inventoryHeader.mapper.InventoryDetailMapper; | 13 | import org.jeecg.modules.wms.inventory.inventoryHeader.mapper.InventoryDetailMapper; |
12 | import org.jeecg.modules.wms.inventory.inventoryHeader.mapper.InventoryHeaderMapper; | 14 | import org.jeecg.modules.wms.inventory.inventoryHeader.mapper.InventoryHeaderMapper; |
15 | +import org.jeecg.modules.wms.inventory.inventoryHeader.service.IInventoryDetailService; | ||
13 | import org.jeecg.modules.wms.inventory.inventoryHeader.service.IInventoryHeaderService; | 16 | import org.jeecg.modules.wms.inventory.inventoryHeader.service.IInventoryHeaderService; |
14 | import org.springframework.beans.factory.annotation.Autowired; | 17 | import org.springframework.beans.factory.annotation.Autowired; |
15 | import org.springframework.stereotype.Service; | 18 | import org.springframework.stereotype.Service; |
@@ -36,6 +39,8 @@ public class InventoryHeaderServiceImpl extends ServiceImpl<InventoryHeaderMappe | @@ -36,6 +39,8 @@ public class InventoryHeaderServiceImpl extends ServiceImpl<InventoryHeaderMappe | ||
36 | private IContainerService containerService; | 39 | private IContainerService containerService; |
37 | @Resource | 40 | @Resource |
38 | private IInventoryHeaderService inventoryHeaderService; | 41 | private IInventoryHeaderService inventoryHeaderService; |
42 | + @Resource | ||
43 | + private IInventoryDetailService inventoryDetailService; | ||
39 | 44 | ||
40 | @Override | 45 | @Override |
41 | @Transactional | 46 | @Transactional |
@@ -71,6 +76,16 @@ public class InventoryHeaderServiceImpl extends ServiceImpl<InventoryHeaderMappe | @@ -71,6 +76,16 @@ public class InventoryHeaderServiceImpl extends ServiceImpl<InventoryHeaderMappe | ||
71 | if (inventoryHeader != null) { | 76 | if (inventoryHeader != null) { |
72 | inventoryHeader.setContainerStatus(container.getStatus()); | 77 | inventoryHeader.setContainerStatus(container.getStatus()); |
73 | boolean success = inventoryHeaderService.updateById(inventoryHeader); | 78 | boolean success = inventoryHeaderService.updateById(inventoryHeader); |
79 | + if (!success) { | ||
80 | + return success; | ||
81 | + } | ||
82 | + List<InventoryDetail> inventoryDetailList = inventoryDetailService.getInventoryDetailListByContainerCode(containerCode, warehouseCode); | ||
83 | + if (inventoryDetailList.size() > 0) { | ||
84 | + for (InventoryDetail inventoryDetail : inventoryDetailList) { | ||
85 | + inventoryDetail.setContainerStatus(container.getStatus()); | ||
86 | + } | ||
87 | + success = inventoryDetailService.updateBatchById(inventoryDetailList); | ||
88 | + } | ||
74 | return success; | 89 | return success; |
75 | } | 90 | } |
76 | return false; | 91 | return false; |
huaheng-wms-core/src/main/java/org/jeecg/modules/wms/receipt/receiptContainerHeader/service/impl/ReceiptContainerHeaderServiceImpl.java
@@ -120,8 +120,7 @@ public class ReceiptContainerHeaderServiceImpl extends ServiceImpl<ReceiptContai | @@ -120,8 +120,7 @@ public class ReceiptContainerHeaderServiceImpl extends ServiceImpl<ReceiptContai | ||
120 | if (receiptContainerDetailList.size() == 0) { | 120 | if (receiptContainerDetailList.size() == 0) { |
121 | return Result.error("id:" + receiptContainerHeader.getId() + "的入库组盘,没有组盘明细,请先组盘!"); | 121 | return Result.error("id:" + receiptContainerHeader.getId() + "的入库组盘,没有组盘明细,请先组盘!"); |
122 | } | 122 | } |
123 | - boolean success = containerService.updateStatusByOriginStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, QuantityConstant.STATUS_CONTAINER_EMPTY, | ||
124 | - warehouseCode); | 123 | + boolean success = containerService.updateStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, warehouseCode); |
125 | if (!success) { | 124 | if (!success) { |
126 | throw new JeecgBootException("更新容器状态失败"); | 125 | throw new JeecgBootException("更新容器状态失败"); |
127 | } | 126 | } |
@@ -136,10 +135,12 @@ public class ReceiptContainerHeaderServiceImpl extends ServiceImpl<ReceiptContai | @@ -136,10 +135,12 @@ public class ReceiptContainerHeaderServiceImpl extends ServiceImpl<ReceiptContai | ||
136 | } | 135 | } |
137 | String zoneCode = null; | 136 | String zoneCode = null; |
138 | if (StringUtils.isNotEmpty(toLocaitonCode)) { | 137 | if (StringUtils.isNotEmpty(toLocaitonCode)) { |
139 | - success = locationService.updateStatusByOriginStatus(toLocaitonCode, QuantityConstant.STATUS_LOCATION_LOCK, QuantityConstant.STATUS_LOCATION_EMPTY, | ||
140 | - warehouseCode); | ||
141 | - if (!success) { | ||
142 | - throw new JeecgBootException("更新目标库位状态失败"); | 138 | + if (!toLocaitonCode.equals(fromLocationCode)) { |
139 | + success = locationService.updateStatusByOriginStatus(toLocaitonCode, QuantityConstant.STATUS_LOCATION_LOCK, QuantityConstant.STATUS_LOCATION_EMPTY, | ||
140 | + warehouseCode); | ||
141 | + if (!success) { | ||
142 | + throw new JeecgBootException("更新目标库位状态失败"); | ||
143 | + } | ||
143 | } | 144 | } |
144 | Location toLocation = locationService.getLocationByCode(toLocaitonCode, warehouseCode); | 145 | Location toLocation = locationService.getLocationByCode(toLocaitonCode, warehouseCode); |
145 | if (!toLocation.getWarehouseCode().equals(warehouseCode)) { | 146 | if (!toLocation.getWarehouseCode().equals(warehouseCode)) { |
huaheng-wms-core/src/main/java/org/jeecg/modules/wms/stocktaking/cycleCountDetail/service/impl/CycleCountDetailServiceImpl.java
@@ -229,8 +229,7 @@ public class CycleCountDetailServiceImpl extends ServiceImpl<CycleCountDetailMap | @@ -229,8 +229,7 @@ public class CycleCountDetailServiceImpl extends ServiceImpl<CycleCountDetailMap | ||
229 | throw new JeecgBootException("更新库位状态失败"); | 229 | throw new JeecgBootException("更新库位状态失败"); |
230 | } | 230 | } |
231 | // 生成任务同时锁定容器 | 231 | // 生成任务同时锁定容器 |
232 | - success = containerServiceImpl.updateStatusByOriginStatus(location.getContainerCode(), QuantityConstant.STATUS_LOCATION_LOCK, | ||
233 | - QuantityConstant.STATUS_LOCATION_EMPTY, warehouseCode); | 232 | + success = containerServiceImpl.updateStatus(location.getContainerCode(), QuantityConstant.STATUS_LOCATION_LOCK, warehouseCode); |
234 | if (!success) { | 233 | if (!success) { |
235 | throw new JeecgBootException("更新容器状态失败"); | 234 | throw new JeecgBootException("更新容器状态失败"); |
236 | } | 235 | } |
huaheng-wms-core/src/main/java/org/jeecg/modules/wms/task/taskHeader/service/impl/TaskHeaderServiceImpl.java
@@ -67,6 +67,7 @@ import org.springframework.stereotype.Service; | @@ -67,6 +67,7 @@ import org.springframework.stereotype.Service; | ||
67 | import org.springframework.transaction.annotation.Transactional; | 67 | import org.springframework.transaction.annotation.Transactional; |
68 | 68 | ||
69 | import com.alibaba.fastjson.JSON; | 69 | import com.alibaba.fastjson.JSON; |
70 | +import com.aliyun.oss.ServiceException; | ||
70 | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 71 | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
71 | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | 72 | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; |
72 | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | 73 | import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
@@ -299,8 +300,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -299,8 +300,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
299 | if (!success) { | 300 | if (!success) { |
300 | throw new JeecgBootException("创建移库任务时, 终点库位" + toLocationCode + "更新失败"); | 301 | throw new JeecgBootException("创建移库任务时, 终点库位" + toLocationCode + "更新失败"); |
301 | } | 302 | } |
302 | - success = containerService.updateStatusByOriginStatus(fromLocation.getContainerCode(), QuantityConstant.STATUS_CONTAINER_LOCK, | ||
303 | - QuantityConstant.STATUS_CONTAINER_EMPTY, warehouseCode); | 303 | + success = containerService.updateStatus(fromLocation.getContainerCode(), QuantityConstant.STATUS_CONTAINER_LOCK, warehouseCode); |
304 | if (!success) { | 304 | if (!success) { |
305 | throw new JeecgBootException("创建移库任务时,容器" + fromLocation.getContainerCode() + "更新失败"); | 305 | throw new JeecgBootException("创建移库任务时,容器" + fromLocation.getContainerCode() + "更新失败"); |
306 | } | 306 | } |
@@ -358,8 +358,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -358,8 +358,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
358 | if (!success) { | 358 | if (!success) { |
359 | throw new JeecgBootException("创建出库查看任务时,更新库位状态失败"); | 359 | throw new JeecgBootException("创建出库查看任务时,更新库位状态失败"); |
360 | } | 360 | } |
361 | - success = containerService.updateStatusByOriginStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, QuantityConstant.STATUS_CONTAINER_EMPTY, | ||
362 | - warehouseCode); | 361 | + success = containerService.updateStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, warehouseCode); |
363 | if (!success) { | 362 | if (!success) { |
364 | throw new JeecgBootException("创建出库查看任务时,更新容器状态失败"); | 363 | throw new JeecgBootException("创建出库查看任务时,更新容器状态失败"); |
365 | } | 364 | } |
@@ -427,8 +426,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -427,8 +426,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
427 | if (!success) { | 426 | if (!success) { |
428 | return Result.error("创建跨站任务时, 创建任务失败"); | 427 | return Result.error("创建跨站任务时, 创建任务失败"); |
429 | } | 428 | } |
430 | - success = containerService.updateStatusByOriginStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, QuantityConstant.STATUS_CONTAINER_EMPTY, | ||
431 | - warehouseCode); | 429 | + success = containerService.updateStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, warehouseCode); |
432 | if (!success) { | 430 | if (!success) { |
433 | return Result.error("创建跨站任务时, 更新容器状态失败"); | 431 | return Result.error("创建跨站任务时, 更新容器状态失败"); |
434 | } | 432 | } |
@@ -520,8 +518,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -520,8 +518,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
520 | if (!container.getStatus().equals(QuantityConstant.STATUS_CONTAINER_EMPTY)) { | 518 | if (!container.getStatus().equals(QuantityConstant.STATUS_CONTAINER_EMPTY)) { |
521 | return Result.error("创建空托盘组入库任务时,容器状态不为空容器"); | 519 | return Result.error("创建空托盘组入库任务时,容器状态不为空容器"); |
522 | } | 520 | } |
523 | - boolean success = containerService.updateStatusByOriginStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, QuantityConstant.STATUS_CONTAINER_EMPTY, | ||
524 | - warehouseCode); | 521 | + boolean success = containerService.updateStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, warehouseCode); |
525 | if (!success) { | 522 | if (!success) { |
526 | throw new JeecgBootException("创建空托盘组入库任务时, 更新容器状态失败"); | 523 | throw new JeecgBootException("创建空托盘组入库任务时, 更新容器状态失败"); |
527 | } | 524 | } |
@@ -586,12 +583,12 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -586,12 +583,12 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
586 | if (StringUtils.isEmpty(zoneCode)) { | 583 | if (StringUtils.isEmpty(zoneCode)) { |
587 | return Result.error("创建空托盘组出库任务时, 库区为空"); | 584 | return Result.error("创建空托盘组出库任务时, 库区为空"); |
588 | } | 585 | } |
589 | - boolean success = containerService.updateStatusByOriginStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, QuantityConstant.STATUS_CONTAINER_EMPTY, | 586 | + boolean success = containerService.updateStatusByOriginStatus(containerCode, QuantityConstant.STATUS_CONTAINER_LOCK, QuantityConstant.STATUS_CONTAINER_MANY, |
590 | warehouseCode); | 587 | warehouseCode); |
591 | if (!success) { | 588 | if (!success) { |
592 | throw new JeecgBootException("创建空托盘组出库任务时, 更新容器状态失败"); | 589 | throw new JeecgBootException("创建空托盘组出库任务时, 更新容器状态失败"); |
593 | } | 590 | } |
594 | - success = locationService.updateStatusByOriginStatus(fromLocationCode, QuantityConstant.STATUS_LOCATION_LOCK, QuantityConstant.STATUS_LOCATION_LOCK, | 591 | + success = locationService.updateStatusByOriginStatus(fromLocationCode, QuantityConstant.STATUS_LOCATION_LOCK, QuantityConstant.STATUS_LOCATION_EMPTY, |
595 | warehouseCode); | 592 | warehouseCode); |
596 | if (!success) { | 593 | if (!success) { |
597 | throw new JeecgBootException("创建空托盘组出库任务时, 更新库位状态失败"); | 594 | throw new JeecgBootException("创建空托盘组出库任务时, 更新库位状态失败"); |
@@ -1128,7 +1125,9 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -1128,7 +1125,9 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
1128 | for (InventoryDetail inventoryDetail : inventoryDetailList) { | 1125 | for (InventoryDetail inventoryDetail : inventoryDetailList) { |
1129 | inventoryDetail.setLocationCode(toLocationCode); | 1126 | inventoryDetail.setLocationCode(toLocationCode); |
1130 | inventoryDetail.setZoneCode(zoneCode); | 1127 | inventoryDetail.setZoneCode(zoneCode); |
1131 | - inventoryDetailService.updateById(inventoryDetail); | 1128 | + if (!inventoryDetailService.updateById(inventoryDetail)) { |
1129 | + throw new ServiceException("更新库存详情失败"); | ||
1130 | + } | ||
1132 | } | 1131 | } |
1133 | } | 1132 | } |
1134 | } else { | 1133 | } else { |
@@ -1255,6 +1254,9 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -1255,6 +1254,9 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
1255 | throw new JeecgBootException("完成入库任务时,更新入库单头失败"); | 1254 | throw new JeecgBootException("完成入库任务时,更新入库单头失败"); |
1256 | } | 1255 | } |
1257 | } | 1256 | } |
1257 | + if (!inventoryHeaderService.updateInventoryContainerStatusByContainerCode(containerCode, warehouseCode)) { | ||
1258 | + throw new JeecgBootException("完成入库任务时,更新托盘状态失败"); | ||
1259 | + } | ||
1258 | receiptDetaiList = receiptDetaiList.stream().filter(t -> t.getStatus().equals(QuantityConstant.RECEIPT_HEADER_COMPLETED)).collect(Collectors.toList()); | 1260 | receiptDetaiList = receiptDetaiList.stream().filter(t -> t.getStatus().equals(QuantityConstant.RECEIPT_HEADER_COMPLETED)).collect(Collectors.toList()); |
1259 | LogRecordContext.putVariable("taskHeader", taskHeader); | 1261 | LogRecordContext.putVariable("taskHeader", taskHeader); |
1260 | LogRecordContext.putVariable("taskDetailList", taskDetailList); | 1262 | LogRecordContext.putVariable("taskDetailList", taskDetailList); |
@@ -1454,6 +1456,11 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -1454,6 +1456,11 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
1454 | throw new JeecgBootException("完成出库任务,更新出库单头失败"); | 1456 | throw new JeecgBootException("完成出库任务,更新出库单头失败"); |
1455 | } | 1457 | } |
1456 | } | 1458 | } |
1459 | + if (taskType != QuantityConstant.TASK_TYPE_WHOLESHIPMENT) { | ||
1460 | + if (!inventoryHeaderService.updateInventoryContainerStatusByContainerCode(containerCode, warehouseCode)) { | ||
1461 | + throw new JeecgBootException("完成出库任务,更新库存状态失败"); | ||
1462 | + } | ||
1463 | + } | ||
1457 | // 操作记录添加 | 1464 | // 操作记录添加 |
1458 | shipmentDetailList = shipmentDetailList.stream().filter(t -> t.getStatus().equals(QuantityConstant.SHIPMENT_HEADER_COMPLETED)).collect(Collectors.toList()); | 1465 | shipmentDetailList = shipmentDetailList.stream().filter(t -> t.getStatus().equals(QuantityConstant.SHIPMENT_HEADER_COMPLETED)).collect(Collectors.toList()); |
1459 | LogRecordContext.putVariable("taskHeader", taskHeader); | 1466 | LogRecordContext.putVariable("taskHeader", taskHeader); |
@@ -1585,10 +1592,6 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -1585,10 +1592,6 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
1585 | } | 1592 | } |
1586 | LoginUser sysUser = (LoginUser)SecurityUtils.getSubject().getPrincipal(); | 1593 | LoginUser sysUser = (LoginUser)SecurityUtils.getSubject().getPrincipal(); |
1587 | taskHeader.setStatus(QuantityConstant.TASK_STATUS_COMPLETED); | 1594 | taskHeader.setStatus(QuantityConstant.TASK_STATUS_COMPLETED); |
1588 | - // 更新用户 | ||
1589 | - taskHeader.setUpdateBy(sysUser.getUsername()); | ||
1590 | - // 更新时间 | ||
1591 | - taskHeader.setUpdateTime(new Date()); | ||
1592 | 1595 | ||
1593 | // 1.先拿到盘点单主单据 | 1596 | // 1.先拿到盘点单主单据 |
1594 | CycleCountDetail cycleCountDetail = cycleCountDetailService.getById(taskHeader.getShipmentContainerHeaderId()); | 1597 | CycleCountDetail cycleCountDetail = cycleCountDetailService.getById(taskHeader.getShipmentContainerHeaderId()); |
@@ -1779,7 +1782,6 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -1779,7 +1782,6 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
1779 | } | 1782 | } |
1780 | // 盘点明细状态 | 1783 | // 盘点明细状态 |
1781 | cycleCountDetail.setEnableStatus(QuantityConstant.CYCLECOUNT_STATUS_COMPLETED); | 1784 | cycleCountDetail.setEnableStatus(QuantityConstant.CYCLECOUNT_STATUS_COMPLETED); |
1782 | - cycleCountDetail.setCompletedBy(sysUser.getUsername()); | ||
1783 | cycleCountDetail.setCompletedAt(new Date()); | 1785 | cycleCountDetail.setCompletedAt(new Date()); |
1784 | cycleCountDetailService.updateById(cycleCountDetail); | 1786 | cycleCountDetailService.updateById(cycleCountDetail); |
1785 | // 更新主单状态 | 1787 | // 更新主单状态 |
@@ -2041,10 +2043,10 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | @@ -2041,10 +2043,10 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea | ||
2041 | } | 2043 | } |
2042 | } else { | 2044 | } else { |
2043 | if (fromLocationCode.equals(toLocationCode)) { | 2045 | if (fromLocationCode.equals(toLocationCode)) { |
2044 | - success = containerService.updateStatusByOriginStatus(containerCode, QuantityConstant.STATUS_CONTAINER_SOME, QuantityConstant.STATUS_CONTAINER_LOCK, | 2046 | + success = containerService.updateStatusByOriginStatus(containerCode, QuantityConstant.STATUS_CONTAINER_EMPTY, QuantityConstant.STATUS_CONTAINER_LOCK, |
2045 | warehouseCode); | 2047 | warehouseCode); |
2046 | } else { | 2048 | } else { |
2047 | - success = containerService.updateLocationCodeAndStatus(containerCode, toLocationCode, QuantityConstant.STATUS_CONTAINER_SOME, warehouseCode); | 2049 | + success = containerService.updateLocationCodeAndStatus(containerCode, toLocationCode, QuantityConstant.STATUS_CONTAINER_EMPTY, warehouseCode); |
2048 | } | 2050 | } |
2049 | if (!success) { | 2051 | if (!success) { |
2050 | throw new JeecgBootException("完成出库查看任务时,更新容器状态失败"); | 2052 | throw new JeecgBootException("完成出库查看任务时,更新容器状态失败"); |
huaheng-wms-core/src/main/java/org/jeecg/utils/HuahengJwtUtil.java
@@ -11,6 +11,7 @@ import org.apache.shiro.SecurityUtils; | @@ -11,6 +11,7 @@ import org.apache.shiro.SecurityUtils; | ||
11 | import org.jeecg.common.exception.JeecgBootException; | 11 | import org.jeecg.common.exception.JeecgBootException; |
12 | import org.jeecg.common.system.vo.LoginUser; | 12 | import org.jeecg.common.system.vo.LoginUser; |
13 | import org.jeecg.common.util.oConvertUtils; | 13 | import org.jeecg.common.util.oConvertUtils; |
14 | +import org.jeecg.utils.constant.QuantityConstant; | ||
14 | import org.jeecg.utils.support.ApiAuthentication; | 15 | import org.jeecg.utils.support.ApiAuthentication; |
15 | import org.jeecg.utils.support.RSA256Key; | 16 | import org.jeecg.utils.support.RSA256Key; |
16 | import org.jeecg.utils.support.SystemAuthentication; | 17 | import org.jeecg.utils.support.SystemAuthentication; |
@@ -30,7 +31,7 @@ import cn.hutool.core.util.ReflectUtil; | @@ -30,7 +31,7 @@ import cn.hutool.core.util.ReflectUtil; | ||
30 | 31 | ||
31 | @Component | 32 | @Component |
32 | public class HuahengJwtUtil { | 33 | public class HuahengJwtUtil { |
33 | - | 34 | + |
34 | /** token失效时间 1天 */ | 35 | /** token失效时间 1天 */ |
35 | public static final long EXPIRE_TIME = 12 * 60 * 60 * 1000; | 36 | public static final long EXPIRE_TIME = 12 * 60 * 60 * 1000; |
36 | 37 | ||
@@ -42,13 +43,13 @@ public class HuahengJwtUtil { | @@ -42,13 +43,13 @@ public class HuahengJwtUtil { | ||
42 | 43 | ||
43 | /** 全仓CODE */ | 44 | /** 全仓CODE */ |
44 | public static final String ALL_WAREHOUSE_CODE = "ALL_WAREHOUSE"; | 45 | public static final String ALL_WAREHOUSE_CODE = "ALL_WAREHOUSE"; |
45 | - | 46 | + |
46 | public static final String SYSTEM_ACTIVATION_CODE_FILE_NAME = "ActivationCode.txt"; | 47 | public static final String SYSTEM_ACTIVATION_CODE_FILE_NAME = "ActivationCode.txt"; |
47 | - | 48 | + |
48 | public static final String SYSTEM_ACTIVATION_CODE_KEY = "ActivationCode"; | 49 | public static final String SYSTEM_ACTIVATION_CODE_KEY = "ActivationCode"; |
49 | 50 | ||
50 | - public static final String UNKNOWN_USER = "unknown"; | ||
51 | - | 51 | + public static final String UNKNOWN_USER = QuantityConstant.EMPTY_STRING; |
52 | + | ||
52 | /** | 53 | /** |
53 | * 根据request中的token获取用户账号 | 54 | * 根据request中的token获取用户账号 |
54 | * @param request | 55 | * @param request |