package com.zt.modules.sys.controller; import com.zt.common.annotation.LogOperation; import com.zt.common.annotation.QueryParam; import com.zt.common.constant.Constant; import com.zt.common.db.query.QueryFilter; import com.zt.common.exception.RenException; import com.zt.common.servlet.PageResult; import com.zt.common.servlet.Result; import com.zt.common.validator.AssertUtils; import com.zt.common.validator.ValidatorUtils; import com.zt.common.validator.group.AddGroup; import com.zt.common.validator.group.DefaultGroup; import com.zt.common.validator.group.UpdateGroup; import com.zt.modules.sys.model.SysPost; import com.zt.modules.sys.service.SysPostService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import springfox.documentation.annotations.ApiIgnore; import java.util.List; /** * SYS_POST * * @author zt generator * @since 1.0.0 2020-06-04 */ @RestController @RequestMapping("/sys/post") @Api(tags = "岗位管理") public class SysPostController { @Autowired private SysPostService sysPostService; @GetMapping("page") @ApiOperation("表格列表") @ApiImplicitParams({ @ApiImplicitParam(name = Constant.Q.PAGE, value = Constant.QV.PAGE, required = true, dataType = Constant.QT.INT), @ApiImplicitParam(name = Constant.Q.LIMIT, value = Constant.QV.LIMIT, required = true, dataType = Constant.QT.INT), @ApiImplicitParam(name = Constant.Q.ORDER_FIELD, value = Constant.QV.ORDER_FIELD, dataType = Constant.QT.STRING), @ApiImplicitParam(name = Constant.Q.ORDER, value = Constant.QV.ORDER, dataType = Constant.QT.STRING), @ApiImplicitParam(name = "name", value = "岗位名称", dataType = Constant.QT.STRING, format = "name^LK"), @ApiImplicitParam(name = "deptId", value = "部门Id", required = true, dataType = Constant.QT.STRING, format = "dept_id^EQ") }) public PageResult page(@ApiIgnore @QueryParam QueryFilter queryFilter) { return PageResult.ok(sysPostService.page(queryFilter)); } @GetMapping("list") @ApiOperation("列表") @ApiImplicitParams({ @ApiImplicitParam(name = "deptId", value = "部门Id", required = true, dataType = Constant.QT.STRING, format = "dept_id^EQ") }) public Result> list(@ApiIgnore @QueryParam QueryFilter queryFilter) { return Result.ok(sysPostService.page(queryFilter)); } @GetMapping("{id}") @ApiOperation("信息") public Result get(@PathVariable("id") Long id) { SysPost data = sysPostService.get(id); return Result.ok(data); } @PostMapping @ApiOperation("新增") @LogOperation("岗位管理--->新增") public Result insert(@RequestBody SysPost post) { ValidatorUtils.validateEntity(post, AddGroup.class, DefaultGroup.class); if (post.getDeptId() == null || post.getDeptId() == 0) { throw new RenException("请选择所属部门"); } sysPostService.insert(post); return Result.ok(); } @PutMapping @ApiOperation("修改") @LogOperation("岗位管理--->修改") public Result update(@RequestBody SysPost post) { // 效验数据 ValidatorUtils.validateEntity(post, UpdateGroup.class, DefaultGroup.class); sysPostService.update(post); return Result.ok(); } @DeleteMapping @ApiOperation("删除") @LogOperation("岗位管理--->删除") public Result delete(@RequestBody Long[] ids) { // 效验数据 AssertUtils.isArrayEmpty(ids, "id"); sysPostService.delete(ids); return Result.ok(); } }