Blame view

src/main/java/com/huaheng/pc/config/materialUnit/controller/MaterialUnitController.java 8.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
package com.huaheng.pc.config.materialUnit.controller;

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.support.Convert;
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.materialUnit.domain.MaterialUnit;
import com.huaheng.pc.config.materialUnit.service.MaterialUnitService;
19
20
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.material.service.MaterialService;
21
22
23
24
25
26
27
28
29
30
31
32
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.*;

import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.List;
33
@Api(tags = "单位 ")
34
35
36
37
38
39
@Controller
@RequestMapping("/config/materialUnit")
public class MaterialUnitController extends BaseController {

    @Resource
    private MaterialUnitService materialUnitService;
40
41
    @Resource
    private MaterialService materialService;
42
43
44
45
46
47
48
49
50
51

    private String prefix = "config/materialUnit";

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

    /**
52
     * 查询单位 列表
53
     */
54
    @ApiOperation(value="查看单位 列表", notes="根据物料编码、名称、单位、创建时间获取单位 列表", httpMethod = "POST")
55
    @RequiresPermissions("config:materialUnit:list")
56
    @Log(title = "配置-单位 ",operating = "单位 列表", action = BusinessType.GRANT)
57
58
59
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
    @PostMapping("/list")
    @ResponseBody
    public TableDataInfo list(@ApiParam(name="receiptType",value="料编码、名称、单位") MaterialUnit materialUnit,
                              @ApiParam(name = "createdBegin", value = "起止时间") String createdBegin,
                              @ApiParam(name = "createdEnd", value = "结束时间") String createdEnd) {
        LambdaQueryWrapper<MaterialUnit> lambdaQueryWrapper = Wrappers.lambdaQuery();
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();
        lambdaQueryWrapper.gt(StringUtils.isNotEmpty(createdBegin), MaterialUnit::getCreated, createdBegin)
                .lt(StringUtils.isNotEmpty(createdEnd), MaterialUnit::getCreated, createdEnd)
                .eq(StringUtils.isNotEmpty(materialUnit.getMaterialCode()), MaterialUnit::getMaterialCode, materialUnit.getMaterialCode())
                .eq(StringUtils.isNotEmpty(materialUnit.getMaterialName()), MaterialUnit::getMaterialName, materialUnit.getMaterialName())
                .eq(StringUtils.isNotEmpty(materialUnit.getUnit()), MaterialUnit::getUnit, materialUnit.getUnit())
                .in(MaterialUnit::getCompanyCode, ShiroUtils.getCompanyCodeList())
                .eq(MaterialUnit::getWarehouseCode, ShiroUtils.getWarehouseCode());

        if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){
            /*使用分页查询*/
            Page<MaterialUnit> page = new Page<>(pageNum, pageSize);
            IPage<MaterialUnit> iPage = materialUnitService.page(page, lambdaQueryWrapper);
            return getMpDataTable(iPage.getRecords(), iPage.getTotal());
        } else {
            List<MaterialUnit> list = materialUnitService.list(lambdaQueryWrapper);
            return getDataTable(list);
        }
    }

    /**
86
     * 新增单位 
87
88
89
90
91
92
93
     */
    @GetMapping("/add")
    public String add() {
        return prefix + "/add";
    }

    /**
94
     * 新增保存单位
95
     */
96
    @ApiOperation(value="新增单位 ", notes="新增单位 ", httpMethod = "POST")
97
    @RequiresPermissions("config:materialUnit:add")
98
    @Log(title = "配置-单位 ",operating = "新增单位 ", action = BusinessType.INSERT)
