|
1
|
package com.huaheng.pc.config.material.controller;
|
|
2
3
4
5
6
7
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.huaheng.common.utils.StringUtils;
|
|
8
|
import com.huaheng.common.utils.poi.ExcelUtil;
|
|
9
10
11
12
13
14
15
16
|
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;
|
|
17
18
|
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.material.service.MaterialService;
|
|
19
20
21
22
23
24
25
|
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.*;
|
|
26
|
import org.springframework.web.multipart.MultipartFile;
|
|
27
28
29
30
31
32
|
import javax.annotation.Resource;
import java.util.List;
@Api(tags={"物料控制类"})
@Controller
|
|
33
|
@RequestMapping("/config/material")
|
|
34
35
|
public class MaterialController extends BaseController {
|
|
36
|
private String prefix = "config/material";
|
|
37
|
|
|
38
|
@Resource
|
|
39
40
|
private MaterialService materialService;
|
|
41
|
@RequiresPermissions("config:material:view")
|
|
42
43
44
45
46
47
48
49
50
51
52
|
@GetMapping()
public String material() {
return prefix + "/material";
}
/**
* 查询物料列表
*/
@ApiOperation(value="查看物料列表",
notes="根据物料编码、名称、规格、物料类别、创建时间获取物料的详细信息",
httpMethod = "POST")
|
|
53
|
@RequiresPermissions("config:material:list")
|
|
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
@Log(title = "通用-物料管理", operating = "查看物料列表", action = BusinessType.GRANT)
@PostMapping("/list")
@ResponseBody
public TableDataInfo list(
@ApiParam(name="location",value="物料编码、名称、规格、物料类别") Material material,
@ApiParam(name = "createdBegin", value = "起止时间") String createdBegin,
@ApiParam(name = "createdEnd", value = "结束时间") String createdEnd) {
PageDomain pageDomain = TableSupport.buildPageRequest();
Integer pageNum = pageDomain.getPageNum();
Integer pageSize = pageDomain.getPageSize();
LambdaQueryWrapper<Material> lambda = Wrappers.lambdaQuery();
lambda.gt(StringUtils.isNotEmpty(createdBegin), Material::getCreated, createdBegin)
.lt(StringUtils.isNotEmpty(createdEnd), Material::getCreated, createdEnd)
.eq(StringUtils.isNotEmpty(material.getCode()), Material::getCode, material.getCode())
.eq(StringUtils.isNotEmpty(material.getName()), Material::getName, material.getName())
.eq(StringUtils.isNotEmpty(material.getType()), Material::getType, material.getType())
.like(StringUtils.isNotEmpty(material.getSpec()), Material::getSpec, material.getSpec())
.eq(Material::getWarehouseCode, ShiroUtils.getWarehouseCode())
.in(Material::getCompanyCode, ShiroUtils.getCompanyCodeList())
|
|
74
|
.eq(Material::getDeleted, false);
|
|
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){
/*使用分页查询*/
Page<Material> page = new Page<>(pageNum, pageSize);
IPage<Material> iPage = materialService.page(page, lambda);
return getMpDataTable(iPage.getRecords(), iPage.getTotal());
} else {
List<Material> list = materialService.list(lambda);
return getDataTable(list);
}
}
/**
* 新增物料
*/
@GetMapping("/add")
public String add() {
return prefix + "/add";
}
/**
* 新增保存物料
*/
@ApiOperation(value="新增物料", notes="新增物料", httpMethod = "POST")
|
|
99
|
@RequiresPermissions("config:material:add")
|
|
100
101
102
103
104
|
@Log(title = "通用-物料管理", operating = "新增物料", action = BusinessType.INSERT)
@PostMapping("/add")
@ResponseBody
public AjaxResult addSave(Material material) {
|
|
105
|
return materialService.addSave(material);
|
|
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
}
/**
* 修改物料
*/
@GetMapping("/edit/{id}")
public String edit(@PathVariable("id") Integer id, ModelMap mmap) {
Material material = materialService.getById(id);
mmap.put("material", material);
return prefix + "/edit";
}
/**
* 修改保存物料
*/
@ApiOperation(value="修改物料", notes="修改物料", httpMethod = "POST")
|
|
122
|
@RequiresPermissions("config:material:edit")
|
|
123
124
125
126
127
128
129
130
131
132
133
|
@Log(title = "通用-物料管理", operating = "修改物料", action = BusinessType.UPDATE)
@PostMapping("/edit")
@ResponseBody
public AjaxResult editSave(Material material) {
material.setLastUpdatedBy(ShiroUtils.getLoginName());
return toAjax(materialService.updateById(material));
}
/**
* 删除物料
*/
|
|
134
|
@RequiresPermissions("config:material:remove")
|
|
135
136
137
138
139
140
141
142
143
144
145
|
@Log(title = "通用-物料管理", operating = "删除物料", action = BusinessType.DELETE)
@PostMapping( "/remove")
@ResponseBody
public AjaxResult remove(String ids) {
if (StringUtils.isEmpty(ids)){
return AjaxResult.error("id不能为空");
} else {
return materialService.removeByIds(ids);
}
}
|
|
146
|
|
|
147
148
149
150
151
152
|
@PostMapping("/importData")
@ResponseBody
public AjaxResult importData(MultipartFile file) throws Exception {
ExcelUtil<Material> util = new ExcelUtil<>(Material.class);
List<Material> materialList = util.importExcel(file.getInputStream());
String operName = ShiroUtils.getLoginName();
|
|
153
|
String message = materialService.importMaterial(materialList, false, operName);
|
|
154
155
156
|
return AjaxResult.success(message);
}
|
|
157
158
159
160
161
|
/**
* 导出模板
* @return
* @throws Exception
*/
|
|
162
163
164
165
166
167
168
|
@GetMapping("/importTemplate")
@ResponseBody
public AjaxResult importTemplate() {
ExcelUtil<Material> util = new ExcelUtil<>(Material.class);
return util.importTemplateExcel("物料");
}
|
|
169
|
}
|