From f3f5a0c0db0b782401a9a0fcf6176312f420d941 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期三, 25 三月 2026 14:01:19 +0800
Subject: [PATCH] 军泰伟业 1.不要树形结构。根据图纸编号为唯一索引添加产品并可以导入 2.要求可以上传图纸 3.产品可以绑定工艺路线 4.工艺路线改成由工序组成,新增编辑是工序可以挪动顺序 5.工序添加报工权限字段,可以多选人员

---
 src/views/productionManagement/processRoute/processRouteItem/index.vue |  122 ++++++++++++++++++++++++++++++++++++++++
 1 files changed, 121 insertions(+), 1 deletions(-)

diff --git a/src/views/productionManagement/processRoute/processRouteItem/index.vue b/src/views/productionManagement/processRoute/processRouteItem/index.vue
index 0f0be43..65035ec 100644
--- a/src/views/productionManagement/processRoute/processRouteItem/index.vue
+++ b/src/views/productionManagement/processRoute/processRouteItem/index.vue
@@ -96,6 +96,11 @@
           {{scope.row.isQuality ? "鏄�" : "鍚�"}}
         </template>
       </el-table-column>
+      <el-table-column label="鎶ュ伐鏉冮檺" prop="userPower" min-width="200">
+        <template #default="scope">
+          {{ scope.row.userPower || '-' }}
+        </template>
+      </el-table-column>
       <el-table-column label="鎿嶄綔" align="center" fixed="right" width="150">
         <template #default="scope">
           <el-button type="primary" link size="small" @click="handleEdit(scope.row)" :disabled="scope.row.isComplete">缂栬緫</el-button>
@@ -207,7 +212,22 @@
         </el-form-item>
 
         <el-form-item label="鏄惁璐ㄦ" prop="isQuality">
-          <el-switch v-model="form.isQuality" :active-value="true" inactive-value="false"/>
+          <el-switch v-model="form.isQuality" :active-value="true" :inactive-value="false"/>
+        </el-form-item>
+        <el-form-item label="鎶ュ伐鏉冮檺" prop="userPower" :rules="[{ required: true, message: '璇烽�夋嫨鎶ュ伐鏉冮檺', trigger: 'change' }]">
+          <el-tree-select
+            v-model="form.userPower"
+            :data="staffList"
+            :props="treeProps"
+            placeholder="璇烽�夋嫨浜哄憳"
+            multiple
+            show-checkbox
+            collapse-tags
+            collapse-tags-tooltip
+            style="width: 100%"
+            node-key="id"
+            :render-after-expand="false"
+          />
         </el-form-item>
       </el-form>
 
@@ -232,6 +252,7 @@
 import { findProcessRouteItemList, addOrUpdateProcessRouteItem, sortProcessRouteItem, batchDeleteProcessRouteItem } from "@/api/productionManagement/processRouteItem.js";
 import { findProductProcessRouteItemList, deleteRouteItem, addRouteItem, addOrUpdateProductProcessRouteItem, sortRouteItem } from "@/api/productionManagement/productProcessRoute.js";
 import { processList } from "@/api/productionManagement/productionProcess.js";
+import { listDeptUserTree } from "@/api/basicData/productProcess.js";
 import { useRoute } from 'vue-router'
 import { ElMessageBox } from 'element-plus'
 import Sortable from 'sortablejs'
@@ -263,6 +284,13 @@
 
 const processOptions = ref([]);
 const showProductSelectDialog = ref(false);
+const staffList = ref([]);
+
+const treeProps = {
+  label: 'label',
+  children: 'children',
+};
+
 let tableSortable = null;
 let cardSortable = null;
 
@@ -284,6 +312,7 @@
   model: "",
   unit: "",
   isQuality: false,
