WfSubscriptionController.java 3.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. package com.xjrsoft.module.ledger.controller;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import cn.hutool.core.bean.BeanUtil;
  4. import com.alibaba.excel.EasyExcel;
  5. import com.alibaba.excel.support.ExcelTypeEnum;
  6. import com.baomidou.mybatisplus.core.metadata.IPage;
  7. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  8. import com.xjrsoft.common.model.result.RT;
  9. import com.xjrsoft.common.page.ConventPage;
  10. import com.xjrsoft.common.page.PageOutput;
  11. import com.xjrsoft.module.ledger.dto.AddWfSubscriptionDto;
  12. import com.xjrsoft.module.ledger.dto.WfSubscriptionPageDto;
  13. import com.xjrsoft.module.ledger.entity.WfSubscription;
  14. import com.xjrsoft.module.ledger.service.IWfSubscriptionService;
  15. import com.xjrsoft.module.ledger.vo.WfSubscriptionExcelVo;
  16. import com.xjrsoft.module.ledger.vo.WfSubscriptionListInfoVo;
  17. import com.xjrsoft.module.ledger.vo.WfSubscriptionPageVo;
  18. import io.swagger.annotations.Api;
  19. import io.swagger.annotations.ApiOperation;
  20. import lombok.AllArgsConstructor;
  21. import org.springframework.http.ResponseEntity;
  22. import org.springframework.web.bind.annotation.GetMapping;
  23. import org.springframework.web.bind.annotation.PostMapping;
  24. import org.springframework.web.bind.annotation.RequestBody;
  25. import org.springframework.web.bind.annotation.RequestMapping;
  26. import org.springframework.web.bind.annotation.RequestParam;
  27. import org.springframework.web.bind.annotation.RestController;
  28. import javax.validation.Valid;
  29. import java.io.ByteArrayOutputStream;
  30. import java.util.List;
  31. /**
  32. * @title: 物品申购
  33. * @Author dzx
  34. * @Date: 2024-02-19
  35. * @Version 1.0
  36. */
  37. @RestController
  38. @RequestMapping("/ledger" + "/wfSubscription")
  39. @Api(value = "/ledger" + "/wfSubscription",tags = "物品申购代码")
  40. @AllArgsConstructor
  41. public class WfSubscriptionController {
  42. private final IWfSubscriptionService wfSubscriptionService;
  43. @GetMapping(value = "/page")
  44. @ApiOperation(value="物品申购台账列表(分页)")
  45. @SaCheckPermission("wfsubscription:detail")
  46. public RT<PageOutput<WfSubscriptionPageVo>> page(@Valid WfSubscriptionPageDto dto){
  47. IPage<WfSubscriptionPageVo> page = wfSubscriptionService.getPage(new Page<>(dto.getLimit(), dto.getSize()), dto);
  48. PageOutput<WfSubscriptionPageVo> pageOutput = ConventPage.getPageOutput(page, WfSubscriptionPageVo.class);
  49. return RT.ok(pageOutput);
  50. }
  51. @GetMapping(value = "/subscription-list")
  52. @ApiOperation(value="查看物品清单")
  53. @SaCheckPermission("wfsubscription:detail")
  54. public RT<WfSubscriptionListInfoVo> subscriptionPage(@RequestParam Long id){
  55. WfSubscriptionListInfoVo wfSubscription = wfSubscriptionService.getSubscriptionList(id);
  56. if (wfSubscription == null) {
  57. return RT.error("找不到此数据!");
  58. }
  59. return RT.ok(wfSubscription);
  60. }
  61. @PostMapping
  62. @ApiOperation(value = "新增物品申购")
  63. @SaCheckPermission("wfsubscription:add")
  64. public RT<Boolean> add(@Valid @RequestBody AddWfSubscriptionDto dto){
  65. WfSubscription wfSubscription = BeanUtil.toBean(dto, WfSubscription.class);
  66. boolean isSuccess = wfSubscriptionService.add(wfSubscription);
  67. return RT.ok(isSuccess);
  68. }
  69. @PostMapping("/export-query")
  70. @ApiOperation(value = "导出")
  71. public ResponseEntity<byte[]> exportData(@Valid @RequestBody WfSubscriptionPageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
  72. List<WfSubscriptionExcelVo> customerList = wfSubscriptionService.getList(dto);
  73. ByteArrayOutputStream bot = new ByteArrayOutputStream();
  74. EasyExcel.write(bot, WfSubscriptionExcelVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
  75. return RT.fileStream(bot.toByteArray(), "WfSubscription" + ExcelTypeEnum.XLSX.getValue());
  76. }
  77. }