SysPostController.java 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package com.ruoyi.web.controller.system;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import com.ruoyi.common.annotation.Log;
  4. import com.ruoyi.common.constant.UserConstants;
  5. import com.ruoyi.common.core.controller.BaseController;
  6. import com.ruoyi.common.core.domain.PageQuery;
  7. import com.ruoyi.common.core.domain.R;
  8. import com.ruoyi.common.core.page.TableDataInfo;
  9. import com.ruoyi.common.enums.BusinessType;
  10. import com.ruoyi.common.utils.poi.ExcelUtil;
  11. import com.ruoyi.system.domain.SysPost;
  12. import com.ruoyi.system.service.ISysPostService;
  13. import io.swagger.v3.oas.annotations.tags.Tag;
  14. import lombok.RequiredArgsConstructor;
  15. import org.springframework.validation.annotation.Validated;
  16. import org.springframework.web.bind.annotation.*;
  17. import javax.servlet.http.HttpServletResponse;
  18. import java.util.List;
  19. /**
  20. * 岗位信息操作处理
  21. *
  22. * @author Lion Li
  23. */
  24. @Validated
  25. @Tag(name ="岗位信息控制器", description = "岗位信息管理")
  26. @RequiredArgsConstructor
  27. @RestController
  28. @RequestMapping("/system/post")
  29. public class SysPostController extends BaseController {
  30. private final ISysPostService postService;
  31. /**
  32. * 获取岗位列表
  33. */
  34. @SaCheckPermission("system:post:list")
  35. @GetMapping("/list")
  36. public TableDataInfo<SysPost> list(SysPost post, PageQuery pageQuery) {
  37. return postService.selectPagePostList(post, pageQuery);
  38. }
  39. /**
  40. * 导出岗位列表
  41. */
  42. @Log(title = "岗位管理", businessType = BusinessType.EXPORT)
  43. @SaCheckPermission("system:post:export")
  44. @PostMapping("/export")
  45. public void export(SysPost post, HttpServletResponse response) {
  46. List<SysPost> list = postService.selectPostList(post);
  47. ExcelUtil.exportExcel(list, "岗位数据", SysPost.class, response);
  48. }
  49. /**
  50. * 根据岗位编号获取详细信息
  51. *
  52. * @param postId 岗位ID
  53. */
  54. @SaCheckPermission("system:post:query")
  55. @GetMapping(value = "/{postId}")
  56. public R<SysPost> getInfo(@PathVariable Long postId) {
  57. return R.ok(postService.selectPostById(postId));
  58. }
  59. /**
  60. * 新增岗位
  61. */
  62. @SaCheckPermission("system:post:add")
  63. @Log(title = "岗位管理", businessType = BusinessType.INSERT)
  64. @PostMapping
  65. public R<Void> add(@Validated @RequestBody SysPost post) {
  66. if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) {
  67. return R.fail("新增岗位'" + post.getPostName() + "'失败,岗位名称已存在");
  68. } else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) {
  69. return R.fail("新增岗位'" + post.getPostName() + "'失败,岗位编码已存在");
  70. }
  71. return toAjax(postService.insertPost(post));
  72. }
  73. /**
  74. * 修改岗位
  75. */
  76. @SaCheckPermission("system:post:edit")
  77. @Log(title = "岗位管理", businessType = BusinessType.UPDATE)
  78. @PutMapping
  79. public R<Void> edit(@Validated @RequestBody SysPost post) {
  80. if (UserConstants.NOT_UNIQUE.equals(postService.checkPostNameUnique(post))) {
  81. return R.fail("修改岗位'" + post.getPostName() + "'失败,岗位名称已存在");
  82. } else if (UserConstants.NOT_UNIQUE.equals(postService.checkPostCodeUnique(post))) {
  83. return R.fail("修改岗位'" + post.getPostName() + "'失败,岗位编码已存在");
  84. }
  85. return toAjax(postService.updatePost(post));
  86. }
  87. /**
  88. * 删除岗位
  89. *
  90. * @param postIds 岗位ID串
  91. */
  92. @SaCheckPermission("system:post:remove")
  93. @Log(title = "岗位管理", businessType = BusinessType.DELETE)
  94. @DeleteMapping("/{postIds}")
  95. public R<Void> remove(@PathVariable Long[] postIds) {
  96. return toAjax(postService.deletePostByIds(postIds));
  97. }
  98. /**
  99. * 获取岗位选择框列表
  100. */
  101. @GetMapping("/optionselect")
  102. public R<List<SysPost>> optionselect() {
  103. List<SysPost> posts = postService.selectPostAll();
  104. return R.ok(posts);
  105. }
  106. }