From 3471290659516cf21db3211a9053daff5f283e03 Mon Sep 17 00:00:00 2001
From: zhuguifei <312353457@qq.com>
Date: 星期五, 20 三月 2026 15:50:18 +0800
Subject: [PATCH] feat: 基础数据仪器管理、判定依据、判定依据明细

---
 RuoYi-Vue-Plus/ruoyi-modules/ruoyi-qa/src/main/java/org/dromara/qa/qm/controller/QmCheckitemController.java |  128 ++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 128 insertions(+), 0 deletions(-)

diff --git a/RuoYi-Vue-Plus/ruoyi-modules/ruoyi-qa/src/main/java/org/dromara/qa/qm/controller/QmCheckitemController.java b/RuoYi-Vue-Plus/ruoyi-modules/ruoyi-qa/src/main/java/org/dromara/qa/qm/controller/QmCheckitemController.java
new file mode 100644
index 0000000..395d74f
--- /dev/null
+++ b/RuoYi-Vue-Plus/ruoyi-modules/ruoyi-qa/src/main/java/org/dromara/qa/qm/controller/QmCheckitemController.java
@@ -0,0 +1,128 @@
+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<QmCheckitemVo> list(QmCheckitemBo bo, PageQuery pageQuery) {
+        return qmCheckitemService.queryPageList(bo, pageQuery);
+    }
+
+    @SaCheckPermission("qm:checkitem:list")
+    @GetMapping("/tree")
+    public TableDataInfo<QmCheckitemVo> tree(@RequestParam @NotBlank(message = "stdCode涓嶈兘涓虹┖") String stdCode,
+                                             @RequestParam(required = false) Integer page,
+                                             @RequestParam(required = false) Integer rows) {
+        List<QmCheckitemVo> list = qmCheckitemService.queryTreeListByStdCode(stdCode);
+        return TableDataInfo.build(list);
+    }
+
+    /**
+     * 鏍规嵁 stdCode 鏌ヨ瑙勭▼妫�楠岄」鐩殑 id 鍜� itemName 鍒楄〃
+     * @param stdCode 瑙勭▼浠g爜
+     * @return 鍖呭惈 id 鍜� text 鐨勫垪琛�
+     */
+    @SaCheckPermission("qm:checkitem:list") // 鍋囪浣跨敤鐩稿悓鐨勬潈闄�
+    @GetMapping("/getRid")
+    public R<List<Map<String, String>>> getRid(@RequestParam @NotBlank(message = "stdCode涓嶈兘涓虹┖") String stdCode) { // 淇敼杩斿洖绫诲瀷
+        List<Map<String, String>> 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<QmCheckitemVo> list = qmCheckitemService.queryList(bo);
+        ExcelUtil.exportExcel(list, "瑙勭▼妫�楠岄」鐩�", QmCheckitemVo.class, response);
+    }
+
+    /**
+     * 鑾峰彇瑙勭▼妫�楠岄」鐩缁嗕俊鎭�
+     *
+     * @param id 涓婚敭
+     */
+    @SaCheckPermission("qm:checkitem:query")
+    @GetMapping("/{id}")
+    public R<QmCheckitemVo> 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<Void> 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<Void> 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<Void> remove(@NotEmpty(message = "涓婚敭涓嶈兘涓虹┖")
+                          @PathVariable String[] ids) {
+        return toAjax(qmCheckitemService.deleteWithValidByIds(List.of(ids), true));
+    }
+}

--
Gitblit v1.9.3