+  userPower: [],
 });
 
 const rules = {
@@ -356,6 +385,12 @@
 // 缂栬緫
 const handleEdit = (row) => {
   operationType.value = 'edit';
+  const userPowerNames = row.userPower ? row.userPower.split(',') : [];
+  const userPowerIds = userPowerNames.map(name => {
+    const user = findUserByName(name);
+    return user ? user.id : null;
+  }).filter(id => id !== null);
+  
   form.value = {
     id: row.id,
     routeId: routeId.value,
@@ -365,8 +400,25 @@
     model: row.model || "",
     unit: row.unit || "",
     isQuality: row.isQuality,
+    userPower: userPowerIds,
   };
   dialogVisible.value = true;
+};
+
+const findUserByName = (name) => {
+  const findInTree = (nodes) => {
+    for (const node of nodes) {
+      if (node.isUser && node.label === name) {
+        return node;
+      }
+      if (node.children && node.children.length > 0) {
+        const found = findInTree(node.children);
+        if (found) return found;
+      }
+    }
+    return null;
+  };
+  return findInTree(staffList.value);
 };
 
 // 鍒犻櫎
@@ -415,6 +467,8 @@
     if (valid) {
       submitLoading.value = true;
       
+      const userPowerNames = getAllUserNamesFromSelection(form.value.userPower);
+      
       if (operationType.value === 'add') {
         // 鏂板锛氫紶鍗曚釜瀵硅薄锛屽寘鍚玠ragSort瀛楁
         // dragSort = 褰撳墠鍒楄〃闀垮害 + 1锛岃〃绀烘柊澧炶褰曟帓鍦ㄦ渶鍚�
@@ -428,6 +482,7 @@
               processId: form.value.processId,
               productModelId: form.value.productModelId,
               isQuality: form.value.isQuality,
+              userPower: userPowerNames.join(','),
               dragSort,
             })
           : addOrUpdateProcessRouteItem({
@@ -435,6 +490,7 @@
               processId: form.value.processId,
               productModelId: form.value.productModelId,
               isQuality: form.value.isQuality,
+              userPower: userPowerNames.join(','),
               dragSort,
             });
 
@@ -460,6 +516,7 @@
               processId: form.value.processId,
               productModelId: form.value.productModelId,
               isQuality: form.value.isQuality,
+              userPower: userPowerNames.join(','),
             })
           : addOrUpdateProcessRouteItem({
               routeId: routeId.value,
@@ -467,6 +524,7 @@
               productModelId: form.value.productModelId,
               id: form.value.id,
               isQuality: form.value.isQuality,
+              userPower: userPowerNames.join(','),
             });
 
         updatePromise
@@ -640,8 +698,70 @@
   getRouteInfo();
   getList();
   getProcessList();
+  getStaffList();
 });
 
+const getStaffList = () => {
+  listDeptUserTree().then(res => {
+    const buildTree = (nodes) => {
+      return nodes.map(node => {
+        const deptNode = {
+          id: `dept_${node.deptId}`,
+          label: node.deptName,
+          isUser: false,
+          children: []
+        };
+        
+        if (node.userList && node.userList.length > 0) {
+          node.userList.forEach(user => {
+            deptNode.children.push({
+              id: user.userId,
+              label: user.nickName || user.userName,
+              isUser: true,
+              userName: user.userName,
+              nickName: user.nickName
+            });
+          });
+        }
+        
+        if (node.childrenList && node.childrenList.length > 0) {
+          const childNodes = buildTree(node.childrenList);
+          deptNode.children = deptNode.children.concat(childNodes);
+        }
+        
+        return deptNode;
+      });
+    };
+    staffList.value = buildTree(res.data || []);
+  }).catch(() => {
+    staffList.value = [];
+  });
+};
+
+const getAllUserNamesFromSelection = (selectedIds) => {
+  const names = [];
+  const processNode = (node) => {
+    if (selectedIds.includes(node.id)) {
+      if (node.isUser) {
+        names.push(node.label);
+      } else {
+        if (node.children && node.children.length > 0) {
+          node.children.forEach(child => {
+            if (child.isUser) {
+              names.push(child.label);
+            }
+          });
+        }
+      }
+    }
+    if (node.children && node.children.length > 0) {
+      node.children.forEach(child => processNode(child));
+    }
+  };
+  staffList.value.forEach(node => processNode(node));
+  return [...new Set(names)];
+};
+
 onUnmounted(() => {
   destroySortable();
 });

--
Gitblit v1.9.3