ZarsiController.java 4.27 KB
package com.huaheng.pc.sap.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.framework.web.page.PageDomain;
import com.huaheng.framework.web.page.TableDataInfo;
import com.huaheng.framework.web.page.TableSupport;
import com.huaheng.common.utils.StringUtils;
import com.huaheng.pc.sap.service.ZarsiService;
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.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.huaheng.framework.aspectj.lang.annotation.Log;
import com.huaheng.framework.aspectj.lang.constant.BusinessType;
import com.huaheng.pc.sap.domain.Zarsi;
import com.huaheng.framework.web.controller.BaseController;
import com.huaheng.framework.web.domain.AjaxResult;
import com.huaheng.common.support.Convert;

import javax.annotation.Resource;
import java.util.Arrays;
import java.util.Date;
import java.util.List;

/**
 * 中间表 信息操作处理
 *
 * @author huaheng
 * @date 2022-05-11
 */
@Controller
@RequestMapping("/sap/zarsi")
public class ZarsiController extends BaseController {
    private String prefix = "sap/zarsi";

    @Resource
    private ZarsiService zarsiService;

    @RequiresPermissions("sap:zarsi:view")
    @GetMapping()
    public String zarsi() {
        return prefix + "/list";
    }

    /**
     * 查询中间表列表
     */
    @RequiresPermissions("sap:zarsi:list")
    @PostMapping("/list")
    @ResponseBody
    public TableDataInfo list(Zarsi zarsi) {
        LambdaQueryWrapper<Zarsi> lambdaQueryWrapper = Wrappers.lambdaQuery();
        lambdaQueryWrapper.eq(StringUtils.isNotEmpty(zarsi.getUniqueId()), Zarsi::getUniqueId, zarsi.getUniqueId())
                .orderByDesc(Zarsi::getCreated);
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();
        if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)) {
            /*使用分页查询*/
            Page<Zarsi> page = new Page<>(pageNum, pageSize);
            IPage<Zarsi> iPage = zarsiService.page(page, lambdaQueryWrapper);
            return getMpDataTable(iPage.getRecords(), iPage.getTotal());
        } else {
            List<Zarsi> list = zarsiService.list(lambdaQueryWrapper);
            return getDataTable(list);
        }
    }

    /**
     * 新增中间表
     */
    @GetMapping("/add")
    public String add() {
        return prefix + "/add";
    }

    /**
     * 新增保存中间表
     */
    @RequiresPermissions("sap:zarsi:add")
    @Log(title = "中间表", action = BusinessType.INSERT)
    @PostMapping("/add")
    @ResponseBody
    public AjaxResult addSave(Zarsi zarsi) {
        return toAjax(zarsiService.saveZarsi(zarsi));
    }

    /**
     * 修改中间表
     */
    @GetMapping("/edit/{id}")
    public String edit(@PathVariable("id") Integer id, ModelMap mmap) {
        Zarsi zarsi = zarsiService.getById(id);
        mmap.put("zarsi", zarsi);
        return prefix + "/edit";
    }

    /**
     * 修改保存中间表
     */
    @RequiresPermissions("sap:zarsi:edit")
    @Log(title = "中间表", action = BusinessType.UPDATE)
    @PostMapping("/edit")
    @ResponseBody
    public AjaxResult editSave(Zarsi zarsi) {
        return toAjax(zarsiService.editZarsi(zarsi));
    }

    /**
     * 删除中间表
     */
    @RequiresPermissions("sap:zarsi:remove")
    @Log(title = "中间表", action = BusinessType.DELETE)
    @PostMapping("/remove")
    @ResponseBody
    public AjaxResult remove(String ids) {
        if (StringUtils.isEmpty(ids)) {
            return AjaxResult.error("id不能为空");
        }
        return toAjax(zarsiService.removeByIds(Arrays.asList(Convert.toIntArray(ids))));
    }

}