From f68d79d0ff6658795c19c2fd473fab9ff6f0640d Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期六, 14 三月 2026 13:53:12 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_宁夏_中盛建材' into dev_宁夏_中盛建材

---
 src/main/java/com/ruoyi/production/controller/ProductMaterialController.java |   73 ++++++++++++++++++++++++++++++------
 1 files changed, 61 insertions(+), 12 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/controller/ProductMaterialController.java b/src/main/java/com/ruoyi/production/controller/ProductMaterialController.java
index e95379f..21eddbc 100644
--- a/src/main/java/com/ruoyi/production/controller/ProductMaterialController.java
+++ b/src/main/java/com/ruoyi/production/controller/ProductMaterialController.java
@@ -1,22 +1,22 @@
 package com.ruoyi.production.controller;
 
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.basic.pojo.ProductModel;
 import com.ruoyi.framework.aspectj.lang.annotation.Log;
 import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
 import com.ruoyi.framework.web.domain.AjaxResult;
+import com.ruoyi.production.dto.ProductMaterialConfigDto;
+import com.ruoyi.production.dto.ProductMaterialGroupDto;
 import com.ruoyi.production.pojo.ProductMaterial;
+import com.ruoyi.production.pojo.ProductMaterialConfig;
+import com.ruoyi.production.service.ProductMaterialConfigService;
 import com.ruoyi.production.service.ProductMaterialService;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.DeleteMapping;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.PutMapping;
-import org.springframework.web.bind.annotation.RequestBody;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.bind.annotation.*;
 
 import java.util.List;
-import java.util.Map;
 
 /**
  * <br>
@@ -34,6 +34,9 @@
     @Autowired
     private ProductMaterialService productMaterialService;
 
+    @Autowired
+    private ProductMaterialConfigService productMaterialConfigService;
+
     @GetMapping("/loadData")
     @ApiOperation("鎷夊彇鐗╂枡缂栫爜鏁版嵁")
     @Log(title = "鎷夊彇鐗╂枡缂栫爜鏁版嵁", businessType = BusinessType.INSERT)
@@ -43,10 +46,18 @@
     }
 
     @GetMapping("/list")
-    @ApiOperation("鐗╂枡鏁版嵁")
-    @Log(title = "鐗╂枡鏁版嵁", businessType = BusinessType.OTHER)
-    public AjaxResult productMaterialList(String materialName) {
-        Map<String, List<ProductMaterial>> productMaterialMap = productMaterialService.ProductMaterialList(materialName);
+    @ApiOperation("鐗╂枡鏁版嵁绫诲埆鏁版嵁闆嗗悎")
+    @Log(title = "鐗╂枡鏁版嵁绫诲埆鏁版嵁闆嗗悎", businessType = BusinessType.OTHER)
+    public AjaxResult productMaterialList(@RequestParam("type") Integer type) {
+        List<ProductMaterialGroupDto> productMaterialMap = productMaterialService.ProductMaterialList(type);
+        return AjaxResult.success(productMaterialMap);
+    }
+
+    @GetMapping("/listQuery")
+    @ApiOperation("鐗╂枡鏁版嵁绫诲埆瀛愮被鏁版嵁闆嗗悎")
+    @Log(title = "鐗╂枡鏁版嵁绫诲埆瀛愮被鏁版嵁闆嗗悎", businessType = BusinessType.OTHER)
+    public AjaxResult productMaterialListByQuery(@RequestParam(value = "materialName", required = false) String materialName, @RequestParam(value = "materialTypeId", required = false) Integer materialTypeId) {
+        List<ProductMaterialGroupDto> productMaterialMap = productMaterialService.productMaterialListByQuery(materialName, materialTypeId);
         return AjaxResult.success(productMaterialMap);
     }
 
@@ -75,5 +86,43 @@
     }
 
 
+    @GetMapping("/materialTypeList")
+    @ApiOperation("鐗╂枡绫诲瀷鏁版嵁闆嗗悎")
+    @Log(title = "鐗╂枡绫诲瀷鏁版嵁闆嗗悎", businessType = BusinessType.OTHER)
+    public AjaxResult materialTypeList() {
+        List<ProductMaterialConfig> list = productMaterialConfigService.materialTypeList();
+        return AjaxResult.success(list);
+    }
 
+    @GetMapping("/inventoryCategoryList")
+    @ApiOperation("'瀛樿揣绫诲埆鏁版嵁闆嗗悎")
+    @Log(title = "'瀛樿揣绫诲埆鏁版嵁闆嗗悎", businessType = BusinessType.OTHER)
+    public AjaxResult inventoryCategoryList() {
+        List<ProductMaterialConfig> list = productMaterialConfigService.inventoryCategoryList();
+        return AjaxResult.success(list);
+    }
+
+    @PostMapping("/config/add")
+    @ApiOperation("鏂板鐗╂枡閰嶇疆")
+    @Log(title = "鏂板鐗╂枡閰嶇疆", businessType = BusinessType.INSERT)
+    public AjaxResult addProductMaterialConfig(@RequestBody ProductMaterialConfigDto config) {
+        productMaterialConfigService.addProductMaterialConfig(config);
+        return AjaxResult.success();
+    }
+
+    @PutMapping("/config/update")
+    @ApiOperation("淇敼鐗╂枡閰嶇疆")
+    @Log(title = "淇敼鐗╂枡閰嶇疆", businessType = BusinessType.UPDATE)
+    public AjaxResult updateProductMaterialConfig(@RequestBody ProductMaterialConfigDto config) {
+        productMaterialConfigService.updateProductMaterialConfig(config);
+        return AjaxResult.success();
+    }
+
+    @DeleteMapping("/config/delete")
+    @ApiOperation("鍒犻櫎鐗╂枡閰嶇疆")
+    @Log(title = "鍒犻櫎鐗╂枡閰嶇疆", businessType = BusinessType.DELETE)
+    public AjaxResult deleteProductMaterialConfig(@RequestBody List<Integer> ids) {
+        productMaterialConfigService.deleteProductMaterialConfig(ids);
+        return AjaxResult.success();
+    }
 }

--
Gitblit v1.9.3