package org.dromara.demo.controller; import cn.dev33.satoken.annotation.SaCheckPermission; import jakarta.servlet.http.HttpServletResponse; import jakarta.validation.constraints.NotEmpty; import jakarta.validation.constraints.NotNull; import lombok.RequiredArgsConstructor; import org.dromara.common.core.domain.R; import org.dromara.common.core.utils.MapstructUtils; import org.dromara.common.core.validate.AddGroup; import org.dromara.common.core.validate.EditGroup; import org.dromara.common.excel.core.ExcelResult; import org.dromara.common.excel.utils.ExcelUtil; import org.dromara.common.idempotent.annotation.RepeatSubmit; import org.dromara.common.log.annotation.Log; import org.dromara.common.log.enums.BusinessType; import org.dromara.common.mybatis.core.page.PageQuery; import org.dromara.common.mybatis.core.page.TableDataInfo; import org.dromara.common.web.core.BaseController; import org.dromara.demo.domain.RsDangerTotal; import org.dromara.demo.domain.bo.RsDangerTotalBo; import org.dromara.demo.domain.vo.RsDangerTotalVo; import org.dromara.demo.service.IRsDangerTotalService; import org.springframework.http.MediaType; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import java.util.ArrayList; import java.util.List; /** * 安全隐患统计 * * @author gonghl * @date 2024-02-29 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/demo/dangerTotal") public class RsDangerTotalController extends BaseController { private final IRsDangerTotalService rsDangerTotalService; /** * 查询安全隐患统计列表 */ @SaCheckPermission("demo:dangerTotal:list") @GetMapping("/list") public TableDataInfo list(RsDangerTotalBo bo, PageQuery pageQuery) { return rsDangerTotalService.queryPageList(bo, pageQuery); } /** * 导出安全隐患统计列表 */ @SaCheckPermission("demo:dangerTotal:export") @Log(title = "安全隐患统计", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(RsDangerTotalBo bo, HttpServletResponse response) { List list = rsDangerTotalService.queryList(bo); ExcelUtil.exportExcel(list, "安全隐患统计", RsDangerTotalVo.class, response); } /** * 导入数据 * * @param file 导入文件 */ @Log(title = "导入数据", businessType = BusinessType.IMPORT) @SaCheckPermission("demo:dangerTotal:import") @PostMapping(value = "/importData", consumes = MediaType.MULTIPART_FORM_DATA_VALUE) public R importData(@RequestPart("file") MultipartFile file) throws Exception { ExcelResult result = ExcelUtil.importExcel(file.getInputStream(), RsDangerTotalVo.class, true); List list = MapstructUtils.convert(result.getList(), RsDangerTotal.class); return R.ok(rsDangerTotalService.importExcel(list)); } /** * 获取导入模板 */ @SaCheckPermission("demo:dangerTotal:importTemplate") @PostMapping("/importTemplate") public void importTemplate(HttpServletResponse response) { ExcelUtil.exportExcel(new ArrayList<>(), "景区运行数据", RsDangerTotalVo.class, response); } /** * 获取安全隐患统计详细信息 * * @param id 主键 */ @SaCheckPermission("demo:dangerTotal:query") @GetMapping("/{id}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable String id) { return R.ok(rsDangerTotalService.queryById(id)); } /** * 新增安全隐患统计 */ @SaCheckPermission("demo:dangerTotal:add") @Log(title = "安全隐患统计", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody RsDangerTotalBo bo) { return toAjax(rsDangerTotalService.insertByBo(bo)); } /** * 修改安全隐患统计 */ @SaCheckPermission("demo:dangerTotal:edit") @Log(title = "安全隐患统计", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody RsDangerTotalBo bo) { return toAjax(rsDangerTotalService.updateByBo(bo)); } /** * 删除安全隐患统计 * * @param ids 主键串 */ @SaCheckPermission("demo:dangerTotal:remove") @Log(title = "安全隐患统计", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable String[] ids) { return toAjax(rsDangerTotalService.deleteWithValidByIds(List.of(ids), true)); } }