TQuestionnaireController.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. package com.ruoyi.web.controller.rc;
  2. import com.ruoyi.common.core.domain.entity.SysDept;
  3. import com.ruoyi.rc.domain.TDeptInfo;
  4. import com.ruoyi.system.service.ISysDeptService;
  5. import java.util.List;
  6. import javax.servlet.http.HttpServletResponse;
  7. import org.springframework.security.access.prepost.PreAuthorize;
  8. import org.springframework.beans.factory.annotation.Autowired;
  9. import org.springframework.web.bind.annotation.GetMapping;
  10. import org.springframework.web.bind.annotation.PostMapping;
  11. import org.springframework.web.bind.annotation.PutMapping;
  12. import org.springframework.web.bind.annotation.DeleteMapping;
  13. import org.springframework.web.bind.annotation.PathVariable;
  14. import org.springframework.web.bind.annotation.RequestBody;
  15. import org.springframework.web.bind.annotation.RequestMapping;
  16. import org.springframework.web.bind.annotation.RestController;
  17. import com.ruoyi.common.annotation.Log;
  18. import com.ruoyi.common.core.controller.BaseController;
  19. import com.ruoyi.common.core.domain.AjaxResult;
  20. import com.ruoyi.common.enums.BusinessType;
  21. import com.ruoyi.rc.domain.TQuestionnaire;
  22. import com.ruoyi.rc.service.ITQuestionnaireService;
  23. import com.ruoyi.common.utils.poi.ExcelUtil;
  24. import com.ruoyi.common.core.page.TableDataInfo;
  25. import com.ruoyi.common.utils.StringUtils;
  26. /**
  27. * 问卷Controller
  28. *
  29. * @author ruoyi
  30. * @date 2024-07-24
  31. */
  32. @RestController
  33. @RequestMapping("/rc/questionnaire")
  34. public class TQuestionnaireController extends BaseController
  35. {
  36. @Autowired
  37. private ITQuestionnaireService tQuestionnaireService;
  38. @Autowired
  39. private ISysDeptService deptService;
  40. /**
  41. * 查询问卷列表
  42. */
  43. @GetMapping("/list")
  44. public TableDataInfo list(TQuestionnaire tQuestionnaire)
  45. {
  46. startPage();
  47. List<TQuestionnaire> list = tQuestionnaireService.selectTQuestionnaireList(tQuestionnaire);
  48. for (TQuestionnaire obj : list) {
  49. String deptId = obj.getDeptId();
  50. if (StringUtils.isNotEmpty(deptId)) {
  51. if (deptId.indexOf(",") != -1) {
  52. StringBuffer sb = new StringBuffer();
  53. String[] ids = deptId.split(",");
  54. for (String id : ids) {
  55. SysDept sysDept = deptService.selectDeptById(Long.parseLong(id));
  56. sb.append(sysDept.getDeptName()).append(" / ");
  57. }
  58. obj.setDeptName(sb.toString().substring(0, sb.length() - 3));
  59. } else {
  60. obj.setDeptName(deptService.selectDeptById(Long.parseLong(deptId)).getDeptName());
  61. }
  62. }
  63. }
  64. return getDataTable(list);
  65. }
  66. /**
  67. * 导出问卷列表
  68. */
  69. @Log(title = "问卷", businessType = BusinessType.EXPORT)
  70. @PostMapping("/export")
  71. public void export(HttpServletResponse response, TQuestionnaire tQuestionnaire)
  72. {
  73. List<TQuestionnaire> list = tQuestionnaireService.selectTQuestionnaireList(tQuestionnaire);
  74. ExcelUtil<TQuestionnaire> util = new ExcelUtil<TQuestionnaire>(TQuestionnaire.class);
  75. util.exportExcel(response, list, "问卷数据");
  76. }
  77. /**
  78. * 获取问卷详细信息
  79. */
  80. @GetMapping(value = "/{id}")
  81. public AjaxResult getInfo(@PathVariable("id") Long id)
  82. {
  83. TQuestionnaire tQuestionnaire = tQuestionnaireService.selectTQuestionnaireById(id);
  84. String year = tQuestionnaire.getYear();
  85. if (StringUtils.isNotEmpty(year) && !"".equals(year) && year.length() > 4) {
  86. tQuestionnaire.setYear(year.substring(0, year.indexOf("-")));
  87. }
  88. return success(tQuestionnaire);
  89. }
  90. /**
  91. * 新增问卷
  92. */
  93. @Log(title = "问卷", businessType = BusinessType.INSERT)
  94. @PostMapping
  95. public AjaxResult add(@RequestBody TQuestionnaire tQuestionnaire)
  96. {
  97. if (StringUtils.isNull(tQuestionnaire.getDeptId())) {
  98. tQuestionnaire.setDeptId(getLoginUser().getDeptId().toString());
  99. }
  100. return toAjax(tQuestionnaireService.insertTQuestionnaire(tQuestionnaire));
  101. }
  102. /**
  103. * 修改问卷
  104. */
  105. @Log(title = "问卷", businessType = BusinessType.UPDATE)
  106. @PutMapping
  107. public AjaxResult edit(@RequestBody TQuestionnaire tQuestionnaire)
  108. {
  109. return toAjax(tQuestionnaireService.updateTQuestionnaire(tQuestionnaire));
  110. }
  111. /**
  112. * 删除问卷
  113. */
  114. @Log(title = "问卷", businessType = BusinessType.DELETE)
  115. @DeleteMapping("/{ids}")
  116. public AjaxResult remove(@PathVariable Long[] ids)
  117. {
  118. return toAjax(tQuestionnaireService.deleteTQuestionnaireByIds(ids));
  119. }
  120. }