IsMaterialsController.java 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. package com.ktg.iscs.controller;
  2. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  3. import com.fasterxml.jackson.core.JsonProcessingException;
  4. import com.ktg.common.annotation.Log;
  5. import com.ktg.common.core.controller.BaseController;
  6. import com.ktg.common.core.domain.AjaxResult;
  7. import com.ktg.common.enums.BusinessType;
  8. import com.ktg.common.pojo.CommonResult;
  9. import com.ktg.common.utils.poi.ExcelUtil;
  10. import com.ktg.iscs.domain.IsMaterials;
  11. import com.ktg.iscs.domain.dto.hardwareApi.LoanParamDTO;
  12. import com.ktg.iscs.domain.dto.materials.MaterialBindingDTO;
  13. import com.ktg.iscs.domain.dto.materials.MaterialsPageDTO;
  14. import com.ktg.iscs.domain.vo.materials.ImportMaterialsVO;
  15. import com.ktg.iscs.domain.vo.materials.MaterialsPageVO;
  16. import com.ktg.iscs.service.IIsMaterialsService;
  17. import io.swagger.annotations.Api;
  18. import io.swagger.annotations.ApiOperation;
  19. import io.swagger.v3.oas.annotations.Parameter;
  20. import io.swagger.v3.oas.annotations.Parameters;
  21. import org.springframework.beans.factory.annotation.Autowired;
  22. import org.springframework.security.access.prepost.PreAuthorize;
  23. import org.springframework.web.bind.annotation.*;
  24. import org.springframework.web.multipart.MultipartFile;
  25. import javax.servlet.http.HttpServletResponse;
  26. import java.util.ArrayList;
  27. import java.util.Date;
  28. import java.util.List;
  29. /**
  30. * 物资Controller
  31. *
  32. * @author cgj
  33. * @date 2024-11-08
  34. */
  35. @Api(tags = "物资")
  36. @RestController
  37. @RequestMapping("/iscs/materials")
  38. public class IsMaterialsController extends BaseController
  39. {
  40. @Autowired
  41. private IIsMaterialsService isMaterialsService;
  42. /**
  43. * 查询物资分页
  44. */
  45. @ApiOperation("查询物资-分页")
  46. @Parameters({
  47. @Parameter(name = "page", description = "Page"),
  48. @Parameter(name = "dto", description = "实体参数")
  49. })
  50. @PreAuthorize("@ss.hasPermi('iscs:materials:list')")
  51. @GetMapping("/getIsMaterialsPage")
  52. public CommonResult<Page<MaterialsPageVO>> getIsMaterialsPage(Page<IsMaterials> page, MaterialsPageDTO dto) throws JsonProcessingException {
  53. Page<MaterialsPageVO> result = isMaterialsService.getIsMaterialsPage(page, dto);
  54. return CommonResult.success(result);
  55. }
  56. @ApiOperation("查询异常还错柜子的物资")
  57. @Parameters({
  58. @Parameter(name = "dto", description = "实体参数")
  59. })
  60. @PreAuthorize("@ss.hasPermi('iscs:materials:list')")
  61. @GetMapping("/getExMaterials")
  62. public CommonResult<List<MaterialsPageVO>> getExMaterials(MaterialsPageDTO dto) {
  63. List<MaterialsPageVO> result = isMaterialsService.getExMaterials(dto);
  64. return CommonResult.success(result);
  65. }
  66. /**
  67. * 导出物资列表
  68. */
  69. @ApiOperation("导出物资列表")
  70. @Parameter(name = "isMaterials", description = "实体参数")
  71. @PreAuthorize("@ss.hasPermi('iscs:materials:export')")
  72. @Log(title = "物资", businessType = BusinessType.EXPORT)
  73. @PostMapping("/exportIsMaterials")
  74. public void exportIsMaterials(HttpServletResponse response, IsMaterials isMaterials)
  75. {
  76. List<IsMaterials> list = isMaterialsService.selectIsMaterialsList(isMaterials);
  77. ExcelUtil<IsMaterials> util = new ExcelUtil<IsMaterials>(IsMaterials.class);
  78. util.exportExcel(response, list, "物资数据");
  79. }
  80. /**
  81. * 获取物资详细信息
  82. */
  83. @ApiOperation("获取物资详细信息")
  84. @Parameter(name = "materialsId", description = "materialsId")
  85. @PreAuthorize("@ss.hasPermi('iscs:materials:query')")
  86. @GetMapping(value = "/selectIsMaterialsById")
  87. public CommonResult<IsMaterials> selectIsMaterialsById(Long materialsId)
  88. {
  89. return CommonResult.success(isMaterialsService.selectIsMaterialsByMaterialsId(materialsId));
  90. }
  91. /**
  92. * 新增物资
  93. */
  94. @ApiOperation("新增物资")
  95. @PreAuthorize("@ss.hasPermi('iscs:materials:add')")
  96. @Log(title = "物资", businessType = BusinessType.INSERT)
  97. @PostMapping("/insertIsMaterials")
  98. public CommonResult<Boolean> insertIsMaterials(@RequestBody @Parameter(name = "isMaterials", description = "新增数据类,放到body") IsMaterials isMaterials)
  99. {
  100. return CommonResult.success(isMaterialsService.insertIsMaterials(isMaterials) == 1);
  101. }
  102. /**
  103. * 修改物资
  104. */
  105. @ApiOperation("修改物资")
  106. @PreAuthorize("@ss.hasPermi('iscs:materials:edit')")
  107. @Log(title = "物资", businessType = BusinessType.UPDATE)
  108. @PostMapping("/updateIsMaterials")
  109. public CommonResult<Boolean> updateIsMaterials(@RequestBody @Parameter(name = "isMaterials", description = "修改数据类,放到body") IsMaterials isMaterials)
  110. {
  111. return CommonResult.success(isMaterialsService.updateIsMaterials(isMaterials) == 1);
  112. }
  113. @ApiOperation("借出/归还物资")
  114. @PreAuthorize("@ss.hasPermi('iscs:materials:loan')")
  115. @Log(title = "借出/归还物资", businessType = BusinessType.UPDATE)
  116. @PostMapping("/updateIsMaterialById")
  117. public CommonResult<Boolean> updateIsMaterialById(@RequestBody @Parameter(name = "dto", description = "修改数据类,放到body") LoanParamDTO dto)
  118. {
  119. return CommonResult.success(isMaterialsService.updateIsMaterialById(dto));
  120. }
  121. /**
  122. * 删除物资
  123. */
  124. @ApiOperation("删除物资")
  125. @PreAuthorize("@ss.hasPermi('iscs:materials:remove')")
  126. @Log(title = "物资", businessType = BusinessType.DELETE)
  127. @PostMapping("/deleteIsMaterialsByMaterialsIds")
  128. public CommonResult<Boolean> deleteIsMaterialsByMaterialsIds(String materialsIds)
  129. {
  130. return CommonResult.success(isMaterialsService.deleteIsMaterialsByMaterialsIds(materialsIds) != 0);
  131. }
  132. @ApiOperation("导入模板-物资")
  133. @Log(title = "导入模板-物资")
  134. @PostMapping("/importTemplate")
  135. public void importTemplate(HttpServletResponse response)
  136. {
  137. ExcelUtil<ImportMaterialsVO> util = new ExcelUtil<>(ImportMaterialsVO.class);
  138. ImportMaterialsVO importMaterialsVO = new ImportMaterialsVO();
  139. importMaterialsVO.setCabinetName("一号物资柜");
  140. importMaterialsVO.setMaterialsName("实验室白大褂K380");
  141. importMaterialsVO.setMaterialsTypeName("白大褂");
  142. importMaterialsVO.setValueName("s");
  143. importMaterialsVO.setMaterialsRfid("7418965826");
  144. importMaterialsVO.setSupplier("零号实验室");
  145. importMaterialsVO.setExpirationDate(new Date());
  146. ArrayList<ImportMaterialsVO> importMaterialsVOS = new ArrayList<>();
  147. importMaterialsVOS.add(importMaterialsVO);
  148. util.importTempExcelWithDate(response, "物资数据", importMaterialsVOS);
  149. }
  150. @ApiOperation("导入-物资")
  151. @Log(title = "导入-物资", businessType = BusinessType.IMPORT)
  152. @PreAuthorize("@ss.hasPermi('iscs:materials:import')")
  153. @PostMapping("/importMaterials")
  154. public AjaxResult importMaterials(MultipartFile file, boolean updateSupport) throws Exception
  155. {
  156. ExcelUtil<ImportMaterialsVO> util = new ExcelUtil<>(ImportMaterialsVO.class);
  157. List<ImportMaterialsVO> itemList = util.importExcel(file.getInputStream());
  158. String operName = getUsername();
  159. String message = isMaterialsService.importMaterials(itemList, updateSupport, operName);
  160. return AjaxResult.success(message);
  161. }
  162. @ApiOperation("绑定物资-物资柜绑定物资")
  163. @PreAuthorize("@ss.hasPermi('iscs:materials:binding')")
  164. @Log(title = "物资", businessType = BusinessType.UPDATE)
  165. @PostMapping("/updateMaterialsBinding")
  166. public CommonResult<Boolean> updateMaterialsBinding(@RequestBody @Parameter(name = "dto", description = "修改数据类,放到body") MaterialBindingDTO dto)
  167. {
  168. return CommonResult.success(isMaterialsService.updateMaterialsBinding(dto));
  169. }
  170. }