Commit 1ae0e30780dd949234e5da8ddfcc7fa76ac8e0cf
Merge branch 'develop' of http://172.16.29.40:8010/wms/wms2 into develop
Showing
33 changed files
with
802 additions
and
753 deletions
src/main/java/com/huaheng/api/wcs/controller/EmptyOutHandle.java
src/main/java/com/huaheng/api/wcs/controller/OverrideHandle.java
1 | 1 | package com.huaheng.api.wcs.controller; |
2 | 2 | |
3 | -import com.huaheng.api.wcs.domain.WcsTask; | |
3 | +import com.huaheng.api.wcs.domain.TaskFinishDomain; | |
4 | 4 | import com.huaheng.api.wcs.service.overrideHandle.OverrideHandleService; |
5 | -import com.huaheng.api.wcs.service.taskFinish.TaskFinishService; | |
6 | 5 | import com.huaheng.framework.aspectj.lang.annotation.Log; |
7 | 6 | import com.huaheng.framework.aspectj.lang.constant.BusinessType; |
8 | 7 | import com.huaheng.framework.web.controller.BaseController; |
... | ... | @@ -21,7 +20,7 @@ import javax.annotation.Resource; |
21 | 20 | */ |
22 | 21 | |
23 | 22 | @RestController |
24 | -@RequestMapping("/WCS/v1") | |
23 | +@RequestMapping("/WCS/v2") | |
25 | 24 | @Api(tags = {"OverrideHandle"}, description = "wcs重入处理接口") |
26 | 25 | public class OverrideHandle extends BaseController { |
27 | 26 | |
... | ... | @@ -32,9 +31,9 @@ public class OverrideHandle extends BaseController { |
32 | 31 | @PostMapping("/OverrideHandle") |
33 | 32 | @ApiOperation("wcs重入处理") |
34 | 33 | @ResponseBody |
35 | - public AjaxResult OverrideHandle(@RequestBody WcsTask wcsTask) | |
34 | + public AjaxResult OverrideHandle(@RequestBody TaskFinishDomain taskFinishDomain) | |
36 | 35 | { |
37 | - AjaxResult ajaxResult =overrideHandleService.OverrideHandle(wcsTask) ; | |
36 | + AjaxResult ajaxResult =overrideHandleService.OverrideHandle(taskFinishDomain) ; | |
38 | 37 | return ajaxResult; |
39 | 38 | } |
40 | 39 | |
... | ... |
src/main/java/com/huaheng/api/wcs/controller/TaskFinish.java
1 | 1 | package com.huaheng.api.wcs.controller; |
2 | 2 | |
3 | +import com.huaheng.api.wcs.domain.TaskFinishDomain; | |
3 | 4 | import com.huaheng.api.wcs.domain.WcsTask; |
4 | 5 | import com.huaheng.api.wcs.service.taskFinish.TaskFinishService; |
5 | 6 | import com.huaheng.framework.aspectj.lang.annotation.Log; |
... | ... | @@ -20,7 +21,7 @@ import javax.annotation.Resource; |
20 | 21 | */ |
21 | 22 | |
22 | 23 | @RestController |
23 | -@RequestMapping("/WCS/v1") | |
24 | +@RequestMapping("/WCS/v2") | |
24 | 25 | @Api(tags = {"TaskFinish"}, description = "wcs任务完成数据接口") |
25 | 26 | public class TaskFinish extends BaseController { |
26 | 27 | |
... | ... | @@ -31,9 +32,9 @@ public class TaskFinish extends BaseController { |
31 | 32 | @PostMapping("/TaskFinish") |
32 | 33 | @ApiOperation("wcs任务完成") |
33 | 34 | @ResponseBody |
34 | - public AjaxResult TaskFinish(@RequestBody WcsTask wcsTask) | |
35 | + public AjaxResult TaskFinish(@RequestBody TaskFinishDomain taskFinishDomain) | |
35 | 36 | { |
36 | - AjaxResult ajaxResult =taskFinishService.completeTaskByWCS(wcsTask) ; | |
37 | + AjaxResult ajaxResult =taskFinishService.completeTaskByWCS(taskFinishDomain) ; | |
37 | 38 | return ajaxResult; |
38 | 39 | } |
39 | 40 | |
... | ... |
src/main/java/com/huaheng/api/wcs/controller/WarecellAllocation.java
... | ... | @@ -21,7 +21,7 @@ import javax.annotation.Resource; |
21 | 21 | */ |
22 | 22 | |
23 | 23 | @RestController |
24 | -@RequestMapping("/WCS/v1") | |
24 | +@RequestMapping("/WCS/v2") | |
25 | 25 | @Api(tags = {"WarecellAllocation"}, description = "wcs仓位分配接口") |
26 | 26 | public class WarecellAllocation extends BaseController { |
27 | 27 | |
... | ... | @@ -30,7 +30,7 @@ public class WarecellAllocation extends BaseController { |
30 | 30 | |
31 | 31 | @Log(title = "wcs仓位分配", action = BusinessType.INSERT) |
32 | 32 | @PostMapping("/WarecellAllocation") |
33 | - @ApiOperation("wcs仓位分配") | |
33 | + @ApiOperation(value="wcs仓位分配", notes="wcs仓位分配", httpMethod = "POST") | |
34 | 34 | @ResponseBody |
35 | 35 | public AjaxResult WarecellAllocation(@RequestBody WcsTask wcsTask) |
36 | 36 | { |
... | ... |
src/main/java/com/huaheng/api/wcs/domain/TaskDetails.java
0 → 100644
1 | +package com.huaheng.api.wcs.domain; | |
2 | + | |
3 | +import lombok.Data; | |
4 | + | |
5 | +import java.math.BigDecimal; | |
6 | + | |
7 | +/** | |
8 | + * Created by Enzo Cotter on 2019/10/15. | |
9 | + */ | |
10 | +@Data | |
11 | +public class TaskDetails { | |
12 | + | |
13 | + //关联行号,string (50),默认0 ",必填 | |
14 | + private String referLineNo; | |
15 | + | |
16 | + //物料编码,string (50),默认0 ",必填 | |
17 | + private String materialCode; | |
18 | + | |
19 | + //物料名称 | |
20 | + private String materialName; | |
21 | + | |
22 | + //数量,float,默认“0” ,必填" | |
23 | + private BigDecimal qty; | |
24 | + | |
25 | + //单位,string(20),默认“PCS” ,必填" | |
26 | + private String unit; | |
27 | +} | |
... | ... |
src/main/java/com/huaheng/api/wcs/domain/TaskFinishDomain.java
0 → 100644
1 | +package com.huaheng.api.wcs.domain; | |
2 | + | |
3 | +import lombok.Data; | |
4 | + | |
5 | +/** | |
6 | + * 任务完成和重入实体类 | |
7 | + * Created by Enzo Cotter on 2019/10/15. | |
8 | + */ | |
9 | +@Data | |
10 | +public class TaskFinishDomain { | |
11 | + | |
12 | + //任务号 | |
13 | + private String taskNo; | |
14 | + | |
15 | + //重入,int,1:重入 0:正常,必填 | |
16 | + private Integer isDoubleIn; | |
17 | + | |
18 | + //空出,int,1:空出 0:正常,必填 | |
19 | + private Integer isEmptyOut; | |
20 | + | |
21 | + //重入的库位编码,string (50),默认0,必填 | |
22 | + private String redirectionLocationCode; | |
23 | + | |
24 | + //目的位置编码,string (50),默认0 ",必填 | |
25 | + private String toLocationCode; | |
26 | +} | |
... | ... |
src/main/java/com/huaheng/api/wcs/domain/WcsTask.java
1 | 1 | package com.huaheng.api.wcs.domain; |
2 | 2 | |
3 | +import lombok.Data; | |
4 | + | |
3 | 5 | import java.io.Serializable; |
6 | +import java.util.List; | |
4 | 7 | |
5 | 8 | /** |
6 | 9 | * wcs任务接口实体层 |
7 | 10 | * @author ricard |
8 | 11 | * @date 2019/10/11 |
9 | 12 | */ |
13 | + | |
14 | +@Data | |
10 | 15 | public class WcsTask implements Serializable { |
11 | 16 | private static final long serialVersionUID = -8855840499538794854L; |
12 | 17 | |
... | ... | @@ -23,7 +28,13 @@ public class WcsTask implements Serializable { |
23 | 28 | private String platform; |
24 | 29 | |
25 | 30 | //容器编码 |
26 | - private String palletNo; | |
31 | + private String containerCode; | |
32 | + | |
33 | + //来源口”,一般用于指定入库口,string (50),默认0,必填 | |
34 | + private String fromPort; | |
35 | + | |
36 | + //目的口”,出库性质的任务必须填写,string (50),默认0,必填 | |
37 | + private String toPort; | |
27 | 38 | |
28 | 39 | //源位置库位编码 |
29 | 40 | private String fromLocationCode; |
... | ... | @@ -34,138 +45,26 @@ public class WcsTask implements Serializable { |
34 | 45 | //重入后再次分配的位置编码 |
35 | 46 | private String locationCode; |
36 | 47 | |
37 | - //取消任务 | |
38 | - private String reason; | |
48 | + //优先级,int,默认100 ,数字越小优先级越高",必填 | |
49 | + private int priority; | |
50 | + | |
51 | + //巷道 | |
52 | + private String roadWay; | |
39 | 53 | |
40 | 54 | //长 |
41 | - private Float length; | |
55 | + private String length; | |
42 | 56 | |
43 | 57 | //宽 |
44 | - private Float width; | |
58 | + private String width; | |
45 | 59 | |
46 | 60 | //高 |
47 | - private Float height; | |
61 | + private String height; | |
48 | 62 | |
49 | 63 | //重 |
50 | - private Float weight; | |
51 | - | |
52 | - public String getTaskNo() { | |
53 | - return taskNo; | |
54 | - } | |
55 | - | |
56 | - public void setTaskNo(String taskNo) { | |
57 | - this.taskNo = taskNo; | |
58 | - } | |
59 | - | |
60 | - public String getTaskType() { | |
61 | - return taskType; | |
62 | - } | |
63 | - | |
64 | - public void setTaskType(String taskType) { | |
65 | - this.taskType = taskType; | |
66 | - } | |
67 | - | |
68 | - public String getStation() { | |
69 | - return station; | |
70 | - } | |
71 | - | |
72 | - public void setStation(String station) { | |
73 | - this.station = station; | |
74 | - } | |
75 | - | |
76 | - public String getPlatform() { | |
77 | - return platform; | |
78 | - } | |
79 | - | |
80 | - public void setPlatform(String platform) { | |
81 | - this.platform = platform; | |
82 | - } | |
83 | - | |
84 | - public String getPalletNo() { | |
85 | - return palletNo; | |
86 | - } | |
87 | - | |
88 | - public void setPalletNo(String palletNo) { | |
89 | - this.palletNo = palletNo; | |
90 | - } | |
91 | - | |
92 | - public String getFromLocationCode() { | |
93 | - return fromLocationCode; | |
94 | - } | |
95 | - | |
96 | - public void setFromLocationCode(String fromLocationCode) { | |
97 | - this.fromLocationCode = fromLocationCode; | |
98 | - } | |
99 | - | |
100 | - public String getToLocationCode() { | |
101 | - return toLocationCode; | |
102 | - } | |
103 | - | |
104 | - public void setToLocationCode(String toLocationCode) { | |
105 | - this.toLocationCode = toLocationCode; | |
106 | - } | |
107 | - | |
108 | - public String getReason() { | |
109 | - return reason; | |
110 | - } | |
111 | - | |
112 | - public void setReason(String reason) { | |
113 | - this.reason = reason; | |
114 | - } | |
115 | - | |
116 | - public float getLength() { | |
117 | - return length; | |
118 | - } | |
119 | - | |
120 | - public void setLength(float length) { | |
121 | - this.length = length; | |
122 | - } | |
123 | - | |
124 | - public float getWidth() { | |
125 | - return width; | |
126 | - } | |
127 | - | |
128 | - public void setWidth(float width) { | |
129 | - this.width = width; | |
130 | - } | |
131 | - | |
132 | - public float getHeight() { | |
133 | - return height; | |
134 | - } | |
135 | - | |
136 | - public void setHeight(float height) { | |
137 | - this.height = height; | |
138 | - } | |
139 | - | |
140 | - public float getWeight() { | |
141 | - return weight; | |
142 | - } | |
143 | - | |
144 | - public void setWeight(float weight) { | |
145 | - this.weight = weight; | |
146 | - } | |
147 | - | |
148 | - public String getLocationCode() { | |
149 | - return locationCode; | |
150 | - } | |
151 | - | |
152 | - public void setLocationCode(String locationCode) { | |
153 | - this.locationCode = locationCode; | |
154 | - } | |
155 | - | |
156 | - public void setLength(Float length) { | |
157 | - this.length = length; | |
158 | - } | |
159 | - | |
160 | - public void setWidth(Float width) { | |
161 | - this.width = width; | |
162 | - } | |
64 | + private String weight; | |
163 | 65 | |
164 | - public void setHeight(Float height) { | |
165 | - this.height = height; | |
166 | - } | |
66 | + //备注 | |
67 | + private String remark; | |
167 | 68 | |
168 | - public void setWeight(Float weight) { | |
169 | - this.weight = weight; | |
170 | - } | |
69 | + private List<TaskDetails> taskDetails; | |
171 | 70 | } |
... | ... |
src/main/java/com/huaheng/api/wcs/service/emptyOutHandle/EmptyOutHandleServiceImpl.java
... | ... | @@ -40,7 +40,7 @@ public class EmptyOutHandleServiceImpl implements EmptyOutHandleService { |
40 | 40 | } |
41 | 41 | |
42 | 42 | //3、修改该任务为空出,过后处理 |
43 | - taskHeader.setUserDef1("空托出库"); | |
43 | + taskHeader.setExceptionCode("空托出库"); | |
44 | 44 | Boolean flag = taskHeaderService.updateById(taskHeader); |
45 | 45 | if(flag == false){ |
46 | 46 | return AjaxResult.error("修改任务失败,空出处理失败"); |
... | ... |
src/main/java/com/huaheng/api/wcs/service/overrideHandle/OverrideHandleService.java
1 | 1 | package com.huaheng.api.wcs.service.overrideHandle; |
2 | 2 | |
3 | +import com.huaheng.api.wcs.domain.TaskFinishDomain; | |
3 | 4 | import com.huaheng.api.wcs.domain.WcsTask; |
4 | 5 | import com.huaheng.framework.web.domain.AjaxResult; |
5 | 6 | |
6 | 7 | public interface OverrideHandleService { |
7 | 8 | |
8 | 9 | //重入处理 |
9 | - AjaxResult OverrideHandle(WcsTask wcsTask); | |
10 | + AjaxResult OverrideHandle(TaskFinishDomain taskFinishDomain); | |
10 | 11 | } |
... | ... |
src/main/java/com/huaheng/api/wcs/service/overrideHandle/OverrideHandleServiceImpl.java
... | ... | @@ -2,6 +2,7 @@ package com.huaheng.api.wcs.service.overrideHandle; |
2 | 2 | |
3 | 3 | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
4 | 4 | import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
5 | +import com.huaheng.api.wcs.domain.TaskFinishDomain; | |
5 | 6 | import com.huaheng.api.wcs.domain.WcsTask; |
6 | 7 | import com.huaheng.common.exception.service.ServiceException; |
7 | 8 | import com.huaheng.common.utils.StringUtils; |
... | ... | @@ -48,19 +49,24 @@ public class OverrideHandleServiceImpl implements OverrideHandleService { |
48 | 49 | |
49 | 50 | @Override |
50 | 51 | @Transactional |
51 | - public AjaxResult OverrideHandle(WcsTask wcsTask) { | |
52 | + public AjaxResult OverrideHandle(TaskFinishDomain taskFinishDomain) { | |
52 | 53 | Boolean flag = true; |
53 | 54 | |
54 | 55 | //1、判断非空字段 |
55 | - if(StringUtils.isEmpty(wcsTask.getTaskNo())){ | |
56 | + if(StringUtils.isEmpty(taskFinishDomain.getTaskNo())){ | |
56 | 57 | return AjaxResult.error("任务号为空"); |
57 | 58 | } |
58 | - if(StringUtils.isEmpty(wcsTask.getToLocationCode())){ | |
59 | + if(StringUtils.isEmpty(taskFinishDomain.getToLocationCode())){ | |
59 | 60 | return AjaxResult.error("目的库位为空"); |
60 | 61 | } |
62 | + if(StringUtils.isEmpty(taskFinishDomain.getRedirectionLocationCode())){ | |
63 | + return AjaxResult.error("目的库位为空"); | |
64 | + } | |
65 | + | |
66 | + | |
61 | 67 | |
62 | 68 | //2、根据任务号查找任务 |
63 | - TaskHeader taskHeader = taskHeaderService.getById(Integer.valueOf(wcsTask.getTaskNo())); | |
69 | + TaskHeader taskHeader = taskHeaderService.getById(Integer.valueOf(taskFinishDomain.getTaskNo())); | |
64 | 70 | if(taskHeader == null){ |
65 | 71 | return AjaxResult.error("任务号错误,没有找到该任务"); |
66 | 72 | } |
... | ... | @@ -80,16 +86,31 @@ public class OverrideHandleServiceImpl implements OverrideHandleService { |
80 | 86 | return AjaxResult.error("修改此任务的原目的库位错误"); |
81 | 87 | } |
82 | 88 | |
83 | - //查看新库位 | |
84 | - locationLam.eq(Location::getCode,wcsTask.getToLocationCode()) | |
85 | - .eq(Location::getWarehouseCode, ShiroUtils.getWarehouseCode()); | |
86 | - Location newlocation = locationService.getOne(locationLam); | |
87 | - if(newlocation == null){ | |
88 | - throw new ServiceException("新目的库位在系统中不存在"); | |
89 | + | |
90 | + /** | |
91 | + * 查看新库位有两种情况 | |
92 | + * 1、重入的库位由wcs提供 | |
93 | + * 2、重入的库位由wms提供 | |
94 | + */ | |
95 | + | |
96 | + Location newlocation =new Location(); | |
97 | + | |
98 | + //重入的库位由wcs提供 | |
99 | + if(!taskFinishDomain.getRedirectionLocationCode().equals("0")) { | |
100 | + locationLam.eq(Location::getCode, taskFinishDomain.getToLocationCode()) | |
101 | + .eq(Location::getWarehouseCode, ShiroUtils.getWarehouseCode()); | |
102 | + newlocation = locationService.getOne(locationLam); | |
103 | + if (newlocation == null) { | |
104 | + throw new ServiceException("新目的库位在系统中不存在"); | |
105 | + } | |
106 | + }else { | |
107 | + //重入的库位由wms提供 | |
108 | + | |
89 | 109 | } |
110 | + | |
90 | 111 | //修改任务 |
91 | - taskHeader.setToLocation(wcsTask.getToLocationCode()); | |
92 | - taskHeader.setUserDef1("重入处理"); | |
112 | + taskHeader.setToLocation(newlocation.getCode()); | |
113 | + taskHeader.setExceptionCode("重入处理"); | |
93 | 114 | flag = taskHeaderService.updateById(taskHeader); |
94 | 115 | if(flag == false){ |
95 | 116 | throw new ServiceException("修改此任务错误"); |
... | ... | @@ -103,7 +124,7 @@ public class OverrideHandleServiceImpl implements OverrideHandleService { |
103 | 124 | List<TaskDetail> taskDetailList = new ArrayList<>(); |
104 | 125 | if(taskDetails != null && taskDetails.size()> 0){ |
105 | 126 | for(TaskDetail taskDetail : taskDetails){ |
106 | - taskDetail.setToLocation(wcsTask.getToLocationCode()); | |
127 | + taskDetail.setToLocation(newlocation.getCode()); | |
107 | 128 | taskDetailList.add(taskDetail); |
108 | 129 | } |
109 | 130 | flag = taskDetailService.updateBatchById(taskDetailList); |
... | ... | @@ -120,7 +141,7 @@ public class OverrideHandleServiceImpl implements OverrideHandleService { |
120 | 141 | if(receiptContainerHeader == null){ |
121 | 142 | throw new ServiceException("找不到此任务的组盘头"); |
122 | 143 | } |
123 | - receiptContainerHeader.setToLocation(wcsTask.getToLocationCode()); | |
144 | + receiptContainerHeader.setToLocation(newlocation.getCode()); | |
124 | 145 | flag = receiptContainerHeaderService.updateById(receiptContainerHeader); |
125 | 146 | if(flag == false){ |
126 | 147 | throw new ServiceException("修改此任务对应的组盘头错误"); |
... | ... | @@ -131,10 +152,11 @@ public class OverrideHandleServiceImpl implements OverrideHandleService { |
131 | 152 | lam.eq(ReceiptContainerDetail::getReceiptContainerId,receiptContainerHeader.getId()) |
132 | 153 | .eq(ReceiptContainerDetail::getWarehouseCode,ShiroUtils.getWarehouseCode()); |
133 | 154 | List<ReceiptContainerDetail> receiptContainerDetails = receiptContainerDetailService.list(lam); |
155 | + | |
134 | 156 | List<ReceiptContainerDetail> receiptContainerDetailList = new ArrayList<>(); |
135 | 157 | if(receiptContainerDetails != null && receiptContainerDetails.size()> 0){ |
136 | 158 | for(ReceiptContainerDetail receiptContainerDetail : receiptContainerDetails){ |
137 | - receiptContainerDetail.setLocationCode(wcsTask.getToLocationCode()); | |
159 | + receiptContainerDetail.setLocationCode(newlocation.getCode()); | |
138 | 160 | receiptContainerDetailList.add(receiptContainerDetail); |
139 | 161 | } |
140 | 162 | flag = receiptContainerDetailService.updateBatchById(receiptContainerDetailList); |
... | ... |
src/main/java/com/huaheng/api/wcs/service/taskAssignService/TaskAssignServiceImpl.java
... | ... | @@ -2,17 +2,25 @@ package com.huaheng.api.wcs.service.taskAssignService; |
2 | 2 | |
3 | 3 | |
4 | 4 | import com.alibaba.fastjson.JSON; |
5 | +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | |
6 | +import com.baomidou.mybatisplus.core.toolkit.Wrappers; | |
7 | +import com.huaheng.api.wcs.domain.TaskDetails; | |
5 | 8 | import com.huaheng.api.wcs.domain.WcsTask; |
6 | 9 | import com.huaheng.common.exception.service.ServiceException; |
7 | 10 | import com.huaheng.common.utils.StringUtils; |
8 | 11 | import com.huaheng.common.utils.http.HttpUtils; |
9 | 12 | import com.huaheng.framework.web.domain.AjaxResult; |
10 | 13 | import com.huaheng.pc.config.address.service.AddressService; |
14 | +import com.huaheng.pc.task.taskDetail.domain.TaskDetail; | |
15 | +import com.huaheng.pc.task.taskDetail.service.TaskDetailService; | |
11 | 16 | import com.huaheng.pc.task.taskHeader.domain.TaskHeader; |
12 | 17 | import org.springframework.beans.factory.annotation.Autowired; |
13 | 18 | import org.springframework.stereotype.Service; |
14 | 19 | import org.springframework.transaction.annotation.Transactional; |
15 | 20 | |
21 | +import java.util.ArrayList; | |
22 | +import java.util.List; | |
23 | + | |
16 | 24 | /** |
17 | 25 | * 任务下发接口ServiceImpl层 |
18 | 26 | * @author ricard |
... | ... | @@ -25,6 +33,8 @@ public class TaskAssignServiceImpl implements TaskAssignService { |
25 | 33 | |
26 | 34 | @Autowired |
27 | 35 | private AddressService addressService; |
36 | + @Autowired | |
37 | + private TaskDetailService taskDetailService; | |
28 | 38 | |
29 | 39 | |
30 | 40 | public static String platform = "wms"; |
... | ... | @@ -57,9 +67,7 @@ public class TaskAssignServiceImpl implements TaskAssignService { |
57 | 67 | if(StringUtils.isEmpty(taskHeader.getContainerCode())){ |
58 | 68 | throw new ServiceException("wms任务中容器为空"); |
59 | 69 | } |
60 | -// if(StringUtils.isEmpty(taskHeader.getStation())){ | |
61 | -// throw new ServiceException("wms站台为空"); | |
62 | -// } | |
70 | + | |
63 | 71 | |
64 | 72 | //入库性质的任务源库位不能为空 |
65 | 73 | if(taskHeader.getTaskType()==100 || taskHeader.getTaskType()==200 |
... | ... | @@ -83,16 +91,40 @@ public class TaskAssignServiceImpl implements TaskAssignService { |
83 | 91 | WcsTask wcsTask = new WcsTask(); |
84 | 92 | wcsTask.setTaskNo(taskHeader.getId().toString()); |
85 | 93 | wcsTask.setTaskType(taskHeader.getTaskType().toString()); |
86 | -// wcsTask.setStation(taskHeader.getStation); | |
87 | - wcsTask.setPalletNo(taskHeader.getContainerCode()); | |
94 | + wcsTask.setFromPort("0"); | |
95 | + wcsTask.setToPort("0"); | |
96 | + wcsTask.setContainerCode(taskHeader.getContainerCode()); | |
88 | 97 | wcsTask.setFromLocationCode(taskHeader.getFromLocation()); |
89 | 98 | wcsTask.setToLocationCode(taskHeader.getToLocation()); |
99 | + wcsTask.setPriority(100); | |
100 | + wcsTask.setRemark("0"); | |
90 | 101 | wcsTask.setPlatform(platform); |
91 | 102 | |
103 | + //找到任务明细 | |
104 | + LambdaQueryWrapper<TaskDetail> taskDetailLam = Wrappers.lambdaQuery(); | |
105 | + taskDetailLam.eq(TaskDetail::getTaskId,taskHeader.getId()); | |
106 | + List<TaskDetail> taskDetailList = taskDetailService.list(taskDetailLam); | |
107 | + if(taskDetailList == null){ | |
108 | + throw new ServiceException("没有子任务"); | |
109 | + } | |
110 | + List<TaskDetails> taskDetails =new ArrayList<>(); | |
111 | + for(TaskDetail item : taskDetailList){ | |
112 | + TaskDetails details = new TaskDetails(); | |
113 | + details.setMaterialCode(item.getMaterialCode()); | |
114 | + details.setMaterialName(item.getMaterialName()); | |
115 | + details.setUnit(item.getMaterialUnit()); | |
116 | + details.setQty(item.getQty()); | |
117 | + details.setReferLineNo(item.getId().toString()); | |
118 | + taskDetails.add(details); | |
119 | + } | |
120 | + | |
121 | + wcsTask.setTaskDetails(taskDetails); | |
122 | + | |
92 | 123 | //4、发送数据 |
93 | 124 | String param="wcs"; |
94 | 125 | String url=addressService.selectAddress(param)+"TaskAssign"; |
95 | 126 | String JsonParam = JSON.toJSONString(wcsTask); |
127 | + System.out.println(JsonParam); | |
96 | 128 | String result = HttpUtils.bodypost(url, JsonParam); |
97 | 129 | if(StringUtils.isEmpty(result)){ |
98 | 130 | throw new ServiceException("接口地址错误"); |
... | ... |
src/main/java/com/huaheng/api/wcs/service/taskCancel/TaskCancelService.java
src/main/java/com/huaheng/api/wcs/service/taskCancel/TaskCancelServiceImpl.java
... | ... | @@ -26,20 +26,17 @@ public class TaskCancelServiceImpl implements TaskCancelService { |
26 | 26 | * @return |
27 | 27 | */ |
28 | 28 | @Override |
29 | - public AjaxResult TaskCance(Integer id, String reason) { | |
29 | + public AjaxResult TaskCance(Integer id) { | |
30 | 30 | |
31 | 31 | //1、判断参数是否为空 |
32 | 32 | if(id == null){ |
33 | 33 | throw new ServiceException("任务号为空"); |
34 | 34 | } |
35 | - if(StringUtils.isEmpty(reason)){ | |
36 | - throw new ServiceException("取消原因"); | |
37 | - } | |
35 | + | |
38 | 36 | |
39 | 37 | //2、转换实体 |
40 | 38 | WcsTask wcsTask = new WcsTask(); |
41 | 39 | wcsTask.setTaskNo(id.toString()); |
42 | - wcsTask.setReason(reason); | |
43 | 40 | |
44 | 41 | //3、发送数据 |
45 | 42 | String param="wcs"; |
... | ... |
src/main/java/com/huaheng/api/wcs/service/taskFinish/TaskFinishService.java
1 | 1 | package com.huaheng.api.wcs.service.taskFinish; |
2 | 2 | |
3 | -import com.huaheng.api.wcs.domain.WcsTask; | |
3 | +import com.huaheng.api.wcs.domain.TaskFinishDomain; | |
4 | 4 | import com.huaheng.framework.web.domain.AjaxResult; |
5 | 5 | |
6 | 6 | public interface TaskFinishService { |
7 | 7 | |
8 | 8 | //任务完成 |
9 | - AjaxResult completeTaskByWCS(WcsTask wcsTask); | |
9 | + AjaxResult completeTaskByWCS(TaskFinishDomain taskFinishDomain); | |
10 | 10 | } |
... | ... |
src/main/java/com/huaheng/api/wcs/service/taskFinish/TaskFinishServiceImpl.java
1 | 1 | package com.huaheng.api.wcs.service.taskFinish; |
2 | 2 | |
3 | -import com.huaheng.api.wcs.domain.WcsTask; | |
3 | +import com.huaheng.api.wcs.domain.TaskFinishDomain; | |
4 | 4 | import com.huaheng.common.support.Convert; |
5 | 5 | import com.huaheng.common.utils.StringUtils; |
6 | 6 | import com.huaheng.framework.web.domain.AjaxResult; |
... | ... | @@ -16,13 +16,13 @@ public class TaskFinishServiceImpl implements TaskFinishService { |
16 | 16 | |
17 | 17 | //任务完成 |
18 | 18 | @Override |
19 | - public AjaxResult completeTaskByWCS(WcsTask wcsTask) { | |
19 | + public AjaxResult completeTaskByWCS(TaskFinishDomain taskFinishDomain) { | |
20 | 20 | AjaxResult ajaxResult=new AjaxResult(); |
21 | - if(StringUtils.isEmpty(wcsTask.getTaskNo())){ | |
21 | + if(StringUtils.isEmpty(taskFinishDomain.getTaskNo())){ | |
22 | 22 | return AjaxResult.error("任务号为空"); |
23 | 23 | } |
24 | 24 | try{ |
25 | - ajaxResult=taskHeaderService.completeTaskByWMS(Convert.toIntArray(wcsTask.getTaskNo())); | |
25 | + ajaxResult=taskHeaderService.completeTaskByWMS(Convert.toIntArray(taskFinishDomain.getTaskNo())); | |
26 | 26 | } catch (Exception e) { |
27 | 27 | e.printStackTrace(); |
28 | 28 | } |
... | ... |
src/main/java/com/huaheng/api/wcs/service/warecellAllocation/WarecellAllocationServiceImpl.java
1 | 1 | package com.huaheng.api.wcs.service.warecellAllocation; |
2 | 2 | |
3 | +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | |
4 | +import com.baomidou.mybatisplus.core.toolkit.Wrappers; | |
3 | 5 | import com.huaheng.api.wcs.domain.WcsTask; |
6 | +import com.huaheng.common.exception.service.ServiceException; | |
4 | 7 | import com.huaheng.common.utils.StringUtils; |
8 | +import com.huaheng.common.utils.security.ShiroUtils; | |
9 | +import com.huaheng.framework.config.FilterConfig; | |
5 | 10 | import com.huaheng.framework.web.domain.AjaxResult; |
11 | +import com.huaheng.pc.config.FilterConfigDetail.domain.FilterConfigDetail; | |
12 | +import com.huaheng.pc.config.FilterConfigDetail.service.FilterConfigDetailService; | |
13 | +import com.huaheng.pc.config.configValue.domain.ConfigValue; | |
14 | +import com.huaheng.pc.config.configValue.service.ConfigValueService; | |
15 | +import com.huaheng.pc.config.location.domain.Location; | |
16 | +import com.huaheng.pc.config.location.service.LocationService; | |
17 | +import com.huaheng.pc.config.locationType.domain.LocationType; | |
18 | +import com.huaheng.pc.config.locationType.service.LocationTypeService; | |
19 | +import com.huaheng.pc.config.material.domain.Material; | |
20 | +import com.huaheng.pc.config.material.service.MaterialService; | |
21 | +import com.huaheng.pc.config.material.service.MaterialServiceImpl; | |
22 | +import com.huaheng.pc.config.materialType.domain.MaterialType; | |
23 | +import com.huaheng.pc.config.materialType.service.MaterialTypeService; | |
24 | +import com.huaheng.pc.config.receiptPreference.domain.ReceiptPreference; | |
25 | +import com.huaheng.pc.config.receiptPreference.service.ReceiptPreferenceService; | |
26 | +import com.huaheng.pc.receipt.receiptContainerDetail.domain.ReceiptContainerDetail; | |
27 | +import com.huaheng.pc.receipt.receiptContainerDetail.service.ReceiptContainerDetailService; | |
28 | +import com.huaheng.pc.receipt.receiptContainerHeader.domain.ReceiptContainerHeader; | |
29 | +import com.huaheng.pc.receipt.receiptContainerHeader.service.ReceiptContainerHeaderService; | |
30 | +import com.huaheng.pc.receipt.receiptDetail.domain.ReceiptDetail; | |
31 | +import com.huaheng.pc.receipt.receiptDetail.service.ReceiptDetailService; | |
32 | +import com.huaheng.pc.system.config.domain.Config; | |
33 | +import com.huaheng.pc.task.taskDetail.domain.TaskDetail; | |
34 | +import com.huaheng.pc.task.taskDetail.service.TaskDetailService; | |
35 | +import com.huaheng.pc.task.taskHeader.domain.TaskHeader; | |
36 | +import com.huaheng.pc.task.taskHeader.service.TaskHeaderService; | |
37 | +import com.jhlabs.image.LightFilter; | |
38 | +import io.swagger.annotations.ResponseHeader; | |
6 | 39 | import org.springframework.stereotype.Service; |
7 | 40 | |
41 | +import javax.annotation.Resource; | |
42 | +import java.util.ArrayList; | |
43 | +import java.util.List; | |
44 | +import java.util.stream.Collectors; | |
45 | + | |
8 | 46 | @Service |
9 | 47 | public class WarecellAllocationServiceImpl implements WarecellAllocationService { |
10 | 48 | |
49 | + @Resource | |
50 | + private LocationTypeService locationTypeService; | |
51 | + @Resource | |
52 | + private LocationService locationService; | |
53 | + @Resource | |
54 | + private ConfigValueService configValueService; | |
55 | + @Resource | |
56 | + private ReceiptPreferenceService receiptPreferenceService; | |
57 | + @Resource | |
58 | + private FilterConfigDetailService filterConfigDetailService; | |
59 | + @Resource | |
60 | + private TaskDetailService taskDetailService; | |
61 | + @Resource | |
62 | + private TaskHeaderService taskHeaderService; | |
63 | + @Resource | |
64 | + private ReceiptContainerDetailService receiptContainerDetailService; | |
65 | + @Resource | |
66 | + private ReceiptContainerHeaderService receiptContainerHeaderService; | |
67 | + @Resource | |
68 | + private ReceiptDetailService receiptDetailService; | |
69 | + @Resource | |
70 | + private MaterialService materialService; | |
71 | + @Resource | |
72 | + private MaterialTypeService materialTypeService; | |
73 | + | |
11 | 74 | /** |
12 | 75 | * 仓位分配 |
13 | 76 | * 1、判断非空字段 |
14 | 77 | * 2、实体转换 |
15 | - * | |
78 | + * 3、查询满足条件的库位类型 | |
16 | 79 | * @param wcsTask |
17 | 80 | * @return |
18 | 81 | */ |
... | ... | @@ -23,11 +86,8 @@ public class WarecellAllocationServiceImpl implements WarecellAllocationService |
23 | 86 | if(StringUtils.isEmpty(wcsTask.getTaskNo())){ |
24 | 87 | return AjaxResult.error("任务号为空"); |
25 | 88 | } |
26 | - if(StringUtils.isEmpty(wcsTask.getPalletNo())){ | |
27 | - return AjaxResult.error("托盘编号为空"); | |
28 | - } | |
29 | - if(StringUtils.isEmpty(wcsTask.getStation())){ | |
30 | - return AjaxResult.error("站台编码为空"); | |
89 | + if(StringUtils.isEmpty(wcsTask.getRoadWay())){ | |
90 | + return AjaxResult.error("巷道为空"); | |
31 | 91 | } |
32 | 92 | if(StringUtils.isNull(wcsTask.getLength())){ |
33 | 93 | return AjaxResult.error("长为空"); |
... | ... | @@ -42,7 +102,144 @@ public class WarecellAllocationServiceImpl implements WarecellAllocationService |
42 | 102 | return AjaxResult.error("重为空"); |
43 | 103 | } |
44 | 104 | |
105 | + //查询满足条件的库位类型 | |
106 | + LambdaQueryWrapper<LocationType> lambdaQueryWrapper = Wrappers.lambdaQuery(); | |
107 | + lambdaQueryWrapper.gt(LocationType::getLength,wcsTask.getLength()) | |
108 | + .gt(LocationType::getWidth, wcsTask.getWidth()) | |
109 | + .gt(LocationType::getHeight, wcsTask.getHeight()) | |
110 | + .gt(LocationType::getMaxWeight, wcsTask.getWidth()); | |
111 | + List<LocationType> locationTypeList = locationTypeService.list(lambdaQueryWrapper); | |
112 | + List<String> codeList = new ArrayList<>(); | |
113 | + for (LocationType locationType: locationTypeList) { | |
114 | + codeList.add(locationType.getCode()); | |
115 | + } | |
116 | + | |
117 | + String locationCode = null; | |
118 | + //查询任务明细 | |
119 | + LambdaQueryWrapper<TaskDetail> taskDetailLambda = Wrappers.lambdaQuery(); | |
120 | + taskDetailLambda.eq(TaskDetail::getTaskId, wcsTask.getTaskNo()); | |
121 | + List<TaskDetail> taskDetailList = taskDetailService.list(taskDetailLambda); | |
122 | + | |
123 | + List<ReceiptContainerDetail> receiptContainerDetailList = new ArrayList<>(); | |
124 | + for (TaskDetail taskDetail : taskDetailList) { | |
125 | + receiptContainerDetailList.add(receiptContainerDetailService.getById(taskDetail.getAllocationId())); | |
126 | + } | |
127 | + //去重 | |
128 | + receiptContainerDetailList = receiptContainerDetailList.stream().distinct().collect(Collectors.toList()); | |
129 | + | |
130 | + for (ReceiptContainerDetail receiptContainerDetail : receiptContainerDetailList) { | |
131 | + ReceiptContainerHeader receiptContainerHeader = receiptContainerHeaderService.getById(receiptContainerDetail.getReceiptContainerId()); | |
132 | + String locatingRule = receiptContainerHeader.getLocatingRule(); //定位规则 | |
133 | + if (StringUtils.isEmpty(locatingRule)){ | |
134 | + locatingRule = receiptDetailService.getById(receiptContainerDetail.getReceiptDetailId()).getLocatingRule(); | |
135 | + //入库单明细定位规则不为空时执行 | |
136 | + if (StringUtils.isEmpty(locatingRule)){ | |
137 | + //入库单明细为空时,查询物料表中是否含有定位规则 | |
138 | + LambdaQueryWrapper<Material> materialLambda = Wrappers.lambdaQuery(); | |
139 | + materialLambda.eq(Material::getCode, receiptContainerDetail.getMaterialCode()); | |
140 | + Material material = materialService.getOne(materialLambda); | |
141 | + locatingRule = material.getLocatingRule(); | |
142 | + | |
143 | + if (StringUtils.isEmpty(locatingRule)){ | |
144 | + //物料表中定位规则为空时,查询物料类别 | |
145 | + LambdaQueryWrapper<MaterialType> materialTypeLambda = Wrappers.lambdaQuery(); | |
146 | + materialTypeLambda.eq(MaterialType::getCode, material.getType()); | |
147 | + MaterialType materialType = materialTypeService.getOne(materialTypeLambda); | |
148 | + locatingRule = materialType.getLocatingRule(); | |
149 | + if (StringUtils.isEmpty(locatingRule)){ | |
150 | + //物料类别中定位规则为空时,查询入库首选项 | |
151 | + LambdaQueryWrapper<ConfigValue> configValueLambda = Wrappers.lambdaQuery(); | |
152 | + configValueLambda.eq(ConfigValue::getWarehouseCode, ShiroUtils.getWarehouseCode()) | |
153 | + .eq(ConfigValue::getModuleType, "receipt") | |
154 | + .eq(ConfigValue::getRecordType, "入库首选项"); | |
155 | + ConfigValue configValue = configValueService.getOne(configValueLambda); | |
156 | + LambdaQueryWrapper<ReceiptPreference> receiptPreferenceLambda = Wrappers.lambdaQuery(); | |
157 | + receiptPreferenceLambda.eq(ReceiptPreference::getCode, configValue.getValue()); | |
158 | + ReceiptPreference receiptPreference = receiptPreferenceService.getOne(receiptPreferenceLambda); | |
159 | + locatingRule = receiptPreferenceService.getOne(receiptPreferenceLambda).getLocationRule(); | |
160 | + } | |
161 | + } | |
162 | + } | |
163 | + | |
164 | + } | |
165 | + //通过定位规则查找自定义sql | |
166 | + if (StringUtils.isEmpty(locatingRule)){ | |
167 | + throw new ServiceException("未绑定定位规则"); | |
168 | + } | |
169 | + | |
170 | + LambdaQueryWrapper<FilterConfigDetail> filterConfigDetailLambda = Wrappers.lambdaQuery(); | |
171 | + filterConfigDetailLambda.eq(FilterConfigDetail::getCode, locatingRule); | |
172 | + FilterConfigDetail filterConfigDetail = filterConfigDetailService.getOne(filterConfigDetailLambda); | |
173 | + | |
174 | + String[] locatingRules = filterConfigDetail.getStatement().split("limit"); | |
175 | + | |
176 | + //根据定位规则查询库位编码 | |
177 | + LambdaQueryWrapper<Location> locationLambda = Wrappers.lambdaQuery(); | |
178 | + locationLambda.last(locatingRules[0]); | |
179 | + List<Location> locationList = locationService.list(locationLambda); | |
180 | +// locationList.stream().filter(location -> location.getLocationType().equals(locationTypeList.get(0))); | |
181 | + locationCode = filter(locationList, locationTypeList); | |
182 | + if (StringUtils.isEmpty(locationCode)){ | |
183 | + throw new ServiceException("没有库位可分配"); | |
184 | + } | |
185 | + | |
186 | + if (StringUtils.isNotEmpty(locationCode)){ | |
187 | + locationService.updateStatus(locationCode, "lock"); | |
188 | + } else { | |
189 | + throw new ServiceException("定位失败,请检查定位规则是否正确"); | |
190 | + } | |
45 | 191 | |
192 | + //更新库位编码到组盘头表 | |
193 | + receiptContainerHeader.setToLocation(locationCode); | |
194 | + if (!receiptContainerHeaderService.updateById(receiptContainerHeader)){ | |
195 | + throw new ServiceException("更新库位失败"); | |
196 | + } | |
197 | + | |
198 | + //把库位编码赋到该入库组盘头表下的所有明细 | |
199 | + LambdaQueryWrapper<ReceiptContainerDetail> lambda = Wrappers.lambdaQuery(); | |
200 | + lambda.eq(ReceiptContainerDetail::getReceiptContainerId, receiptContainerHeader.getId()); | |
201 | + List<ReceiptContainerDetail> receiptContainerDetails = receiptContainerDetailService.list(lambda); | |
202 | + for (ReceiptContainerDetail receiptContainerDetail2: receiptContainerDetails) { | |
203 | + receiptContainerDetail2.setLocationCode(locationCode); | |
204 | + if (!receiptContainerDetailService.updateById(receiptContainerDetail2)){throw new ServiceException("更新库位编码到入库组盘明细");} | |
205 | + } | |
206 | + | |
207 | + } | |
208 | + if (StringUtils.isNotEmpty(locationCode)){ | |
209 | + //修改任务明细目标库位 | |
210 | + for (TaskDetail taskDetail : taskDetailList) { | |
211 | + taskDetail.setToLocation(locationCode); | |
212 | + if (!taskDetailService.updateById(taskDetail)){ throw new ServiceException("更新任务明细目标库位失败");} | |
213 | + } | |
214 | + | |
215 | + TaskHeader taskHeader = taskHeaderService.getById(wcsTask.getTaskNo()); | |
216 | + | |
217 | + taskHeader.setToLocation(locationCode); | |
218 | + if (!taskHeaderService.updateById(taskHeader)){throw new ServiceException("更新任务头表目标库位失败");} | |
219 | + WcsTask wcsTaskResult = new WcsTask(); | |
220 | + wcsTaskResult.setToLocationCode(locationCode); | |
221 | + return AjaxResult.success(wcsTaskResult); | |
222 | + } | |
223 | + | |
224 | + return AjaxResult.error("错误"); | |
225 | + } | |
226 | + | |
227 | + /** | |
228 | + * 库位筛选 | |
229 | + * @param locationList | |
230 | + * @param locationTypeList | |
231 | + * @return | |
232 | + */ | |
233 | + public String filter(List<Location> locationList, List<LocationType> locationTypeList){ | |
234 | + String locationCode = null; | |
235 | + for (Location location: locationList){ | |
236 | + for (LocationType locationType: locationTypeList) { | |
237 | + if (location.getLocationType().equals(locationType.getCode())){ | |
238 | + locationCode = location.getCode(); | |
239 | + return locationCode; | |
240 | + } | |
241 | + } | |
242 | + } | |
46 | 243 | return null; |
47 | 244 | } |
48 | 245 | } |
... | ... |
src/main/java/com/huaheng/pc/config/station/controller/stationController.java
0 → 100644
1 | +package com.huaheng.pc.config.station.controller; | |
2 | + | |
3 | +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | |
4 | +import com.baomidou.mybatisplus.core.metadata.IPage; | |
5 | +import com.baomidou.mybatisplus.core.toolkit.Wrappers; | |
6 | +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | |
7 | +import com.huaheng.common.support.Convert; | |
8 | +import com.huaheng.common.utils.StringUtils; | |
9 | +import com.huaheng.common.utils.security.ShiroUtils; | |
10 | +import com.huaheng.framework.aspectj.lang.annotation.Log; | |
11 | +import com.huaheng.framework.aspectj.lang.constant.BusinessType; | |
12 | +import com.huaheng.framework.web.controller.BaseController; | |
13 | +import com.huaheng.framework.web.domain.AjaxResult; | |
14 | +import com.huaheng.framework.web.page.PageDomain; | |
15 | +import com.huaheng.framework.web.page.TableDataInfo; | |
16 | +import com.huaheng.framework.web.page.TableSupport; | |
17 | +import com.huaheng.pc.config.station.domain.Station; | |
18 | +import com.huaheng.pc.config.station.service.StationService; | |
19 | +import io.swagger.annotations.ApiParam; | |
20 | +import org.apache.shiro.authz.annotation.RequiresPermissions; | |
21 | +import org.springframework.stereotype.Controller; | |
22 | +import org.springframework.ui.ModelMap; | |
23 | +import org.springframework.web.bind.annotation.*; | |
24 | + | |
25 | +import javax.annotation.Resource; | |
26 | +import java.util.ArrayList; | |
27 | +import java.util.Arrays; | |
28 | +import java.util.List; | |
29 | + | |
30 | +/** | |
31 | + * Created by Enzo Cotter on 2019/10/14. | |
32 | + */ | |
33 | +@Controller | |
34 | +@RequestMapping("/config/station") | |
35 | +public class stationController extends BaseController { | |
36 | + | |
37 | + @Resource | |
38 | + private StationService stationService; | |
39 | + | |
40 | + private String prefix = "config/station"; | |
41 | + | |
42 | + @RequiresPermissions("config:station:view") | |
43 | + @GetMapping() | |
44 | + public String station() { | |
45 | + return prefix + "/station"; | |
46 | + } | |
47 | + | |
48 | + /** | |
49 | + * 查询出库类型 | |
50 | + */ | |
51 | + @RequiresPermissions("config:station:list") | |
52 | + @Log(title = "配置-站台",operating = "站台列表", action = BusinessType.GRANT) | |
53 | + @PostMapping("/list") | |
54 | + @ResponseBody | |
55 | + public TableDataInfo list(@ApiParam(name="shipmentType",value="编码、类型") Station station, | |
56 | + @ApiParam(name = "createdBegin", value = "起止时间") String createdBegin, | |
57 | + @ApiParam(name = "createdEnd", value = "结束时间") String createdEnd) { | |
58 | + LambdaQueryWrapper<Station> lambdaQueryWrapper = Wrappers.lambdaQuery(); | |
59 | + PageDomain pageDomain = TableSupport.buildPageRequest(); | |
60 | + Integer pageNum = pageDomain.getPageNum(); | |
61 | + Integer pageSize = pageDomain.getPageSize(); | |
62 | + lambdaQueryWrapper.gt(StringUtils.isNotEmpty(createdBegin), Station::getCreated, createdBegin) | |
63 | + .lt(StringUtils.isNotEmpty(createdEnd), Station::getCreated, createdEnd) | |
64 | + .eq(StringUtils.isNotEmpty(station.getCode()), Station::getCode, station.getCode()) | |
65 | + .eq(StringUtils.isNotEmpty(station.getType()), Station::getType, station.getType()) | |
66 | + .eq(Station::getWarehouseCode, ShiroUtils.getWarehouseCode()); | |
67 | + | |
68 | + if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){ | |
69 | + /*使用分页查询*/ | |
70 | + Page<Station> page = new Page<>(pageNum, pageSize); | |
71 | + IPage<Station> iPage = stationService.page(page, lambdaQueryWrapper); | |
72 | + return getMpDataTable(iPage.getRecords(), iPage.getTotal()); | |
73 | + } else { | |
74 | + List<Station> list = stationService.list(lambdaQueryWrapper); | |
75 | + return getDataTable(list); | |
76 | + } | |
77 | + } | |
78 | + | |
79 | + /** | |
80 | + * 新增站台 | |
81 | + */ | |
82 | + @GetMapping("/add") | |
83 | + public String add() { | |
84 | + return prefix + "/add"; | |
85 | + } | |
86 | + | |
87 | + /** | |
88 | + * 新增保存站台 | |
89 | + */ | |
90 | + @RequiresPermissions("config:station:add") | |
91 | + @Log(title = "配置-站台",operating = "新增站台", action = BusinessType.INSERT) | |
92 | + @PostMapping("/add") | |
93 | + @ResponseBody | |
94 | + public AjaxResult addSave(Station station) { | |
95 | + station.setWarehouseCode(ShiroUtils.getWarehouseCode()); | |
96 | + return toAjax(stationService.save(station)); | |
97 | + } | |
98 | + | |
99 | + /** | |
100 | + * 修改站台 | |
101 | + */ | |
102 | + @GetMapping("/edit/{id}") | |
103 | + public String edit(@PathVariable("id") Integer id, ModelMap mmap) { | |
104 | + Station station = stationService.getById(id); | |
105 | + mmap.put("station", station); | |
106 | + return prefix + "/edit"; | |
107 | + } | |
108 | + | |
109 | + /** | |
110 | + * 修改保存站台 | |
111 | + */ | |
112 | + @RequiresPermissions("config:station:edit") | |
113 | + @Log(title = "配置-站台",operating = "修改站台", action = BusinessType.UPDATE) | |
114 | + @PostMapping("/edit") | |
115 | + @ResponseBody | |
116 | + public AjaxResult editSave(Station station) { | |
117 | + station.setLastUpdatedBy(ShiroUtils.getLoginName()); | |
118 | + return toAjax(stationService.updateById(station)); | |
119 | + } | |
120 | + | |
121 | + /** | |
122 | + * 删除出库 | |
123 | + */ | |
124 | + @RequiresPermissions("config:station:remove") | |
125 | + @Log(title = "配置-站台",operating = "删除站台", action = BusinessType.DELETE) | |
126 | + @PostMapping( "/remove") | |
127 | + @ResponseBody | |
128 | + public AjaxResult remove(String ids) { | |
129 | + if (StringUtils.isEmpty(ids)) { | |
130 | + return AjaxResult.error("id不能为空"); | |
131 | + } | |
132 | + List<Integer> list = new ArrayList<>(Arrays.asList(Convert.toIntArray(ids))); | |
133 | + return toAjax(stationService.removeByIds(list)); | |
134 | + } | |
135 | + | |
136 | +} | |
... | ... |
src/main/java/com/huaheng/pc/config/station/domain/Station.java
... | ... | @@ -30,6 +30,13 @@ public class Station implements Serializable { |
30 | 30 | private String code; |
31 | 31 | |
32 | 32 | /** |
33 | + * 类型 | |
34 | + */ | |
35 | + @TableField(value = "type") | |
36 | + @ApiModelProperty(value="类型") | |
37 | + private String type; | |
38 | + | |
39 | + /** | |
33 | 40 | * 状态 |
34 | 41 | */ |
35 | 42 | @TableField(value = "status") |
... | ... |
src/main/java/com/huaheng/pc/receipt/receiptContainerHeader/domain/ReceiptContainerHeader.java
... | ... | @@ -6,11 +6,14 @@ import com.baomidou.mybatisplus.annotation.TableId; |
6 | 6 | import com.baomidou.mybatisplus.annotation.TableName; |
7 | 7 | import io.swagger.annotations.ApiModel; |
8 | 8 | import io.swagger.annotations.ApiModelProperty; |
9 | +import lombok.Data; | |
10 | + | |
9 | 11 | import java.io.Serializable; |
10 | 12 | import java.util.Date; |
11 | 13 | |
12 | 14 | @ApiModel(value="com.huaheng.pc.receipt.receiptContainerHeader.domain.ReceiptContainerHeader") |
13 | 15 | @TableName(value = "receipt_container_header") |
16 | +@Data | |
14 | 17 | public class ReceiptContainerHeader implements Serializable { |
15 | 18 | /** |
16 | 19 | * ID |
... | ... | @@ -208,563 +211,13 @@ public class ReceiptContainerHeader implements Serializable { |
208 | 211 | @ApiModelProperty(value="状态") |
209 | 212 | private Short status; |
210 | 213 | |
211 | - private static final long serialVersionUID = 1L; | |
212 | - | |
213 | - public static final String COL_WAREHOUSECODE = "warehouseCode"; | |
214 | - | |
215 | - public static final String COL_COMPANYCODE = "companyCode"; | |
216 | - | |
217 | - public static final String COL_CONTAINERCODE = "containerCode"; | |
218 | - | |
219 | - public static final String COL_CONTAINERTYPE = "containerType"; | |
220 | - | |
221 | - public static final String COL_TASKTYPE = "taskType"; | |
222 | - | |
223 | - public static final String COL_WEIGHT = "weight"; | |
224 | - | |
225 | - public static final String COL_PROJECTNO = "projectNo"; | |
226 | - | |
227 | - public static final String COL_LOCATINGRULE = "locatingRule"; | |
228 | - | |
229 | - public static final String COL_FROMLOCATION = "fromLocation"; | |
230 | - | |
231 | - public static final String COL_TOLOCATION = "toLocation"; | |
232 | - | |
233 | - public static final String COL_WAVEID = "waveId"; | |
234 | - | |
235 | - public static final String COL_TASKCREATED = "taskCreated"; | |
236 | - | |
237 | - public static final String COL_CREATED = "created"; | |
238 | - | |
239 | - public static final String COL_CREATEDBY = "createdBy"; | |
240 | - | |
241 | - public static final String COL_LASTUPDATED = "lastUpdated"; | |
242 | - | |
243 | - public static final String COL_LASTUPDATEDBY = "lastUpdatedBy"; | |
244 | - | |
245 | - public static final String COL_VERSION = "version"; | |
246 | - | |
247 | - public static final String COL_USERDEF1 = "userDef1"; | |
248 | - | |
249 | - public static final String COL_USERDEF2 = "userDef2"; | |
250 | - | |
251 | - public static final String COL_USERDEF3 = "userDef3"; | |
252 | - | |
253 | - public static final String COL_USERDEF4 = "userDef4"; | |
254 | - | |
255 | - public static final String COL_USERDEF5 = "userDef5"; | |
256 | - | |
257 | - public static final String COL_USERDEF6 = "userDef6"; | |
258 | - | |
259 | - public static final String COL_USERDEF7 = "userDef7"; | |
260 | - | |
261 | - public static final String COL_USERDEF8 = "userDef8"; | |
262 | - | |
263 | - public static final String COL_PROCESSSTAMP = "processStamp"; | |
264 | - | |
265 | - public static final String COL_STATUS = "status"; | |
266 | - | |
267 | - /** | |
268 | - * 获取ID | |
269 | - * | |
270 | - * @return id - ID | |
271 | - */ | |
272 | - public Integer getId() { | |
273 | - return this.id; | |
274 | - } | |
275 | - | |
276 | - /** | |
277 | - * 设置ID | |
278 | - * | |
279 | - * @param id ID | |
280 | - */ | |
281 | - public void setId(Integer id) { | |
282 | - this.id = id; | |
283 | - } | |
284 | - | |
285 | - /** | |
286 | - * 获取仓库 | |
287 | - * | |
288 | - * @return warehouseCode - 仓库 | |
289 | - */ | |
290 | - public String getWarehouseCode() { | |
291 | - return warehouseCode; | |
292 | - } | |
293 | - | |
294 | - /** | |
295 | - * 设置仓库 | |
296 | - * | |
297 | - * @param warehouseCode 仓库 | |
298 | - */ | |
299 | - public void setWarehouseCode(String warehouseCode) { | |
300 | - this.warehouseCode = warehouseCode; | |
301 | - } | |
302 | - | |
303 | - /** | |
304 | - * 获取货主 | |
305 | - * | |
306 | - * @return companyCode - 货主 | |
307 | - */ | |
308 | - public String getCompanyCode() { | |
309 | - return companyCode; | |
310 | - } | |
311 | - | |
312 | - /** | |
313 | - * 设置货主 | |
314 | - * | |
315 | - * @param companyCode 货主 | |
316 | - */ | |
317 | - public void setCompanyCode(String companyCode) { | |
318 | - this.companyCode = companyCode; | |
319 | - } | |
320 | - | |
321 | - /** | |
322 | - * 获取容器号 | |
323 | - * | |
324 | - * @return containerCode - 容器号 | |
325 | - */ | |
326 | - public String getContainerCode() { | |
327 | - return containerCode; | |
328 | - } | |
329 | - | |
330 | - /** | |
331 | - * 设置容器号 | |
332 | - * | |
333 | - * @param containerCode 容器号 | |
334 | - */ | |
335 | - public void setContainerCode(String containerCode) { | |
336 | - this.containerCode = containerCode; | |
337 | - } | |
338 | - | |
339 | - /** | |
340 | - * 获取容器类型 | |
341 | - * | |
342 | - * @return containerType - 容器类型 | |
343 | - */ | |
344 | - public String getContainerType() { | |
345 | - return containerType; | |
346 | - } | |
347 | - | |
348 | - /** | |
349 | - * 设置容器类型 | |
350 | - * | |
351 | - * @param containerType 容器类型 | |
352 | - */ | |
353 | - public void setContainerType(String containerType) { | |
354 | - this.containerType = containerType; | |
355 | - } | |
356 | - | |
357 | - /** | |
358 | - * 获取任务类型 | |
359 | - * | |
360 | - * @return taskType - 任务类型 | |
361 | - */ | |
362 | - public String getTaskType() { | |
363 | - return taskType; | |
364 | - } | |
365 | - | |
366 | - /** | |
367 | - * 设置任务类型 | |
368 | - * | |
369 | - * @param taskType 任务类型 | |
370 | - */ | |
371 | - public void setTaskType(String taskType) { | |
372 | - this.taskType = taskType; | |
373 | - } | |
374 | - | |
375 | - /** | |
376 | - * 获取重量 | |
377 | - * | |
378 | - * @return weight - 重量 | |
379 | - */ | |
380 | - public String getWeight() { | |
381 | - return weight; | |
382 | - } | |
383 | - | |
384 | - /** | |
385 | - * 设置重量 | |
386 | - * | |
387 | - * @param weight 重量 | |
388 | - */ | |
389 | - public void setWeight(String weight) { | |
390 | - this.weight = weight; | |
391 | - } | |
392 | - | |
393 | - /** | |
394 | - * 获取项目号 | |
395 | - * | |
396 | - * @return projectNo - 项目号 | |
397 | - */ | |
398 | - public String getProjectNo() { | |
399 | - return projectNo; | |
400 | - } | |
401 | - | |
402 | - /** | |
403 | - * 设置项目号 | |
404 | - * | |
405 | - * @param projectNo 项目号 | |
406 | - */ | |
407 | - public void setProjectNo(String projectNo) { | |
408 | - this.projectNo = projectNo; | |
409 | - } | |
410 | - | |
411 | - /** | |
412 | - * 获取定位规则 | |
413 | - * | |
414 | - * @return locatingRule - 定位规则 | |
415 | - */ | |
416 | - public String getLocatingRule() { | |
417 | - return locatingRule; | |
418 | - } | |
419 | - | |
420 | - /** | |
421 | - * 设置定位规则 | |
422 | - * | |
423 | - * @param locatingRule 定位规则 | |
424 | - */ | |
425 | - public void setLocatingRule(String locatingRule) { | |
426 | - this.locatingRule = locatingRule; | |
427 | - } | |
428 | - | |
429 | - /** | |
430 | - * 获取从库位 | |
431 | - * | |
432 | - * @return fromLocation - 从库位 | |
433 | - */ | |
434 | - public String getFromLocation() { | |
435 | - return fromLocation; | |
436 | - } | |
437 | - | |
438 | - /** | |
439 | - * 设置从库位 | |
440 | - * | |
441 | - * @param fromLocation 从库位 | |
442 | - */ | |
443 | - public void setFromLocation(String fromLocation) { | |
444 | - this.fromLocation = fromLocation; | |
445 | - } | |
446 | - | |
447 | - /** | |
448 | - * 获取目标库位 | |
449 | - * | |
450 | - * @return toLocation - 目标库位 | |
451 | - */ | |
452 | - public String getToLocation() { | |
453 | - return toLocation; | |
454 | - } | |
455 | - | |
456 | - /** | |
457 | - * 设置目标库位 | |
458 | - * | |
459 | - * @param toLocation 目标库位 | |
460 | - */ | |
461 | - public void setToLocation(String toLocation) { | |
462 | - this.toLocation = toLocation; | |
463 | - } | |
464 | - | |
465 | - /** | |
466 | - * 获取波次号 | |
467 | - * | |
468 | - * @return waveId - 波次号 | |
469 | - */ | |
470 | - public Integer getWaveId() { | |
471 | - return waveId; | |
472 | - } | |
473 | - | |
474 | 214 | /** |
475 | - * 设置波次号 | |
476 | - * | |
477 | - * @param waveId 波次号 | |
215 | + * 站台 | |
478 | 216 | */ |
479 | - public void setWaveId(Integer waveId) { | |
480 | - this.waveId = waveId; | |
481 | - } | |
217 | + @TableField(value = "recvDock") | |
218 | + @ApiModelProperty(value="站台") | |
219 | + private String recvDock; | |
482 | 220 | |
483 | - /** | |
484 | - * 获取任务已创建 | |
485 | - * | |
486 | - * @return taskCreated - 任务已创建 | |
487 | - */ | |
488 | - public Integer getTaskCreated() { | |
489 | - return taskCreated; | |
490 | - } | |
491 | - | |
492 | - /** | |
493 | - * 设置任务已创建 | |
494 | - * | |
495 | - * @param taskCreated 任务已创建 | |
496 | - */ | |
497 | - public void setTaskCreated(Integer taskCreated) { | |
498 | - this.taskCreated = taskCreated; | |
499 | - } | |
500 | - | |
501 | - /** | |
502 | - * 获取创建时间 | |
503 | - * | |
504 | - * @return created - 创建时间 | |
505 | - */ | |
506 | - public Date getCreated() { | |
507 | - return created; | |
508 | - } | |
509 | - | |
510 | - /** | |
511 | - * 设置创建时间 | |
512 | - * | |
513 | - * @param created 创建时间 | |
514 | - */ | |
515 | - public void setCreated(Date created) { | |
516 | - this.created = created; | |
517 | - } | |
518 | - | |
519 | - /** | |
520 | - * 获取创建用户 | |
521 | - * | |
522 | - * @return createdBy - 创建用户 | |
523 | - */ | |
524 | - public String getCreatedBy() { | |
525 | - return createdBy; | |
526 | - } | |
527 | - | |
528 | - /** | |
529 | - * 设置创建用户 | |
530 | - * | |
531 | - * @param createdBy 创建用户 | |
532 | - */ | |
533 | - public void setCreatedBy(String createdBy) { | |
534 | - this.createdBy = createdBy; | |
535 | - } | |
536 | - | |
537 | - /** | |
538 | - * 获取创建时间 | |
539 | - * | |
540 | - * @return lastUpdated - 创建时间 | |
541 | - */ | |
542 | - public Date getLastUpdated() { | |
543 | - return lastUpdated; | |
544 | - } | |
545 | - | |
546 | - /** | |
547 | - * 设置创建时间 | |
548 | - * | |
549 | - * @param lastUpdated 创建时间 | |
550 | - */ | |
551 | - public void setLastUpdated(Date lastUpdated) { | |
552 | - this.lastUpdated = lastUpdated; | |
553 | - } | |
554 | - | |
555 | - /** | |
556 | - * 获取更新用户 | |
557 | - * | |
558 | - * @return lastUpdatedBy - 更新用户 | |
559 | - */ | |
560 | - public String getLastUpdatedBy() { | |
561 | - return lastUpdatedBy; | |
562 | - } | |
563 | - | |
564 | - /** | |
565 | - * 设置更新用户 | |
566 | - * | |
567 | - * @param lastUpdatedBy 更新用户 | |
568 | - */ | |
569 | - public void setLastUpdatedBy(String lastUpdatedBy) { | |
570 | - this.lastUpdatedBy = lastUpdatedBy; | |
571 | - } | |
572 | - | |
573 | - /** | |
574 | - * 获取数据版本 | |
575 | - * | |
576 | - * @return version - 数据版本 | |
577 | - */ | |
578 | - public Integer getVersion() { | |
579 | - return version; | |
580 | - } | |
581 | - | |
582 | - /** | |
583 | - * 设置数据版本 | |
584 | - * | |
585 | - * @param version 数据版本 | |
586 | - */ | |
587 | - public void setVersion(Integer version) { | |
588 | - this.version = version; | |
589 | - } | |
590 | - | |
591 | - /** | |
592 | - * 获取自定义字段1 | |
593 | - * | |
594 | - * @return userDef1 - 自定义字段1 | |
595 | - */ | |
596 | - public String getUserDef1() { | |
597 | - return userDef1; | |
598 | - } | |
599 | - | |
600 | - /** | |
601 | - * 设置自定义字段1 | |
602 | - * | |
603 | - * @param userDef1 自定义字段1 | |
604 | - */ | |
605 | - public void setUserDef1(String userDef1) { | |
606 | - this.userDef1 = userDef1; | |
607 | - } | |
608 | - | |
609 | - /** | |
610 | - * 获取自定义字段2 | |
611 | - * | |
612 | - * @return userDef2 - 自定义字段2 | |
613 | - */ | |
614 | - public String getUserDef2() { | |
615 | - return userDef2; | |
616 | - } | |
617 | - | |
618 | - /** | |
619 | - * 设置自定义字段2 | |
620 | - * | |
621 | - * @param userDef2 自定义字段2 | |
622 | - */ | |
623 | - public void setUserDef2(String userDef2) { | |
624 | - this.userDef2 = userDef2; | |
625 | - } | |
626 | - | |
627 | - /** | |
628 | - * 获取自定义字段3 | |
629 | - * | |
630 | - * @return userDef3 - 自定义字段3 | |
631 | - */ | |
632 | - public String getUserDef3() { | |
633 | - return userDef3; | |
634 | - } | |
635 | - | |
636 | - /** | |
637 | - * 设置自定义字段3 | |
638 | - * | |
639 | - * @param userDef3 自定义字段3 | |
640 | - */ | |
641 | - public void setUserDef3(String userDef3) { | |
642 | - this.userDef3 = userDef3; | |
643 | - } | |
644 | - | |
645 | - /** | |
646 | - * 获取自定义字段4 | |
647 | - * | |
648 | - * @return userDef4 - 自定义字段4 | |
649 | - */ | |
650 | - public String getUserDef4() { | |
651 | - return userDef4; | |
652 | - } | |
653 | - | |
654 | - /** | |
655 | - * 设置自定义字段4 | |
656 | - * | |
657 | - * @param userDef4 自定义字段4 | |
658 | - */ | |
659 | - public void setUserDef4(String userDef4) { | |
660 | - this.userDef4 = userDef4; | |
661 | - } | |
662 | - | |
663 | - /** | |
664 | - * 获取自定义字段5 | |
665 | - * | |
666 | - * @return userDef5 - 自定义字段5 | |
667 | - */ | |
668 | - public String getUserDef5() { | |
669 | - return userDef5; | |
670 | - } | |
671 | - | |
672 | - /** | |
673 | - * 设置自定义字段5 | |
674 | - * | |
675 | - * @param userDef5 自定义字段5 | |
676 | - */ | |
677 | - public void setUserDef5(String userDef5) { | |
678 | - this.userDef5 = userDef5; | |
679 | - } | |
680 | - | |
681 | - /** | |
682 | - * 获取自定义字段6 | |
683 | - * | |
684 | - * @return userDef6 - 自定义字段6 | |
685 | - */ | |
686 | - public String getUserDef6() { | |
687 | - return userDef6; | |
688 | - } | |
689 | - | |
690 | - /** | |
691 | - * 设置自定义字段6 | |
692 | - * | |
693 | - * @param userDef6 自定义字段6 | |
694 | - */ | |
695 | - public void setUserDef6(String userDef6) { | |
696 | - this.userDef6 = userDef6; | |
697 | - } | |
698 | - | |
699 | - /** | |
700 | - * 获取自定义字段7 | |
701 | - * | |
702 | - * @return userDef7 - 自定义字段7 | |
703 | - */ | |
704 | - public String getUserDef7() { | |
705 | - return userDef7; | |
706 | - } | |
707 | - | |
708 | - /** | |
709 | - * 设置自定义字段7 | |
710 | - * | |
711 | - * @param userDef7 自定义字段7 | |
712 | - */ | |
713 | - public void setUserDef7(String userDef7) { | |
714 | - this.userDef7 = userDef7; | |
715 | - } | |
716 | - | |
717 | - /** | |
718 | - * 获取自定义字段8 | |
719 | - * | |
720 | - * @return userDef8 - 自定义字段8 | |
721 | - */ | |
722 | - public String getUserDef8() { | |
723 | - return userDef8; | |
724 | - } | |
725 | - | |
726 | - /** | |
727 | - * 设置自定义字段8 | |
728 | - * | |
729 | - * @param userDef8 自定义字段8 | |
730 | - */ | |
731 | - public void setUserDef8(String userDef8) { | |
732 | - this.userDef8 = userDef8; | |
733 | - } | |
734 | - | |
735 | - /** | |
736 | - * 获取处理标记 | |
737 | - * | |
738 | - * @return processStamp - 处理标记 | |
739 | - */ | |
740 | - public String getProcessStamp() { | |
741 | - return processStamp; | |
742 | - } | |
743 | - | |
744 | - /** | |
745 | - * 设置处理标记 | |
746 | - * | |
747 | - * @param processStamp 处理标记 | |
748 | - */ | |
749 | - public void setProcessStamp(String processStamp) { | |
750 | - this.processStamp = processStamp; | |
751 | - } | |
752 | - | |
753 | - /** | |
754 | - * 获取状态 | |
755 | - * | |
756 | - * @return status - 状态 | |
757 | - */ | |
758 | - public Short getStatus() { | |
759 | - return status; | |
760 | - } | |
221 | + private static final long serialVersionUID = 1L; | |
761 | 222 | |
762 | - /** | |
763 | - * 设置状态 | |
764 | - * | |
765 | - * @param status 状态 | |
766 | - */ | |
767 | - public void setStatus(Short status) { | |
768 | - this.status = status; | |
769 | - } | |
770 | 223 | } |
771 | 224 | \ No newline at end of file |
... | ... |
src/main/java/com/huaheng/pc/receipt/receiptDetail/service/ReceiptDetailServiceImpl.java
... | ... | @@ -26,6 +26,7 @@ import com.huaheng.pc.receipt.receiptHeader.service.ReceiptHeaderService; |
26 | 26 | import com.huaheng.pc.system.config.domain.Config; |
27 | 27 | import com.huaheng.pc.system.dict.domain.DictData; |
28 | 28 | import com.huaheng.pc.system.dict.service.IDictDataService; |
29 | +import io.swagger.models.auth.In; | |
29 | 30 | import org.aspectj.weaver.loadtime.Aj; |
30 | 31 | import org.springframework.stereotype.Service; |
31 | 32 | import javax.annotation.Resource; |
... | ... | @@ -296,13 +297,18 @@ public class ReceiptDetailServiceImpl extends ServiceImpl<ReceiptDetailMapper, R |
296 | 297 | //查询出头表信息 |
297 | 298 | ReceiptHeader receiptHeader = receiptHeaderService.getById(id); |
298 | 299 | Integer minStatus = Integer.parseInt(receiptDetails.get(0).getProcessStamp()); |
300 | + Integer maxStatus = Integer.parseInt(receiptDetails.get(0).getProcessStamp()); | |
299 | 301 | //遍历明细状态得出最小状态值 |
300 | 302 | for (int i = 1; i<receiptDetails.size(); i++){ |
301 | - if ( minStatus > Integer.parseInt(receiptDetails.get(1).getProcessStamp())) { | |
302 | - minStatus = Integer.parseInt(receiptDetails.get(1).getProcessStamp()); | |
303 | + if ( minStatus > Integer.parseInt(receiptDetails.get(i).getProcessStamp())) { | |
304 | + minStatus = Integer.parseInt(receiptDetails.get(i).getProcessStamp()); | |
305 | + } | |
306 | + if ( maxStatus < Integer.parseInt(receiptDetails.get(i).getProcessStamp())) { | |
307 | + maxStatus = Integer.parseInt(receiptDetails.get(i).getProcessStamp()); | |
303 | 308 | } |
304 | 309 | } |
305 | 310 | |
311 | + | |
306 | 312 | //从数据字典中获取单据当前状态 |
307 | 313 | List<DictData> dictData = dictDataService.selectDictDataByType("receiptHeaderStatus"); |
308 | 314 | for (int i = 0; i<dictData.size(); i++){ |
... | ... | @@ -314,8 +320,8 @@ public class ReceiptDetailServiceImpl extends ServiceImpl<ReceiptDetailMapper, R |
314 | 320 | //若更新状态值小于头状态,更新尾状态否则更新头尾状态 |
315 | 321 | if (minStatus < receiptHeader.getFirstStatus()){ |
316 | 322 | receiptHeader.setLastStatus(minStatus); |
317 | - } else { | |
318 | - receiptHeader.setFirstStatus(minStatus); | |
323 | + } if (maxStatus > receiptHeader.getFirstStatus()){ | |
324 | + receiptHeader.setFirstStatus(maxStatus); | |
319 | 325 | receiptHeader.setLastStatus(minStatus); |
320 | 326 | receiptHeaderService.updateById(receiptHeader); |
321 | 327 | } |
... | ... |
src/main/java/com/huaheng/pc/receipt/receiving/service/ReceivingService.java
... | ... | @@ -90,9 +90,7 @@ public class ReceivingService { |
90 | 90 | //如果入库组盘表中有目标库位说明已经指定 |
91 | 91 | if (StringUtils.isNotEmpty(receiptContainerHeader.getToLocation())){return true;} |
92 | 92 | String locatingRule = receiptContainerHeader.getLocatingRule(); //定位规则 |
93 | - if (StringUtils.isNotEmpty(locatingRule)){ | |
94 | - //入库组盘头表中定位规则不为空时执行 | |
95 | - } else if (locatingRule == null){ | |
93 | + if (StringUtils.isEmpty(locatingRule)){ | |
96 | 94 | locatingRule = receiptDetailService.getById(receiptContainerDetail.getReceiptDetailId()).getLocatingRule(); |
97 | 95 | //入库单明细定位规则不为空时执行 |
98 | 96 | if (StringUtils.isEmpty(locatingRule)){ |
... | ... | @@ -147,6 +145,7 @@ public class ReceivingService { |
147 | 145 | |
148 | 146 | //更新库位编码到组盘头表 |
149 | 147 | receiptContainerHeader.setToLocation(locationCode); |
148 | + receiptContainerHeader.setRecvDock("0"); | |
150 | 149 | if (!receiptContainerHeaderService.updateById(receiptContainerHeader)){ |
151 | 150 | throw new ServiceException("更新库位失败"); |
152 | 151 | } |
... | ... |
src/main/java/com/huaheng/pc/task/taskHeader/domain/TaskHeader.java
... | ... | @@ -294,5 +294,12 @@ public class TaskHeader implements Serializable { |
294 | 294 | @ApiModelProperty(value="处理标记") |
295 | 295 | private String processStamp; |
296 | 296 | |
297 | + /** | |
298 | + * 站台 | |
299 | + */ | |
300 | + @TableField(value = "recvDock") | |
301 | + @ApiModelProperty(value="站台") | |
302 | + private String recvDock; | |
303 | + | |
297 | 304 | private static final long serialVersionUID = 1L; |
298 | 305 | } |
299 | 306 | \ No newline at end of file |
... | ... |
src/main/java/com/huaheng/pc/task/taskHeader/service/TaskHeaderServiceImpl.java
... | ... | @@ -407,8 +407,8 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea |
407 | 407 | // } |
408 | 408 | // } |
409 | 409 | |
410 | - //给wcs传递任务 | |
411 | -// taskAssignService.wcsTaskAssign(task); | |
410 | +// 给wcs传递任务 | |
411 | + taskAssignService.wcsTaskAssign(task); | |
412 | 412 | } |
413 | 413 | return AjaxResult.success("执行下发任务成功", task); |
414 | 414 | } |
... | ... | @@ -1141,6 +1141,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea |
1141 | 1141 | task.setFromLocation(receiptContainerHeader.getFromLocation()); |
1142 | 1142 | task.setToLocation(receiptContainerHeader.getToLocation()); |
1143 | 1143 | task.setContainerCode(receiptContainerHeader.getContainerCode()); |
1144 | + task.setRecvDock(receiptContainerHeader.getRecvDock()); | |
1144 | 1145 | task.setCreated(new Date()); |
1145 | 1146 | task.setCreatedBy(ShiroUtils.getLoginName()); |
1146 | 1147 | if (this.save(task)){ |
... | ... | @@ -1151,6 +1152,7 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea |
1151 | 1152 | taskDetail.setTaskType(Integer.valueOf(receiptContainerHeaderService.getById(item.getReceiptContainerId()).getTaskType())); |
1152 | 1153 | taskDetail.setInternalTaskType(100); |
1153 | 1154 | taskDetail.setWarehouseCode(task.getWarehouseCode()); |
1155 | + taskDetail.setAllocationId(item.getReceiptId()); | |
1154 | 1156 | taskDetail.setCompanyCode(task.getCompanyCode()); |
1155 | 1157 | taskDetail.setCompanyCode(task.getCompanyCode()); |
1156 | 1158 | taskDetail.setMaterialCode(item.getMaterialCode()); |
... | ... | @@ -1174,12 +1176,14 @@ public class TaskHeaderServiceImpl extends ServiceImpl<TaskHeaderMapper, TaskHea |
1174 | 1176 | } |
1175 | 1177 | |
1176 | 1178 | ReceiptDetail receiptDetail = receiptDetailService.getById(item.getReceiptDetailId()); |
1177 | - if ("300".equals(receiptDetail.getProcessStamp())){ | |
1178 | - ReceiptDetail detail = receiptDetailService.queryflow(receiptDetail); | |
1179 | - if (!receiptDetailService.updateById(detail)){ | |
1180 | - throw new ServiceException("更新入库单详情失败"); | |
1181 | - } | |
1179 | + | |
1180 | + ReceiptDetail detail = receiptDetailService.queryflow(receiptDetail); | |
1181 | + if (!receiptDetailService.updateById(detail)){ | |
1182 | + throw new ServiceException("更新入库单详情失败"); | |
1182 | 1183 | } |
1184 | + //更新头表状态 | |
1185 | + receiptDetailService.updateReceiptHeaderLastStatus(receiptDetail.getReceiptId()); | |
1186 | + | |
1183 | 1187 | } |
1184 | 1188 | } else { |
1185 | 1189 | throw new ServiceException("生成任务头表失败"); |
... | ... |
src/main/resources/mybatis/config/StationMapper.xml
... | ... | @@ -7,6 +7,7 @@ |
7 | 7 | <id column="id" jdbcType="INTEGER" property="id" /> |
8 | 8 | <result column="code" jdbcType="VARCHAR" property="code" /> |
9 | 9 | <result column="status" jdbcType="INTEGER" property="status" /> |
10 | + <result column="code" jdbcType="VARCHAR" property="code" /> | |
10 | 11 | <result column="warehouseCode" jdbcType="VARCHAR" property="warehouseCode" /> |
11 | 12 | <result column="created" jdbcType="TIMESTAMP" property="created" /> |
12 | 13 | <result column="createdBy" jdbcType="VARCHAR" property="createdBy" /> |
... | ... | @@ -15,6 +16,6 @@ |
15 | 16 | </resultMap> |
16 | 17 | <sql id="Base_Column_List"> |
17 | 18 | <!--@mbg.generated--> |
18 | - id, code, `status`, warehouseCode, created, createdBy, lastUpdated, lastUpdatedBy | |
19 | + id, code, `status`, type, warehouseCode, created, createdBy, lastUpdated, lastUpdatedBy | |
19 | 20 | </sql> |
20 | 21 | </mapper> |
21 | 22 | \ No newline at end of file |
... | ... |
src/main/resources/mybatis/receipt/ReceiptContainerHeaderMapper.xml
... | ... | @@ -31,12 +31,13 @@ |
31 | 31 | <result column="userDef8" jdbcType="VARCHAR" property="userDef8" /> |
32 | 32 | <result column="processStamp" jdbcType="VARCHAR" property="processStamp" /> |
33 | 33 | <result column="status" jdbcType="SMALLINT" property="status" /> |
34 | + <result column="recvDock" jdbcType="VARCHAR" property="recvDock" /> | |
34 | 35 | </resultMap> |
35 | 36 | <sql id="Base_Column_List"> |
36 | 37 | <!--@mbg.generated--> |
37 | 38 | id, warehouseCode, companyCode, containerCode, containerType, taskType, weight, projectNo, |
38 | 39 | locatingRule, fromLocation, toLocation, waveId, taskCreated, created, createdBy, |
39 | 40 | lastUpdated, lastUpdatedBy, version, userDef1, userDef2, userDef3, userDef4, userDef5, |
40 | - userDef6, userDef7, userDef8, processStamp, `status` | |
41 | + userDef6, userDef7, userDef8, processStamp, `status`, recvDock | |
41 | 42 | </sql> |
42 | 43 | </mapper> |
43 | 44 | \ No newline at end of file |
... | ... |
src/main/resources/mybatis/task/TaskHeaderMapper.xml
... | ... | @@ -41,6 +41,7 @@ |
41 | 41 | <result column="userDef2" jdbcType="VARCHAR" property="userDef2"/> |
42 | 42 | <result column="userDef3" jdbcType="VARCHAR" property="userDef3"/> |
43 | 43 | <result column="processStamp" jdbcType="VARCHAR" property="processStamp"/> |
44 | + <result column="recvDock" jdbcType="VARCHAR" property="recvDock" /> | |
44 | 45 | </resultMap> |
45 | 46 | <select id="getReceiptTask" resultType="java.util.Map"> |
46 | 47 | SELECT rd.id receiptDetailId,rd.receiptId,td.taskId, td.warehouseCode, td.id taskDetailId, td.status, |
... | ... |
src/main/resources/templates/config/configValue/add.html
... | ... | @@ -9,13 +9,17 @@ |
9 | 9 | <div class="form-group"> |
10 | 10 | <label class="col-sm-3 control-label">模块:</label> |
11 | 11 | <div class="col-sm-8"> |
12 | - <input id="moduleType" name="moduleType" class="form-control" type="text"> | |
12 | + <select id="moduleType" name="moduleType" class="form-control" th:with="moduleTypeList=${@dict.getType('moduleType')}"> | |
13 | + <option th:each="moduleType : ${moduleTypeList}" th:text="${moduleType['dictLabel']}" th:value="${moduleType['dictValue']}"></option> | |
14 | + </select> | |
13 | 15 | </div> |
14 | 16 | </div> |
15 | 17 | <div class="form-group"> |
16 | 18 | <label class="col-sm-3 control-label">类型:</label> |
17 | 19 | <div class="col-sm-8"> |
18 | - <input id="recordType" name="recordType" class="form-control" type="text"> | |
20 | + <select id="recordType" name="recordType" class="form-control" th:with="moduleTypeList=${@dict.getType('recordType')}"> | |
21 | + <option th:each="moduleType : ${moduleTypeList}" th:text="${moduleType['dictLabel']}" th:value="${moduleType['dictValue']}"></option> | |
22 | + </select> | |
19 | 23 | </div> |
20 | 24 | </div> |
21 | 25 | <div class="form-group"> |
... | ... |
src/main/resources/templates/config/configValue/edit.html
... | ... | @@ -9,13 +9,13 @@ |
9 | 9 | <div class="form-group"> |
10 | 10 | <label class="col-sm-3 control-label">模块:</label> |
11 | 11 | <div class="col-sm-8"> |
12 | - <input id="moduleType" name="moduleType" class="form-control" type="text" th:field="*{moduleType}"> | |
12 | + <input id="moduleType" name="moduleType" class="form-control" type="text" th:field="*{moduleType}" readonly> | |
13 | 13 | </div> |
14 | 14 | </div> |
15 | 15 | <div class="form-group"> |
16 | 16 | <label class="col-sm-3 control-label">类型:</label> |
17 | 17 | <div class="col-sm-8"> |
18 | - <input id="recordType" name="recordType" class="form-control" type="text" th:field="*{recordType}"> | |
18 | + <input id="recordType" name="recordType" class="form-control" type="text" th:field="*{recordType}" readonly> | |
19 | 19 | </div> |
20 | 20 | </div> |
21 | 21 | <div class="form-group"> |
... | ... |
src/main/resources/templates/config/receiptPreference/edit.html
... | ... | @@ -21,7 +21,7 @@ |
21 | 21 | <div class="form-group"> |
22 | 22 | <label class="col-sm-3 control-label">入库流程:</label> |
23 | 23 | <div class="col-sm-8"> |
24 | - <select id="receivingFlow" name="receivingFlow" class="form-control" th:with="statusFlowList=${@StatusFlow.flowList('入库单')}" th:field="*{receivingFlow}"> | |
24 | + <select id="receivingFlow" name="receivingFlow" class="form-control" th:with="statusFlowList=${@StatusFlow.flowList('receivingFlow')}" th:field="*{receivingFlow}"> | |
25 | 25 | <option th:each="flow : ${statusFlowList}" th:text="${flow['name']}" th:value="${flow['code']}"></option> |
26 | 26 | </select> |
27 | 27 | </div> |
... | ... |
src/main/resources/templates/config/station/add.html
0 → 100644
1 | +<!DOCTYPE HTML> | |
2 | +<html lang="zh" xmlns:th="http://www.thymeleaf.org"> | |
3 | +<meta charset="utf-8"> | |
4 | +<head th:include="include :: header"></head> | |
5 | +<body class="white-bg"> | |
6 | +<div class="wrapper wrapper-content animated fadeInRight ibox-content"> | |
7 | + <form class="form-horizontal m" id="form-station-add"> | |
8 | + <div class="form-group"> | |
9 | + <label class="col-sm-3 control-label">编码:</label> | |
10 | + <div class="col-sm-8"> | |
11 | + <input id="code" name="code" class="form-control" type="text"> | |
12 | + </div> | |
13 | + </div> | |
14 | + <div class="form-group"> | |
15 | + <label class="col-sm-3 control-label">类型:</label> | |
16 | + <div class="col-sm-8"> | |
17 | + <input id="type" name="type" class="form-control" type="text" > | |
18 | + </div> | |
19 | + </div> | |
20 | + <div class="form-group"> | |
21 | + <label class="col-sm-3 control-label">状态:</label> | |
22 | + <div class="col-sm-8"> | |
23 | + <input id="status" name="status" class="form-control" type="text" > | |
24 | + </div> | |
25 | + </div> | |
26 | + <div class="form-group"> | |
27 | + <div class="form-control-static col-sm-offset-9"> | |
28 | + <button type="submit" class="btn btn-primary">提交</button> | |
29 | + <button onclick="$.modal.close()" class="btn btn-danger" type="button">关闭</button> | |
30 | + </div> | |
31 | + </div> | |
32 | + </form> | |
33 | +</div> | |
34 | +<div th:include="include::footer"></div> | |
35 | +<script type="text/javascript"> | |
36 | + var prefix = ctx + "config/station" | |
37 | + $("#form-station-add").validate({ | |
38 | + rules:{ | |
39 | + code:{ | |
40 | + required:true | |
41 | + }, | |
42 | + type:{ | |
43 | + required: true | |
44 | + } | |
45 | + }, | |
46 | + submitHandler: function(form) { | |
47 | + // $.operate.save(prefix + "/add", $('#form-supplier-add').serialize()); | |
48 | + var tableValue = $.common.getTableValue("#form-station-add"); | |
49 | + $.operate.save(prefix + "/add", tableValue); | |
50 | + } | |
51 | + }); | |
52 | +</script> | |
53 | +</body> | |
54 | +</html> | |
... | ... |
src/main/resources/templates/config/station/edit.html
0 → 100644
1 | +<!DOCTYPE HTML> | |
2 | +<html lang="zh" xmlns:th="http://www.thymeleaf.org"> | |
3 | +<meta charset="utf-8"> | |
4 | +<head th:include="include :: header"></head> | |
5 | +<body class="white-bg"> | |
6 | +<div class="wrapper wrapper-content animated fadeInRight ibox-content"> | |
7 | + <form class="form-horizontal m" id="form-station-add" th:object="${station}"> | |
8 | + <div class="form-group"> | |
9 | + <label class="col-sm-3 control-label">编码:</label> | |
10 | + <div class="col-sm-8"> | |
11 | + <input id="code" name="code" class="form-control" type="text" th:field="*{code}"> | |
12 | + </div> | |
13 | + </div> | |
14 | + <div class="form-group"> | |
15 | + <label class="col-sm-3 control-label">类型:</label> | |
16 | + <div class="col-sm-8"> | |
17 | + <input id="type" name="type" class="form-control" type="text" th:field="*{type}"> | |
18 | + </div> | |
19 | + </div> | |
20 | + <div class="form-group"> | |
21 | + <label class="col-sm-3 control-label">状态:</label> | |
22 | + <div class="col-sm-8"> | |
23 | + <input id="status" name="status" class="form-control" type="text" th:field="*{status}"> | |
24 | + </div> | |
25 | + </div> | |
26 | + <div class="form-group"> | |
27 | + <div class="form-control-static col-sm-offset-9"> | |
28 | + <button type="submit" class="btn btn-primary">提交</button> | |
29 | + <button onclick="$.modal.close()" class="btn btn-danger" type="button">关闭</button> | |
30 | + </div> | |
31 | + </div> | |
32 | + </form> | |
33 | +</div> | |
34 | +<div th:include="include::footer"></div> | |
35 | +<script type="text/javascript"> | |
36 | + var prefix = ctx + "config/station" | |
37 | + $("#form-station-add").validate({ | |
38 | + rules:{ | |
39 | + code:{ | |
40 | + required:true | |
41 | + }, | |
42 | + type:{ | |
43 | + required: true | |
44 | + } | |
45 | + }, | |
46 | + submitHandler: function(form) { | |
47 | + // $.operate.save(prefix + "/add", $('#form-supplier-add').serialize()); | |
48 | + var tableValue = $.common.getTableValue("#form-station-add"); | |
49 | + $.operate.save(prefix + "/edit", tableValue); | |
50 | + } | |
51 | + }); | |
52 | +</script> | |
53 | +</body> | |
54 | +</html> | |
... | ... |
src/main/resources/templates/config/station/station.html
0 → 100644
1 | +<!DOCTYPE HTML> | |
2 | +<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro"> | |
3 | +<meta charset="utf-8"> | |
4 | +<head th:include="include :: header"></head> | |
5 | +<body class="gray-bg"> | |
6 | +<div class="container-div"> | |
7 | + <div class="row"> | |
8 | + <div class="col-sm-12 select-info"> | |
9 | + <form id="supplier-form"> | |
10 | + <div class="select-list"> | |
11 | + <ul> | |
12 | + <li> | |
13 | + 编码:<input type="text" name="code"/> | |
14 | + </li> | |
15 | + <li class="time"> | |
16 | + <label>创建时间: </label> | |
17 | + <input type="text" class="time-input" id="startTime" placeholder="开始时间" name="params[createdBegin]"/> | |
18 | + <span>-</span> | |
19 | + <input type="text" class="time-input" id="endTime" placeholder="结束时间" name="params[createdEnd]"/> | |
20 | + </li> | |
21 | + <li> | |
22 | + <a class="btn btn-primary btn-rounded btn-sm" onclick="$.table.search()"><i class="fa fa-search"></i> 搜索</a> | |
23 | + <a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset('supplier-form')"><i class="fa fa-refresh"></i> 重置</a> | |
24 | + <!--<a class="btn btn-success btn-rounded btn-sm" onclick="$.table.exportExcel()" shiro:hasPermission="config:supplier:export"><i class="fa fa-download"></i> 导出</a>--> | |
25 | + </li> | |
26 | + </ul> | |
27 | + </div> | |
28 | + </form> | |
29 | + </div> | |
30 | + | |
31 | + <div class="btn-group hidden-xs" id="toolbar" role="group"> | |
32 | + <a class="btn btn-outline btn-success btn-rounded" onclick="$.operate.add()" shiro:hasPermission="config:station:add"> | |
33 | + <i class="fa fa-plus"></i> 新增 | |
34 | + </a> | |
35 | + <a class="btn btn-outline btn-danger btn-rounded" onclick="$.operate.batRemove()" shiro:hasPermission="config:station:remove"> | |
36 | + <i class="fa fa-trash-o"></i> 删除 | |
37 | + </a> | |
38 | + </div> | |
39 | + | |
40 | + <div class="col-sm-12 select-info"> | |
41 | + <table id="bootstrap-table" data-mobile-responsive="true" class="table table-bordered table-hover"></table> | |
42 | + </div> | |
43 | + </div> | |
44 | +</div> | |
45 | +<div th:include="include :: footer"></div> | |
46 | +<script th:inline="javascript"> | |
47 | + var editFlag = [[${@permission.hasPermi('config:station:edit')}]]; | |
48 | + var removeFlag = [[${@permission.hasPermi('config:station:remove')}]]; | |
49 | + var prefix = ctx + "config/station" | |
50 | + var datas = [[${@dict.getType('sys_normal_disable')}]]; | |
51 | + $(function() { | |
52 | + var options = { | |
53 | + url: prefix + "/list", | |
54 | + createUrl: prefix + "/add", | |
55 | + updateUrl: prefix + "/edit/{id}", | |
56 | + removeUrl: prefix + "/remove", | |
57 | + modalName: "站台", | |
58 | + search: false, | |
59 | + sortName: "id", | |
60 | + sortOrder: "desc", | |
61 | + columns: [{ | |
62 | + checkbox: true | |
63 | + }, | |
64 | + { | |
65 | + field : 'id', | |
66 | + title : 'id' | |
67 | + }, | |
68 | + { | |
69 | + field : 'warehouseCode', | |
70 | + title : '仓库' | |
71 | + }, | |
72 | + { | |
73 | + field : 'code', | |
74 | + title : '编码' | |
75 | + }, | |
76 | + { | |
77 | + field : 'type', | |
78 | + title : '类型' | |
79 | + }, | |
80 | + { | |
81 | + field : 'status', | |
82 | + title : '状态' | |
83 | + }, | |
84 | + { | |
85 | + field : 'created', | |
86 | + title : '创建时间' | |
87 | + }, | |
88 | + { | |
89 | + field : 'createdBy', | |
90 | + title : '创建用户' | |
91 | + }, | |
92 | + { | |
93 | + field : 'lastUpdated', | |
94 | + title : '更新时间' | |
95 | + }, | |
96 | + { | |
97 | + field : 'lastUpdatedBy', | |
98 | + title : '更新用户' | |
99 | + }, | |
100 | + { | |
101 | + title: '操作', | |
102 | + align: 'center', | |
103 | + formatter: function(value, row, index) { | |
104 | + var actions = []; | |
105 | + actions.push('<a class="btn btn-success btn-xs ' + editFlag + '" href="#" onclick="$.operate.edit(\'' + row.id + '\')"><i class="fa fa-edit"></i>编辑</a> '); | |
106 | + actions.push('<a class="btn btn-danger btn-xs ' + removeFlag + '" href="#" onclick="$.operate.remove(\'' + row.id + '\')" ><i class="fa fa-trash-o"></i>删除</a>'); | |
107 | + return actions.join(''); | |
108 | + } | |
109 | + }] | |
110 | + }; | |
111 | + $.table.init(options); | |
112 | + }); | |
113 | +</script> | |
114 | +</body> | |
115 | +</html> | |
0 | 116 | \ No newline at end of file |
... | ... |
src/main/resources/templates/task/taskHeader/taskHeader.html
... | ... | @@ -188,6 +188,11 @@ |
188 | 188 | title : '容器号' , |
189 | 189 | sortable: true |
190 | 190 | }, |
191 | + { | |
192 | + field : 'exceptionCode', | |
193 | + title : '异常原因', | |
194 | + sortable: true | |
195 | + }, | |
191 | 196 | |
192 | 197 | { |
193 | 198 | field : 'startPickDateTime', |
... | ... | @@ -218,7 +223,8 @@ |
218 | 223 | }, |
219 | 224 | { |
220 | 225 | field : 'userDef1', |
221 | - title : '处理' , | |
226 | + title : '自定义字段1' , | |
227 | + visible:false | |
222 | 228 | }, |
223 | 229 | { |
224 | 230 | field : 'userDef2', |
... | ... |