package org.dromara.eims.controller; import java.util.ArrayList; import java.util.List; import org.dromara.common.excel.core.ExcelResult; import org.dromara.eims.domain.bo.EimsEquBo; import org.dromara.eims.domain.vo.EimsEquImportVo; import org.dromara.eims.domain.vo.EimsEquVo; import org.dromara.eims.listener.EimsEquImportListener; import org.dromara.eims.service.IEimsEquService; import lombok.RequiredArgsConstructor; import jakarta.servlet.http.HttpServletResponse; import jakarta.validation.constraints.*; import cn.dev33.satoken.annotation.SaCheckPermission; import org.springframework.http.MediaType; import org.springframework.web.bind.annotation.*; import org.springframework.validation.annotation.Validated; import org.dromara.common.idempotent.annotation.RepeatSubmit; import org.dromara.common.log.annotation.Log; import org.dromara.common.web.core.BaseController; import org.dromara.common.mybatis.core.page.PageQuery; import org.dromara.common.core.domain.R; import org.dromara.common.core.validate.AddGroup; import org.dromara.common.core.validate.EditGroup; import org.dromara.common.log.enums.BusinessType; import org.dromara.common.excel.utils.ExcelUtil; import org.dromara.common.mybatis.core.page.TableDataInfo; import org.springframework.web.multipart.MultipartFile; /** * 【设备台账】 * * @author zhuguifei * @date 2025-01-04 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/eims/equ") public class EimsEquController extends BaseController { private final IEimsEquService eimsEquipmentService; /** * 查询【设备台账】列表 */ @SaCheckPermission("eims:equ:list") @GetMapping("/list") public TableDataInfo list(EimsEquBo bo, PageQuery pageQuery) { return eimsEquipmentService.queryPageList(bo, pageQuery); } /** * 导出【设备台账】列表 */ @SaCheckPermission("eims:equ:export") @Log(title = "【设备台账】", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(EimsEquBo bo, HttpServletResponse response) { List list = eimsEquipmentService.queryList(bo); ExcelUtil.exportExcel(list, "【设备台账】", EimsEquVo.class, response); } /** * 获取【设备台账】详细信息 * * @param equId 主键 */ @SaCheckPermission("eims:equ:query") @GetMapping("/{equId}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable Long equId) { return R.ok(eimsEquipmentService.queryById(equId)); } /** * 获取【设备台账】详细信息 * * @param assetNo */ @SaCheckPermission("eims:equ:query") @GetMapping("/info/{assetNo}") public R getInfoByAssetNo(@NotNull(message = "资产编号不能为空") @PathVariable String assetNo) { return R.ok(eimsEquipmentService.queryByAssetNo(assetNo)); } /** * 新增【设备台账】 */ @SaCheckPermission("eims:equ:add") @Log(title = "【设备台账】", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody EimsEquBo bo) { return toAjax(eimsEquipmentService.insertByBo(bo)); } /** * 修改【设备台账】 */ @SaCheckPermission("eims:equ:edit") @Log(title = "【设备台账】", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody EimsEquBo bo) { return toAjax(eimsEquipmentService.updateByBo(bo)); } /** * 删除【设备台账】 * * @param equIds 主键串 */ @SaCheckPermission("eims:equ:remove") @Log(title = "【设备台账】", businessType = BusinessType.DELETE) @DeleteMapping("/{equIds}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable Long[] equIds) { return toAjax(eimsEquipmentService.deleteWithValidByIds(List.of(equIds), true)); } /** * 导入数据 * * @param file 导入文件 * @param updateSupport 是否更新已存在数据 */ @Log(title = "设备管理", businessType = BusinessType.IMPORT) @SaCheckPermission("eims:equ:import") @PostMapping(value = "/importData", consumes = MediaType.MULTIPART_FORM_DATA_VALUE) public R importData(@RequestPart("file") MultipartFile file, boolean updateSupport) throws Exception { ExcelResult result = ExcelUtil.importExcel(file.getInputStream(), EimsEquImportVo.class, new EimsEquImportListener(updateSupport)); return R.ok(result.getAnalysis()); } /** * 获取导入模板 */ @PostMapping("/importTemplate") public void importTemplate(HttpServletResponse response) { ExcelUtil.exportExcel(new ArrayList<>(), "设备数据", EimsEquVo.class, response); } }