From 6ad5c2cdc193cf7bb02884961b7434cd7f607a0d Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期四, 16 四月 2026 10:48:09 +0800
Subject: [PATCH] feat(production): 扩展生产工艺路线支持多产品绑定及工单权限控制

---
 src/main/java/com/ruoyi/production/controller/ProcessRouteItemController.java |   40 +++++++++++++++++++++++++++++++++-------
 1 files changed, 33 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/controller/ProcessRouteItemController.java b/src/main/java/com/ruoyi/production/controller/ProcessRouteItemController.java
index 451548d..b9040de 100644
--- a/src/main/java/com/ruoyi/production/controller/ProcessRouteItemController.java
+++ b/src/main/java/com/ruoyi/production/controller/ProcessRouteItemController.java
@@ -1,29 +1,27 @@
 package com.ruoyi.production.controller;
 
-import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.baomidou.mybatisplus.core.toolkit.Wrappers;
-import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 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.framework.web.domain.R;
 import com.ruoyi.production.dto.ProcessRouteItemDto;
-import com.ruoyi.production.pojo.ProcessRoute;
 import com.ruoyi.production.pojo.ProcessRouteItem;
 import com.ruoyi.production.service.ProcessRouteItemService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.util.CollectionUtils;
+import org.springframework.util.StringUtils;
 import org.springframework.web.bind.annotation.*;
 
 import java.util.Arrays;
 import java.util.List;
+import java.util.stream.Collectors;
 
 @RestController
 @RequestMapping("processRouteItem")
 @Api(tags = "宸ヨ壓璺嚎鏄庣粏")
 public class ProcessRouteItemController {
+
     @Autowired
     private ProcessRouteItemService processRouteItemService;
 
@@ -32,13 +30,14 @@
         return R.ok(processRouteItemService.listProcessRouteItemDto(processRouteItemDto));
     }
 
-    @PostMapping ()
+    @PostMapping
     @ApiOperation("鏂板淇敼")
     public R addOrUpdate(@RequestBody ProcessRouteItem processRouteItem) {
+        normalizeProductBinding(processRouteItem);
         return R.ok(processRouteItemService.saveOrUpdate(processRouteItem));
     }
 
-    @PostMapping ("/sort")
+    @PostMapping("/sort")
     @ApiOperation("鎺掑簭")
     public R sort(@RequestBody ProcessRouteItem processRouteItem) {
         return R.ok(processRouteItemService.sort(processRouteItem));
@@ -50,4 +49,31 @@
     public AjaxResult batchDelete(@PathVariable("id") Long id) {
         return AjaxResult.success(processRouteItemService.batchDelete(id));
     }
+
+    private void normalizeProductBinding(ProcessRouteItem processRouteItem) {
+        if (processRouteItem == null) {
+            return;
+        }
+        String ids = null;
+        List<Long> idList = processRouteItem.getProductModelIdList();
+        if (idList != null && !idList.isEmpty()) {
+            ids = idList.stream()
+                    .filter(item -> item != null && item > 0)
+                    .distinct()
+                    .map(String::valueOf)
+                    .collect(Collectors.joining(","));
+        } else if (StringUtils.hasText(processRouteItem.getProductModelIds())) {
+            ids = Arrays.stream(processRouteItem.getProductModelIds().split(","))
+                    .map(String::trim)
+                    .filter(StringUtils::hasText)
+                    .distinct()
+                    .collect(Collectors.joining(","));
+        } else if (processRouteItem.getProductModelId() != null) {
+            ids = String.valueOf(processRouteItem.getProductModelId());
+        }
+        processRouteItem.setProductModelIds(ids);
+        if (StringUtils.hasText(ids)) {
+            processRouteItem.setProductModelId(Long.valueOf(ids.split(",")[0]));
+        }
+    }
 }

--
Gitblit v1.9.3