99
100
101
    @PostMapping("/add")
    @ResponseBody
    public AjaxResult addSave(MaterialUnit materialUnit) {
102
103
104
105
106
107
108
        LambdaQueryWrapper<Material> lambdaQueryWrapper = Wrappers.lambdaQuery();
        lambdaQueryWrapper.eq(Material::getCode, materialUnit.getMaterialCode());
        Material material = materialService.getOne(lambdaQueryWrapper);
        if (material == null){
            return AjaxResult.error(" 该物料编码不存在");
        }
109
110
111
112
113
114
115
116
        LambdaQueryWrapper<MaterialUnit> lambda = Wrappers.lambdaQuery();
        lambda.eq(MaterialUnit::getWarehouseCode, ShiroUtils.getWarehouseCode())
            .eq(MaterialUnit::getCompanyCode, materialUnit.getCompanyCode())
            .eq(MaterialUnit::getMaterialCode, materialUnit.getMaterialCode())
            .eq(MaterialUnit::getUnit, materialUnit.getUnit());
        if (materialUnitService.getOne(lambda) != null){
            return AjaxResult.error("当前新增记录已存在");
        }
117
118
119

        materialUnit.setMaterialName(material.getName());
        materialUnit.setMaterialSpec(material.getSpec());
120
121
122
123
124
125
        materialUnit.setCreatedBy(ShiroUtils.getLoginName());
        materialUnit.setLastUpdatedBy(ShiroUtils.getLoginName());
        return toAjax(materialUnitService.save(materialUnit));
    }

    /**
126
     * 修改单位 
127
128
129
130
131
132
133
134
135
     */
    @GetMapping("/edit/{id}")
    public String edit(@PathVariable("id") Integer id, ModelMap mmap) {
        MaterialUnit materialUnit = materialUnitService.getById(id);
        mmap.put("materialUnit", materialUnit);
        return prefix + "/edit";
    }

    /**
136
     * 修改保存单位 
137
     */
138
    @ApiOperation(value="修改单位信息", notes="修改单位信息", httpMethod = "POST")
139
    @RequiresPermissions("config:warehouse:edit")
140
    @Log(title = "配置-单位 ",operating = "修改单位 ", action = BusinessType.UPDATE)
141
142
143
    @PostMapping("/edit")
    @ResponseBody
    public AjaxResult editSave(MaterialUnit materialUnit) {
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
        LambdaQueryWrapper<Material> lambdaQueryWrapper = Wrappers.lambdaQuery();
        lambdaQueryWrapper.eq(Material::getCode, materialUnit.getMaterialCode());
        Material material = materialService.getOne(lambdaQueryWrapper);
        if (material == null){
            return AjaxResult.error(" 该物料编码不存在");
        }

        LambdaQueryWrapper<MaterialUnit> lambda = Wrappers.lambdaQuery();
        lambda.eq(MaterialUnit::getWarehouseCode, ShiroUtils.getWarehouseCode())
                .eq(MaterialUnit::getCompanyCode, materialUnit.getCompanyCode())
                .eq(MaterialUnit::getMaterialCode, materialUnit.getMaterialCode())
                .eq(MaterialUnit::getUnit, materialUnit.getUnit());
        if (materialUnitService.getOne(lambda) != null){
            return AjaxResult.error("物料编码"+materialUnit.getMaterialCode()+",d 单位"+material.getUnit()+"已存在记录");
        }
160
161
162
163
164
        materialUnit.setLastUpdatedBy(ShiroUtils.getLoginName());
        return toAjax(materialUnitService.updateById(materialUnit));
    }

    /**
165
     * 删除单位 
166
     */
167
    @ApiOperation(value="删除单位 ", notes="单条删除或批量删除单位 ,示例1或1,2,3", httpMethod = "POST")
168
    @RequiresPermissions("config:receiptType:remove")
169
    @Log(title = "配置-单位 ",operating = "删除单位 ", action = BusinessType.DELETE)
170
171
172
173
174
175
176
177
178
179
180
181
182
    @PostMapping( "/remove")
    @ResponseBody
    public AjaxResult remove(String ids) {
        if (StringUtils.isEmpty(ids)) {
            return AjaxResult.error("id不能为空");
        }
        List<Integer> list = new ArrayList<>();
        for (Integer id : Convert.toIntArray(ids)) {
            list.add(id);
        }
        return toAjax(materialUnitService.removeByIds(list));
    }
}