Blame view

src/main/java/com/huaheng/pc/config/points/controller/PointController.java 8.48 KB
pengcheng authored
1
2
3
4
5
package com.huaheng.pc.config.points.controller;


import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
周鸿 authored
6
import com.huaheng.common.utils.Wrappers;
pengcheng authored
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.huaheng.common.utils.StringUtils;
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;
import com.huaheng.pc.config.company.domain.Company;
import com.huaheng.pc.config.company.service.CompanyService;
import com.huaheng.pc.config.container.domain.Container;
import com.huaheng.pc.config.container.service.ContainerService;
import com.huaheng.pc.config.points.domain.Points;
import com.huaheng.pc.config.points.service.PointsService;
xumiao authored
23
24
import com.huaheng.pc.config.warehouse.domain.WarehouseU8;
import com.huaheng.pc.config.warehouse.service.WarehouseU8Service;
25
26
import com.huaheng.pc.inventory.inventoryDetail.domain.InventoryDetail;
import com.huaheng.pc.inventory.inventoryDetail.service.InventoryDetailService;
27
import io.swagger.annotations.ApiOperation;
pengcheng authored
28
29
30
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
xumiao authored
31
import org.springframework.transaction.annotation.Transactional;
pengcheng authored
32
33
34
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.*;
xumiao authored
35
import javax.annotation.Resource;
pengcheng authored
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import java.util.List;

/**
 * 货架 信息操作处理
 * 
 * @author huaheng
 * @date 2019-07-11
 */
@Controller
@RequestMapping("/config/point")
public class PointController extends BaseController
{
    private String prefix = "config/point";

	@Autowired
	private PointsService pointsService;
	@Autowired
	private CompanyService companyService;
	@Autowired
	private ContainerService containerService;
56
57
	@Autowired
	private InventoryDetailService inventoryDetailService;
xumiao authored
58
59
	@Resource
	private WarehouseU8Service warehouseU8Service;
pengcheng authored
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90

	@RequiresPermissions("config:point:view")
	@GetMapping()
	public String point()
	{
	    return prefix + "/point";
	}

	/**
	 * 查询货架列表
	 */
	@RequiresPermissions("config:point:list")
	@Log(title = "配置-货架设置", operating = "货架查看列表", action = BusinessType.GRANT)
	@PostMapping("/list")
	@ResponseBody
	public TableDataInfo list(Points points)
	{

		LambdaQueryWrapper<Points> lambdaQueryWrapper = Wrappers.lambdaQuery();
		PageDomain pageDomain = TableSupport.buildPageRequest();
		Integer pageNum = pageDomain.getPageNum();
		Integer pageSize = pageDomain.getPageSize();
		lambdaQueryWrapper
				.eq(StringUtils.isNotEmpty(points.getGoodsShelfNo()), Points::getGoodsShelfNo, points.getGoodsShelfNo())
				.eq(StringUtils.isNotEmpty(points.getCompanyCode()),Points::getCompanyCode, points.getCompanyCode())
				.eq(Points::getWarehouseCode, ShiroUtils.getWarehouseCode());

		if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){
			/*使用分页查询*/
			Page<Points> page = new Page<>(pageNum, pageSize);
			IPage<Points> iPage = pointsService.page(page, lambdaQueryWrapper);
xumiao authored
91
92
93
94
95
96
97
98
99
100
101
102
103
			iPage.getRecords().forEach(s->{
				if(!StringUtils.isAnyEmpty(s.getUWarehouseCode(),s.getWarehouseCode(),s.getCompanyCode())){
					WarehouseU8 warehouseU8 = warehouseU8Service.getOne(new LambdaQueryWrapper<WarehouseU8>()
							.eq(WarehouseU8::getUWarehouseCode, s.getUWarehouseCode())
							.eq(WarehouseU8::getWarehouseCode, s.getWarehouseCode())
							.eq(WarehouseU8::getCompanyCode, s.getCompanyCode())
							.last("limit 1")
					);
					if (warehouseU8 != null) {
						s.setUWarehouseName(warehouseU8.getUWarehouseName());
					}
				}
			});
pengcheng authored
104
105
106
107
108
109
110
111
112
113
			return getMpDataTable(iPage.getRecords(), iPage.getTotal());
		} else {
			List<Points> list = pointsService.list(lambdaQueryWrapper);
			list.forEach(t->{
				LambdaQueryWrapper<Company> companyLamb = Wrappers.lambdaQuery();
				companyLamb.eq(Company::getCode,t.getCompanyCode());
				Company company= companyService.getOne(companyLamb);
				if(company!=null) {
					t.setCompanyName(company.getName());
				}
xumiao authored
114
115
116
117
118
119
120
121
122
123
124
				if(!StringUtils.isAnyEmpty(t.getUWarehouseCode(),t.getWarehouseCode(),t.getCompanyCode())){
					WarehouseU8 warehouseU8 = warehouseU8Service.getOne(new LambdaQueryWrapper<WarehouseU8>()
							.eq(WarehouseU8::getUWarehouseCode, t.getUWarehouseCode())
							.eq(WarehouseU8::getWarehouseCode, t.getWarehouseCode())
							.eq(WarehouseU8::getCompanyCode, t.getCompanyCode())
							.last("limit 1")
					);
					if (warehouseU8 != null) {
						t.setUWarehouseName(warehouseU8.getUWarehouseName());
					}
				}
pengcheng authored
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
			});
			return getDataTable(list);
		}
	}

	/**
	 * 修改货架
	 */
	@GetMapping("/edit/{id}")
	public String edit(@PathVariable("id") Integer id, ModelMap mmap)
	{

		Points points = pointsService.getById(id);
		mmap.put("points", points);
	    return prefix + "/edit";
	}

	/**
	 * 修改保存货架
	 */
