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/md/controller/MdInstrumentController.java |  105 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 105 insertions(+), 0 deletions(-)

diff --git a/RuoYi-Vue-Plus/ruoyi-modules/ruoyi-qa/src/main/java/org/dromara/qa/md/controller/MdInstrumentController.java b/RuoYi-Vue-Plus/ruoyi-modules/ruoyi-qa/src/main/java/org/dromara/qa/md/controller/MdInstrumentController.java
new file mode 100644
index 0000000..df68e72
--- /dev/null
+++ b/RuoYi-Vue-Plus/ruoyi-modules/ruoyi-qa/src/main/java/org/dromara/qa/md/controller/MdInstrumentController.java
@@ -0,0 +1,105 @@
+package org.dromara.qa.md.controller;
+
+import java.util.List;
+
+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.md.domain.vo.MdInstrumentVo;
+import org.dromara.qa.md.domain.bo.MdInstrumentBo;
+import org.dromara.qa.md.service.IMdInstrumentService;
+import org.dromara.common.mybatis.core.page.TableDataInfo;
+
+/**
+ * 娴嬮噺浠櫒
+ *
+ * @author zhuguifei
+ * @date 2026-03-18
+ */
+@Validated
+@RequiredArgsConstructor
+@RestController
+@RequestMapping("/md/instrument")
+public class MdInstrumentController extends BaseController {
+
+    private final IMdInstrumentService mdInstrumentService;
+
+    /**
+     * 鏌ヨ娴嬮噺浠櫒鍒楄〃
+     */
+    @SaCheckPermission("md:instrument:list")
+    @GetMapping("/list")
+    public TableDataInfo<MdInstrumentVo> list(MdInstrumentBo bo, PageQuery pageQuery) {
+        return mdInstrumentService.queryPageList(bo, pageQuery);
+    }
+
+    /**
+     * 瀵煎嚭娴嬮噺浠櫒鍒楄〃
+     */
+    @SaCheckPermission("md:instrument:export")
+    @Log(title = "娴嬮噺浠櫒", businessType = BusinessType.EXPORT)
+    @PostMapping("/export")
+    public void export(MdInstrumentBo bo, HttpServletResponse response) {
+        List<MdInstrumentVo> list = mdInstrumentService.queryList(bo);
+        ExcelUtil.exportExcel(list, "娴嬮噺浠櫒", MdInstrumentVo.class, response);
+    }
+
+    /**
+     * 鑾峰彇娴嬮噺浠櫒璇︾粏淇℃伅
+     *
+     * @param id 涓婚敭
+     */
+    @SaCheckPermission("md:instrument:query")
+    @GetMapping("/{id}")
+    public R<MdInstrumentVo> getInfo(@NotNull(message = "涓婚敭涓嶈兘涓虹┖")
+                                     @PathVariable String id) {
+        return R.ok(mdInstrumentService.queryById(id));
+    }
+
+    /**
+     * 鏂板娴嬮噺浠櫒
+     */
+    @SaCheckPermission("md:instrument:add")
+    @Log(title = "娴嬮噺浠櫒", businessType = BusinessType.INSERT)
+    @RepeatSubmit()
+    @PostMapping()
+    public R<Void> add(@Validated(AddGroup.class) @RequestBody MdInstrumentBo bo) {
+        return toAjax(mdInstrumentService.insertByBo(bo));
+    }
+
+    /**
+     * 淇敼娴嬮噺浠櫒
+     */
+    @SaCheckPermission("md:instrument:edit")
+    @Log(title = "娴嬮噺浠櫒", businessType = BusinessType.UPDATE)
+    @RepeatSubmit()
+    @PutMapping()
+    public R<Void> edit(@Validated(EditGroup.class) @RequestBody MdInstrumentBo bo) {
+        return toAjax(mdInstrumentService.updateByBo(bo));
+    }
+
+    /**
+     * 鍒犻櫎娴嬮噺浠櫒
+     *
+     * @param ids 涓婚敭涓�
+     */
+    @SaCheckPermission("md:instrument:remove")
+    @Log(title = "娴嬮噺浠櫒", businessType = BusinessType.DELETE)
+    @DeleteMapping("/{ids}")
+    public R<Void> remove(@NotEmpty(message = "涓婚敭涓嶈兘涓虹┖")
+                          @PathVariable String[] ids) {
+        return toAjax(mdInstrumentService.deleteWithValidByIds(List.of(ids), true));
+    }
+}

--
Gitblit v1.9.3