From 3baaad59171ded6aca17340fcc907acbeeb45b7b Mon Sep 17 00:00:00 2001
From: zhuguifei <zhuguifei@zhuguifeideiMac.local>
Date: 星期二, 08 四月 2025 08:14:43 +0800
Subject: [PATCH] Merge branch 'main' of http://lanpucloud.cn:1111/r/eims-master

---
 eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/controller/EimsSpareTypeController.java |  126 ++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 126 insertions(+), 0 deletions(-)

diff --git a/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/controller/EimsSpareTypeController.java b/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/controller/EimsSpareTypeController.java
new file mode 100644
index 0000000..ed94469
--- /dev/null
+++ b/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/controller/EimsSpareTypeController.java
@@ -0,0 +1,126 @@
+package org.dromara.eims.controller;
+
+import java.util.List;
+
+import cn.hutool.core.lang.tree.Tree;
+import lombok.RequiredArgsConstructor;
+import jakarta.servlet.http.HttpServletResponse;
+import jakarta.validation.constraints.*;
+import cn.dev33.satoken.annotation.SaCheckPermission;
+import org.dromara.eims.domain.bo.EimsEquTypeBo;
+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.eims.domain.vo.EimsSpareTypeVo;
+import org.dromara.eims.domain.bo.EimsSpareTypeBo;
+import org.dromara.eims.service.IEimsSpareTypeService;
+
+/**
+ * 澶囦欢绫诲瀷
+ *
+ * @author zhuguifei
+ * @date 2025-03-20
+ */
+@Validated
+@RequiredArgsConstructor
+@RestController
+@RequestMapping("/eims/spareType")
+public class EimsSpareTypeController extends BaseController {
+
+    private final IEimsSpareTypeService eimsSpareTypeService;
+
+    /**
+     * 鏌ヨ澶囦欢绫诲瀷鍒楄〃
+     */
+    @SaCheckPermission("eims:spareType:list")
+    @GetMapping("/list")
+    public R<List<EimsSpareTypeVo>> list(EimsSpareTypeBo bo) {
+        List<EimsSpareTypeVo> list = eimsSpareTypeService.queryList(bo);
+        return R.ok(list);
+    }
+
+    /**
+     * 鑾峰彇璁惧绫诲瀷鏍戝垪琛�
+     */
+    @SaCheckPermission("eims:spareType:list")
+    @GetMapping("/tree")
+    public R<List<Tree<Long>>> spareTypeTree(EimsSpareTypeBo bo) {
+        return R.ok(eimsSpareTypeService.selectSpareTypeTreeList(bo));
+    }
+
+    /**
+     * 瀵煎嚭澶囦欢绫诲瀷鍒楄〃
+     */
+    @SaCheckPermission("eims:spareType:export")
+    @Log(title = "澶囦欢绫诲瀷", businessType = BusinessType.EXPORT)
+    @PostMapping("/export")
+    public void export(EimsSpareTypeBo bo, HttpServletResponse response) {
+        List<EimsSpareTypeVo> list = eimsSpareTypeService.queryList(bo);
+        ExcelUtil.exportExcel(list, "澶囦欢绫诲瀷", EimsSpareTypeVo.class, response);
+    }
+
+    /**
+     * 鑾峰彇澶囦欢绫诲瀷璇︾粏淇℃伅
+     *
+     * @param id 涓婚敭
+     */
+    @SaCheckPermission("eims:spareType:query")
+    @GetMapping("/{id}")
+    public R<EimsSpareTypeVo> getInfo(@NotNull(message = "涓婚敭涓嶈兘涓虹┖")
+                                     @PathVariable Long id) {
+        return R.ok(eimsSpareTypeService.queryById(id));
+    }
+
+    /**
+     * 鏂板澶囦欢绫诲瀷
+     */
+    @SaCheckPermission("eims:spareType:add")
+    @Log(title = "澶囦欢绫诲瀷", businessType = BusinessType.INSERT)
+    @RepeatSubmit()
+    @PostMapping()
+    public R<Void> add(@Validated(AddGroup.class) @RequestBody EimsSpareTypeBo bo) {
+        return toAjax(eimsSpareTypeService.insertByBo(bo));
+    }
+
+    /**
+     * 淇敼澶囦欢绫诲瀷
+     */
+    @SaCheckPermission("eims:spareType:edit")
+    @Log(title = "澶囦欢绫诲瀷", businessType = BusinessType.UPDATE)
+    @RepeatSubmit()
+    @PutMapping()
+    public R<Void> edit(@Validated(EditGroup.class) @RequestBody EimsSpareTypeBo bo) {
+        return toAjax(eimsSpareTypeService.updateByBo(bo));
+    }
+
+    /**
+     * 鍒犻櫎澶囦欢绫诲瀷
+     *
+     * @param ids 涓婚敭涓�
+     */
+    @SaCheckPermission("eims:spareType:remove")
+    @Log(title = "澶囦欢绫诲瀷", businessType = BusinessType.DELETE)
+    @DeleteMapping("/{ids}")
+    public R<Void> remove(@NotEmpty(message = "涓婚敭涓嶈兘涓虹┖")
+                          @PathVariable Long[] ids) {
+
+        if (ids == null || ids.length == 0) {
+            return R.warn("璇烽�夋嫨闇�瑕佸垹闄ょ殑鏁版嵁");
+        }
+        for (int i = 0; i < ids.length; i++) {
+            if (eimsSpareTypeService.hasChildBySpareTypeId(ids[i])) {
+                return R.warn("瀛樺湪瀛愯彍鍗�,涓嶅厑璁稿垹闄�");
+            }
+        }
+
+        return toAjax(eimsSpareTypeService.deleteWithValidByIds(List.of(ids), true));
+    }
+}

--
Gitblit v1.9.3