DepartmentController.java 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package com.x1ongzhu.wisFactory.web;
  2. import com.x1ongzhu.wisFactory.domain.Department;
  3. import com.x1ongzhu.wisFactory.dto.PageQuery;
  4. import com.x1ongzhu.wisFactory.exception.BusinessException;
  5. import com.x1ongzhu.wisFactory.repo.DepartmentRepo;
  6. import com.x1ongzhu.wisFactory.service.DepartmentService;
  7. import com.x1ongzhu.wisFactory.utils.ObjUtils;
  8. import com.x1ongzhu.wisFactory.utils.excel.ExcelUtils;
  9. import lombok.AllArgsConstructor;
  10. import org.springframework.data.domain.Page;
  11. import org.springframework.web.bind.annotation.*;
  12. import javax.servlet.http.HttpServletResponse;
  13. import java.io.IOException;
  14. import java.util.List;
  15. @RestController
  16. @RequestMapping("/department")
  17. @AllArgsConstructor
  18. public class DepartmentController extends BaseController {
  19. private DepartmentService departmentService;
  20. private DepartmentRepo departmentRepo;
  21. //@PreAuthorize("hasRole('ADMIN')")
  22. @PostMapping("/save")
  23. public Department save(@RequestBody Department record) {
  24. if (record.getId() != null) {
  25. Department orig = departmentRepo.findById(record.getId()).orElseThrow(new BusinessException("无记录"));
  26. ObjUtils.merge(orig, record);
  27. return departmentRepo.save(orig);
  28. }
  29. return departmentRepo.save(record);
  30. }
  31. //@PreAuthorize("hasRole('ADMIN')")
  32. @GetMapping("/all")
  33. public Page<Department> all(PageQuery pageQuery) {
  34. return departmentRepo.findAll(toSpecification(pageQuery,Department.class), toPageRequest(pageQuery));
  35. }
  36. @GetMapping("/get/{id}")
  37. public Department get(@PathVariable Long id) {
  38. return departmentRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  39. }
  40. @PostMapping("/del/{id}")
  41. public void del(@PathVariable Long id) {
  42. departmentRepo.deleteById(id);
  43. }
  44. @GetMapping("/excel")
  45. @ResponseBody
  46. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  47. List<Department> data = all(pageQuery).getContent();
  48. ExcelUtils.export(response, data);
  49. }
  50. @PostMapping("/saveHours")
  51. public void saveHours(@RequestBody List<Department> departments) {
  52. departmentService.saveHours(departments);
  53. }
  54. }