huhai
authored
|
1
|
package com.huaheng.pc.config.container.controller;
|
|
2
3
4
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
5
|
import com.huaheng.common.utils.Wrappers;
|
|
6
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
7
|
import com.huaheng.common.constant.QuantityConstant;
|
|
8
9
|
import com.huaheng.common.support.Convert;
import com.huaheng.common.utils.StringUtils;
|
|
10
|
import com.huaheng.common.utils.poi.ExcelUtil;
|
|
11
12
13
14
15
16
17
18
|
import com.huaheng.common.utils.security.ShiroUtils;
import com.huaheng.framework.aspectj.lang.annotation.Log;
import com.huaheng.framework.aspectj.lang.constant.BusinessType;
import com.huaheng.framework.web.controller.BaseController;
import com.huaheng.framework.web.domain.AjaxResult;
import com.huaheng.framework.web.page.PageDomain;
import com.huaheng.framework.web.page.TableDataInfo;
import com.huaheng.framework.web.page.TableSupport;
|
|
19
|
import com.huaheng.pc.common.JasperPrint.Print;
|
|
20
21
|
import com.huaheng.pc.config.container.domain.Container;
import com.huaheng.pc.config.container.service.ContainerService;
|
|
22
23
|
import com.huaheng.pc.config.location.domain.Location;
import com.huaheng.pc.config.location.service.LocationService;
|
|
24
25
26
27
28
29
30
|
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.*;
|
|
31
|
import org.springframework.web.multipart.MultipartFile;
|
|
32
33
|
import javax.annotation.Resource;
|
|
34
|
import javax.sql.DataSource;
|
|
35
36
37
38
|
import java.util.List;
@Api(tags={"容器操作类"})
@Controller
|
|
39
|
@RequestMapping("/config/container")
|
|
40
41
|
public class ContainerController extends BaseController {
|
|
42
|
private String prefix = "config/container";
|
|
43
44
45
|
@Resource
private ContainerService containerService;
|
|
46
47
48
49
50
51
|
@Resource
private LocationService locationService;
@Resource
private DataSource dataSource;
@Resource
private Print print;
|
|
52
|
@RequiresPermissions("config:container:view")
|
|
53
54
55
56
57
58
59
60
61
62
63
|
@GetMapping()
public String container() {
return prefix + "/container";
}
/**
* 查询库位列表
*/
@ApiOperation(value="查看容器列表",
notes="根据容器编号、库位编码、容器状态、容器类型、创建时间获取库位的详细信息",
httpMethod = "POST")
|
|
64
|
@RequiresPermissions("config:container:list")
|
huhai
authored
|
65
|
@Log(title = "配置-库存资料-库位管理", operating = "查看库位列表", action = BusinessType.GRANT)
|
|
66
67
68
69
70
71
|
@PostMapping("/list")
@ResponseBody
public TableDataInfo list(
@ApiParam(name="location",value="容器编号、库位编码、容器状态、容器类型") Container container,
@ApiParam(name = "createdBegin", value = "起止时间") String createdBegin,
@ApiParam(name = "createdEnd", value = "结束时间") String createdEnd) {
|
|
72
|
LambdaQueryWrapper<Container> lambdaQueryWrapper = Wrappers.lambdaQueryNoWarehouse();
|
|
73
74
75
76
77
|
PageDomain pageDomain = TableSupport.buildPageRequest();
Integer pageNum = pageDomain.getPageNum();
Integer pageSize = pageDomain.getPageSize();
lambdaQueryWrapper.gt(StringUtils.isNotEmpty(createdBegin), Container::getCreated, createdBegin)
.lt(StringUtils.isNotEmpty(createdEnd), Container::getCreated, createdEnd)
|
huhai
authored
|
78
|
.like(StringUtils.isNotNull(container.getCode()) && StringUtils.isNotEmpty(container.getCode()), Container::getCode, container.getCode())
|
|
79
80
|
.eq(StringUtils.isNotEmpty(container.getStatus()), Container::getStatus, container.getStatus())
.eq(StringUtils.isNotEmpty(container.getContainerType()), Container::getContainerType, container.getContainerType())
|
|
81
|
.eq(StringUtils.isNotEmpty(container.getCompanyCode()), Container::getCompanyCode, container.getCompanyCode())
|
|
82
|
.eq(StringUtils.isNotEmpty(ShiroUtils.getWarehouseCode()), Container::getWarehouseCode, ShiroUtils.getWarehouseCode())
|
huhai
authored
|
83
|
.like(StringUtils.isNotNull(container.getLocationCode())&&StringUtils.isNotEmpty(container.getLocationCode()), Container::getLocationCode, container.getLocationCode())
|
|
84
85
|
.eq(Container::getEnable,true)
.orderByDesc(Container::getId);
|
|
86
87
88
89
90
|
if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){
/*使用分页查询*/
Page<Container> page = new Page<>(pageNum, pageSize);
IPage<Container> iPage = containerService.page(page, lambdaQueryWrapper);
|
|
91
|
return getMpDataTable(iPage.getRecords(), iPage.getTotal());
|
|
92
93
94
95
96
97
|
} else {
List<Container> list = containerService.list(lambdaQueryWrapper);
return getDataTable(list);
}
}
|
|
98
99
|
@PostMapping("/emptyContainer")
@ResponseBody
|
|
100
|
public TableDataInfo emptyContainer(String containerType) {
|
|
101
102
103
104
105
|
LambdaQueryWrapper<Container> lambdaQueryWrapper = Wrappers.lambdaQuery();
PageDomain pageDomain = TableSupport.buildPageRequest();
Integer pageNum = pageDomain.getPageNum();
Integer pageSize = pageDomain.getPageSize();
lambdaQueryWrapper
|
|
106
|
.eq(Container::getStatus, QuantityConstant.STATUS_CONTAINER_EMPTY)
|
|
107
|
.isNotNull(Container::getLocationCode)
|
|
108
|
.eq(StringUtils.isNotEmpty(containerType),Container::getContainerType,containerType)
|
|
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
.ne(Container::getLocationCode, "")
.eq(Container::getWarehouseCode, ShiroUtils.getWarehouseCode())
.eq(Container::getEnable,true)
.orderByDesc(Container::getId);
if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){
/*使用分页查询*/
Page<Container> page = new Page<>(pageNum, pageSize);
IPage<Container> iPage = containerService.page(page, lambdaQueryWrapper);
return getMpDataTable(iPage.getRecords(), iPage.getTotal());
} else {
List<Container> list = containerService.list(lambdaQueryWrapper);
return getDataTable(list);
}
}
|
|
125
126
127
128
129
130
131
132
133
134
135
136
|
/**
* 新增容器
*/
@GetMapping("/add")
public String add() {
return prefix + "/add";
}
/**
* 新增保存容器
*/
@ApiOperation(value="新增容器", notes="根据容器类型、数量批量新增容器", httpMethod = "POST")
|
|
137
|
@RequiresPermissions("config:container:add")
|
huhai
authored
|
138
|
@Log(title = "配置-库存资料-容器", operating = "新增容器", action = BusinessType.INSERT)
|
|
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
|
@PostMapping("/add")
@ResponseBody
public AjaxResult addSave(
@ApiParam(name = "containerType", value = "容器类型", required = true)String containerType,
@ApiParam(name = "quantity", value = "数量", required = true)Integer quantity) {
AjaxResult result = containerService.insertContainer(containerType, quantity);
result.setData(null);
return result;
}
/**
* 修改容器
*/
@GetMapping("/edit/{id}")
public String edit(@PathVariable("id") Integer id, ModelMap mmap) {
Container container = containerService.getById(id);
mmap.put("container", container);
return prefix + "/edit";
}
/**
* 修改保存容器
*/
@ApiOperation(value="修改容器", notes="修改容器", httpMethod = "POST")
|
|
163
|
@RequiresPermissions("config:container:edit")
|
huhai
authored
|
164
|
@Log(title = "配置-库存资料-容器", operating = "修改容器", action = BusinessType.UPDATE)
|
|
165
166
167
|
@PostMapping("/edit")
@ResponseBody
public AjaxResult editSave(
|
|
168
169
170
171
172
173
174
175
176
177
|
@ApiParam(name = "Container", value = "容器实体", required = true) Container container) {
String locationCode = container.getLocationCode();
if (StringUtils.isNotEmpty(locationCode)) {
Location location = locationService.getLocationByCode(locationCode);
if (location == null) {
return AjaxResult.error("库位编码输入错误");
}
}
boolean success = containerService.updateById(container);
return toAjax(success);
|
|
178
179
180
181
182
183
|
}
/**
* 删除容器
*/
@ApiOperation(value="删除容器", notes="根据id批量删除容器,参数示例1,2,3", httpMethod = "POST")
|
|
184
|
@RequiresPermissions("config:container:remove")
|
huhai
authored
|
185
|
@Log(title = "配置-库存资料-容器", operating = "删除容器", action = BusinessType.DELETE)
|
|
186
187
188
189
190
191
192
193
194
|
@PostMapping( "/remove")
@ResponseBody
public AjaxResult remove(String ids) {
if (StringUtils.isEmpty(ids)){
return AjaxResult.error("id不能为空");
}
for (Integer id : Convert.toIntArray(ids)) {
Container container = containerService.getById(id);
|
|
195
196
|
if (QuantityConstant.STATUS_CONTAINER_EMPTY.equals(container.getStatus())
&& StringUtils.isEmpty(container.getLocationCode())) {
|
|
197
|
container.setEnable(false);
|
|
198
199
200
201
202
203
204
205
|
container.setLastUpdatedBy(ShiroUtils.getLoginName());
containerService.updateById(container);
} else {
return AjaxResult.error("容器(" + container.getCode() + ")不是空,或者已在货架上,不能删除成功!");
}
}
return AjaxResult.success("删除成功!");
}
|
|
206
207
208
209
|
@PostMapping("/importData")
@ResponseBody
public AjaxResult importData(MultipartFile file) throws Exception {
|
|
210
211
|
ExcelUtil<Container> util = new ExcelUtil<>(Container.class);
List<Container> containerList = util.importExcel(file.getInputStream());
|
|
212
213
|
String operName = ShiroUtils.getLoginName();
Boolean updateSupport = false;
|
huhai
authored
|
214
|
String message = containerService.importContainer(containerList, updateSupport, operName);
|
|
215
216
217
218
219
220
|
return AjaxResult.success(message);
}
@GetMapping("/importTemplate")
@ResponseBody
public AjaxResult importTemplate() {
|
|
221
|
ExcelUtil<Container> util = new ExcelUtil<>(Container.class);
|
|
222
223
|
return util.importTemplateExcel("容器");
}
|
|
224
225
|
|
huhai
authored
|
226
|
@RequiresPermissions("config:container:print")
|
huhai
authored
|
227
|
@Log(title = "配置-库存资料-容器条码", operating = "容器条码打印", action = BusinessType.OTHER)
|
|
228
|
@GetMapping("/print/{ids}")
|
|
229
|
public void print (@PathVariable("ids") Integer[] ids, ModelMap mmap) // arg1:物料id arg2:会话对象不需要直接返回
|
|
230
|
{
|
|
231
|
print.jasperPrint(ids, prefix);// 不用返回json打印
|
|
232
|
}
|
|
233
|
|
|
234
|
}
|