package org.dromara.qa.qm.controller; import java.util.List; import java.util.Map; import lombok.RequiredArgsConstructor; import jakarta.servlet.http.HttpServletResponse; import jakarta.validation.constraints.*; import cn.dev33.satoken.annotation.SaCheckPermission; 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.qa.qm.domain.vo.QmCheckitemVo; import org.dromara.qa.qm.domain.bo.QmCheckitemBo; import org.dromara.qa.qm.service.IQmCheckitemService; import org.dromara.common.mybatis.core.page.TableDataInfo; /** * 规程检验项目 * * @author zhuguifei * @date 2026-03-12 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/qm/checkitem") public class QmCheckitemController extends BaseController { private final IQmCheckitemService qmCheckitemService; /** * 查询规程检验项目列表 */ @SaCheckPermission("qm:checkitem:list") @GetMapping("/list") public TableDataInfo list(QmCheckitemBo bo, PageQuery pageQuery) { return qmCheckitemService.queryPageList(bo, pageQuery); } @SaCheckPermission("qm:checkitem:list") @GetMapping("/tree") public TableDataInfo tree(@RequestParam @NotBlank(message = "stdCode不能为空") String stdCode, @RequestParam(required = false) Integer page, @RequestParam(required = false) Integer rows) { List list = qmCheckitemService.queryTreeListByStdCode(stdCode); return TableDataInfo.build(list); } /** * 根据 stdCode 查询规程检验项目的 id 和 itemName 列表 * @param stdCode 规程代码 * @return 包含 id 和 text 的列表 */ @SaCheckPermission("qm:checkitem:list") // 假设使用相同的权限 @GetMapping("/getRid") public R>> getRid(@RequestParam @NotBlank(message = "stdCode不能为空") String stdCode) { // 修改返回类型 List> list = qmCheckitemService.getRid(stdCode); return R.ok(list); } /** * 导出规程检验项目列表 */ @SaCheckPermission("qm:checkitem:export") @Log(title = "规程检验项目", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(QmCheckitemBo bo, HttpServletResponse response) { List list = qmCheckitemService.queryList(bo); ExcelUtil.exportExcel(list, "规程检验项目", QmCheckitemVo.class, response); } /** * 获取规程检验项目详细信息 * * @param id 主键 */ @SaCheckPermission("qm:checkitem:query") @GetMapping("/{id}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable String id) { return R.ok(qmCheckitemService.queryById(id)); } /** * 新增规程检验项目 */ @SaCheckPermission("qm:checkitem:add") @Log(title = "规程检验项目", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody QmCheckitemBo bo) { return toAjax(qmCheckitemService.insertByBo(bo)); } /** * 修改规程检验项目 */ @SaCheckPermission("qm:checkitem:edit") @Log(title = "规程检验项目", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody QmCheckitemBo bo) { return toAjax(qmCheckitemService.updateByBo(bo)); } /** * 删除规程检验项目 * * @param ids 主键串 */ @SaCheckPermission("qm:checkitem:remove") @Log(title = "规程检验项目", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable String[] ids) { return toAjax(qmCheckitemService.deleteWithValidByIds(List.of(ids), true)); } }