xumiao authored
145
	//@RequiresPermissions("config:point:edit")
pengcheng authored
146
147
148
	@Log(title = "配置-货架设置", operating = "修改货架", action = BusinessType.UPDATE)
	@PostMapping("/edit")
	@ResponseBody
xumiao authored
149
	@Transactional(rollbackFor = Exception.class)
pengcheng authored
150
151
	public AjaxResult editSave(Points points)
	{
152
153
154
155
156
157
158
159
160
161
162
163
164
165
		Points points1 =new Points();
		points1.setWarehouseCode(ShiroUtils.getWarehouseCode());
		points1.setGoodsShelfNo(points.getGoodsShelfNo());
		points1=pointsService.selectEntity(points1);

		Company company=new Company();
		if(StringUtils.isNotEmpty(points.getCompanyCode())){

			company.setCode(points.getCompanyCode());
			company=companyService.getByDomainOne(company);

			points1.setCompanyCode(company.getCode());
			points1.setCompanyId(company.getId());
			if(StringUtils.isNotEmpty(points.getUWarehouseCode())) {
166
167
168
				String uwarehouseCode=points.getUWarehouseCode();
				String[] str=uwarehouseCode.split(",");
				points.setUWarehouseCode(str[str.length-1]);
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
				points1.setUWarehouseCode(points.getUWarehouseCode());
			}
		}
		points1.setIsLocked(points.getIsLocked());

		if(StringUtils.isNotEmpty(points.getUWarehouseCode()) && StringUtils.isNotEmpty(points.getCompanyCode())) {
			Container container = new Container();
			container.setGoodsShelfNo(points.getGoodsShelfNo());
			List<Container> containerList = containerService.selectListEntityByEqual(container);
			for (Container item : containerList) {
				item.setCompanyCode(points.getCompanyCode());
				item.setUWarehouseCode(points.getUWarehouseCode());
				if (!containerService.updateById(item)) {
					return AjaxResult.error("修改失败");
				}
pengcheng authored
184
			}
185
186
187
188
189
190
			InventoryDetail inventory = new InventoryDetail();
			InventoryDetail inventory1 =new InventoryDetail();
			inventory.setCompanyCode(points.getCompanyCode());
			inventory.setUWarehouseCode(points.getUWarehouseCode());
			inventory1.setGoodsShelfNo(points.getGoodsShelfNo());
			inventoryDetailService.updateByCondition(inventory,inventory1);
pengcheng authored
191
		}
192
		if(!pointsService.updateById(points1)){
pengcheng authored
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
			return AjaxResult.error("修改失败");
		}
		return AjaxResult.success("修改成功");
	}


	/**
	 * 恢复货架状态
	 */
	@RequiresPermissions("config:point:edit")
	@Log(title = "配置-货架设置", operating = "恢复货架状态", action = BusinessType.UPDATE)
	@PostMapping("/restore")
	@ResponseBody
	public AjaxResult restore(){
		if(pointsService.updateAll() >0){
			return AjaxResult.success("货架状态恢复成功");
		}else {
			return AjaxResult.error("失败");
		}
	}

	/**
	 * 检测货架装货状态
	 */
	@RequiresPermissions("config:point:edit")
	@Log(title = "配置-货架设置", operating = "检测货架装货状态", action = BusinessType.UPDATE)
	@PostMapping("/detectShelf")
	@ResponseBody
	public AjaxResult detectShelf(){
		return pointsService.detectShelf();
	}
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242


	/**
	 * 修改保存货架常规属性
	 */
	@ApiOperation(value="修改常规属性", notes="修改常规属性", httpMethod = "POST")
	@RequiresPermissions("config:container:editCommonFlag")
	@Log(title = "配置-常规属性", operating = "修改常规属性", action = BusinessType.UPDATE)
	@PostMapping("/editCommonFlag")
	@ResponseBody
	public AjaxResult editCommonFlag(Integer[] ids,int commonStatus) {
		try{
			pointsService.updateContainerCommon(ids,commonStatus);
		}catch (Exception e) {
			return AjaxResult.error(e.getMessage());
		}
		return AjaxResult.success("成功");
	}
pengcheng authored
243
}