SnController.java 8.03 KB
package com.huaheng.pc.config.sn.controller;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

import javax.annotation.Resource;

import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.huaheng.common.utils.poi.ExcelUtil;
import com.huaheng.pc.common.JasperPrint.Print;
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.sn.domain.PartDomain;
import com.huaheng.pc.config.sn.domain.Sn;
import com.huaheng.pc.config.sn.domain.SnPartDetail;
import com.huaheng.pc.config.sn.domain.SnPartDomain;
import com.huaheng.pc.config.sn.service.SnPartDetailService;
import com.huaheng.pc.config.sn.service.SnService;
import io.swagger.annotations.ApiOperation;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.*;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
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.shipmentType.domain.ShipmentType;
import com.huaheng.pc.config.shipmentType.service.ShipmentTypeService;
import com.huaheng.pc.shipment.shipmentHeader.domain.ShipmentHeader;
import com.huaheng.pc.shipment.shipmentHeader.service.ShipmentHeaderService;

import io.swagger.annotations.ApiParam;
import org.springframework.web.multipart.MultipartFile;

@Controller
@RequestMapping("/config/sn")
public class SnController extends BaseController {

    @Resource
    private SnService snService;
    @Resource
    private SnPartDetailService snPartDetailService;
    @Resource
    private Print print;

    private String prefix = "config/sn";

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

    /**
     * 查询出库类型
     */
    @RequiresPermissions("config:sn:list")
    @Log(title = "配置-出库类型",operating = "出库类型列表", action = BusinessType.GRANT)
    @PostMapping("/list")
    @ResponseBody
    public TableDataInfo list(@ApiParam(name="sn",value="编码、类型") Sn sn,
           @ApiParam(name = "createdBegin", value = "起止时间") String createdBegin,
           @ApiParam(name = "createdEnd", value = "结束时间") String createdEnd) {
        LambdaQueryWrapper<Sn> lambdaQueryWrapper = Wrappers.lambdaQuery();
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();
        lambdaQueryWrapper.gt(StringUtils.isNotEmpty(createdBegin), Sn::getCreated, createdBegin)
                .lt(StringUtils.isNotEmpty(createdEnd), Sn::getCreated, createdEnd)
                .like(StringUtils.isNotEmpty(sn.getCode()), Sn::getCode, sn.getCode())
                .like(StringUtils.isNotEmpty(sn.getCorrelatedCode()), Sn::getCorrelatedCode, sn.getCorrelatedCode());
        if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){
            /*使用分页查询*/
            Page<Sn> page = new Page<>(pageNum, pageSize);
            IPage<Sn> iPage = snService.page(page, lambdaQueryWrapper);
            return getMpDataTable(iPage.getRecords(), iPage.getTotal());
        } else {
            List<Sn> list = snService.list(lambdaQueryWrapper);
            return getDataTable(list);
        }
    }

    /**
     * 新增出库类型
     */
    @GetMapping("/add")
    public String add() {
        return prefix + "/add";
    }

    /**
     * 新增出库类型
     */
    @RequiresPermissions("config:sn:add")
    @Log(title = "配置-出库类型",operating = "新增出库类型", action = BusinessType.INSERT)
    @PostMapping("/add")
    @ResponseBody
    public AjaxResult addSave(Sn sn) {
        Sn sn1=snService.getSn(sn.getCode());
        if(sn1!=null){
            return AjaxResult.error("数据已存在");
        }
        sn.setCreatedBy(ShiroUtils.getLoginName());
        sn.setLastUpdatedBy(ShiroUtils.getLoginName());
        return toAjax(snService.save(sn ));
    }

    /**
     * 修改出库类型
     */
    @GetMapping("/edit/{id}")
    public String edit(@PathVariable("id") Integer id, ModelMap mmap) {
        Sn sn = snService.getById(id);
        mmap.put("sn", sn);
        return prefix + "/edit";
    }

    /**
     * 修改保存出库类型
     */
    @RequiresPermissions("config:sn:edit")
    @Log(title = "配置-出库类型",operating = "修改出库类型", action = BusinessType.UPDATE)
    @PostMapping("/edit")
    @ResponseBody
    public AjaxResult editSave(Sn sn) {
        Sn sn1=snService.getById(sn.getId());
        if(!sn1.getCode().equals(sn.getCode())){
            Sn sn2=snService.getSn(sn.getCode());
            if(sn2!=null){
                return AjaxResult.error("数据已存在");
            }
        }
        sn.setLastUpdatedBy(ShiroUtils.getLoginName());
        return toAjax(snService.updateById(sn));
    }

    /**
     * 删除出库
     */
    @RequiresPermissions("config:sn:remove")
    @Log(title = "配置-出库管理",operating = "修改出库", action = BusinessType.DELETE)
    @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)) {
            Sn sn = snService.getById(id);
            if (sn != null) {
                List<SnPartDetail> partlist=snPartDetailService.getSnPartByCode(sn.getCode());
                if(partlist.size()<=0){
                    list.add(id);
                }else{
                    return AjaxResult.error("sn绑定了部件,不能删除");
                }
            }
        }
        return toAjax(snService.removeByIds(list));
    }

    /**
     * sn号打印,需要显示部件相关信息
     */
    @RequiresPermissions("config:sn:print")
    @Log(title = "配置-sn", operating = "sn打印", action = BusinessType.OTHER)
    @GetMapping("/report/{ids}")
    public String report (@PathVariable("ids") Integer[] ids, ModelMap mmap)  // arg1:物料id arg2:会话对象不需要直接返回
    {
        LambdaQueryWrapper<Sn> wrapper=new LambdaQueryWrapper<>();
        wrapper.in(Sn::getId,ids);
        List<Sn> details = snService.list(wrapper);
        for (Sn sn : details){
            List<SnPartDetail> partlist=snPartDetailService.getSnPartByCode(sn.getCode());
            String parts="";
            for (SnPartDetail snPartDetail : partlist){
                parts=parts+snPartDetail.getPart()+",";
            }
            sn.setParts(parts);
        }
        mmap.put("snList", details);
        return prefix + "/report";
    }
    @PostMapping("/importData")
    @ResponseBody
    public AjaxResult importData (MultipartFile file) throws Exception {
        ExcelUtil<Sn> util = new ExcelUtil<>(Sn.class);
        List<Sn> snList = util.importExcel(file.getInputStream());
        String operName = ShiroUtils.getLoginName();
        String message = snService.importSn(snList,  operName);
        return AjaxResult.success(message);
    }

    /**
     * 导出模板
     *
     * @return
     * @throws Exception
     */
    @GetMapping("/importTemplate")
    @ResponseBody
    public AjaxResult importTemplate () {
        ExcelUtil<Sn> util = new ExcelUtil<>(Sn.class);
        return util.importTemplateExcel("sn");
    }


}