From 057ce688e9fe904c1a74b2505531d5afc7acf43e Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期三, 10 九月 2025 23:03:56 +0800
Subject: [PATCH] 修复bug

---
 src/views/flow/todolist.vue |   72 +++++++++++++++++++----------------
 1 files changed, 39 insertions(+), 33 deletions(-)

diff --git a/src/views/flow/todolist.vue b/src/views/flow/todolist.vue
index e3e2262..8c2579a 100644
--- a/src/views/flow/todolist.vue
+++ b/src/views/flow/todolist.vue
@@ -10,13 +10,13 @@
                 </el-button>
                 <el-button type="primary" :disabled="this.transferTaskSelection.length==0" v-if="permission.manual_dispatch" plain @click="reassign(1)">鎵嬪姩娲惧伐
                 </el-button>
-                <el-button type="primary" :disabled="this.transferTaskSelection.length==0" plain @click="reassign(0)">閲嶆柊鎸囨淳</el-button>
+                <el-button type="primary" :disabled="this.transferTaskSelection.length==0" plain @click="reassign(0)">杞淳</el-button>
                 <el-button type="primary" :disabled="this.transferTaskSelection.length==0" v-if="permission.batch_approve" plain @click="reassign(3)">鎵归噺瀹℃壒
                 </el-button>
             </template>
             <template #menu="scope">
                 <el-button type="primary" text size="default" @click.stop="handleAction(scope.row, scope.index)">
-                    {{scope.row.taskDefinitionKey === 'teamLeaderTask' ? '娲惧伐' : '瀹℃壒'}}
+                    {{approveButtonText(scope.row.taskDefinitionKey)}}
                 </el-button>
             </template>
         </avue-crud>
@@ -26,7 +26,7 @@
         <el-drawer title="瀹℃壒" append-to-body v-model="approveBox" size="100%" v-if="approveBox">
             <div class="approve-box">
                 <div class="left">
-                    <TodolistLeft :row="row" @selection-change="selectionChange" />
+                    <TodolistLeft ref="todolistLeft" :row="row" @selection-change="selectionChange" />
                 </div>
                 <div class="right">
                     <TodolistRightTop :row="row" />
@@ -97,24 +97,7 @@
                             { label: '椹冲洖', value: 'N' },
                         ],
                         rules: [{ required: true, message: '璇烽�夋嫨瀹℃壒缁撴灉', trigger: 'blur' }],
-                    },/*
-                    {
-                        label: '鍙戦�佺粰',
-                        prop: 'assignee',
-                        type: 'select',
-                        props: {
-                            label: 'name',
-                            value: 'id',
-                        },
-                        display: true,
-                        filterable: true,
-                        span: 24,
-                        disabled: false,
-                        dicData: [
-
-                        ],
-                       
-                    },*/
+                    },
                     {
                         label: '鍙戦�佺粰',
                         prop: 'assignee',
@@ -137,7 +120,6 @@
                         span: 24,
                         prop: 'comment',
                         type: 'textarea',
-                        // rules: [{ required: true, message: '璇疯緭鍏ュ鎵规剰瑙�', trigger: 'blur' }],
                         rules: [
                             {
                             validator: (rule, value, callback) => {
@@ -428,7 +410,26 @@
              });
     },
     methods: {
-        
+        approveButtonText(taskDefinitionKey){
+            let lower = taskDefinitionKey.toLowerCase();
+            if(taskDefinitionKey === 'teamLeaderTask') {
+                return '娲惧伐'
+            }else if(taskDefinitionKey == 'unlockProgramConfirm') {
+                //瑙i攣锛岀紪鍒跺鏍�
+                return '澶嶆牳'
+            }else if(taskDefinitionKey == 'programMgrConfirm') {
+                //鍥哄寲锛岀▼搴忕鐞嗗憳纭
+                return '纭'
+            }else if(lower.indexOf('program')>-1) {
+                return '缂栧埗'
+            }else if(lower.indexOf('check')>-1) {
+                return '鏍″'
+            }else if(lower.indexOf('useable')>-1) {
+                return '妫�鏌�'
+            }else{
+                return '瀹℃壒'
+            } 
+        },
         setApproveBtn (row) { // 璁剧疆瀹℃壒缁撴灉鐨勭姸鎬�
             // 1.瀹℃壒鐣岄潰radio鏂囨湰淇敼锛屾櫘閫氳妭鐐圭殑2涓猺adio鏂囨湰 閫氳繃锛坅pprove=Y),涓嶉�氳繃(鐜板湪鐨勯┏鍥�)(approve=N)
             
@@ -500,7 +501,7 @@
                 this.optionApprove.column[1].disabled = false;
                 if (["check", 'cureCheckTask','repalceCheckTask','appendCheckTask'].includes(row.taskDefinitionKey)) {// 鏍″鑺傜偣
                     this.formApprove.assignee = row.variables.senior;
-                } else if (["programmingTask",'cureProgramTask','repalceProgrammingTask','appendProgrammingTask'].includes(row.taskDefinitionKey)) {// 缂栧埗鑺傜偣
+                } else if (["programmingTask",'cureProgramTask','replaceProgrammingTask','appendProgrammingTask'].includes(row.taskDefinitionKey)) {// 缂栧埗鑺傜偣
                     this.formApprove.assignee = row.variables.checker;
                 } else if (row.taskDefinitionKey == "teamLeaderTask") {// 浠诲姟娲惧伐(缁勯暱)
                     this.optionApprove.column[1].disabled = false;
@@ -519,10 +520,12 @@
                 //鏍规嵁鍦ㄧ嚎鏂囨。34琛岋紝'鍙戦�佺粰'鏄鐢紝浣嗘湁榛樿閫夐」
                 this.optionApprove.column[1].disabled = true;
 
-                if (["approveTask", 'seniorApproveTask','replaceApprove','unlockApproveTask','appendApproveTask'].includes(row.taskDefinitionKey)) {
+                if (["approveTask", 'seniorApproveTask','replaceApprove','appendApproveTask'].includes(row.taskDefinitionKey)) {
                     //瀹℃壒鑺傜偣锛屼笉閫氳繃缁欑紪鍒讹細缂栧埗鏄矗浠讳汉锛岀粰瀹為檯缂栫▼鍛�
-                    //this.formApprove.assignee = row.variables.programmer;
                     this.formApprove.assignee = row.variables.actProgrammer;//缁欏疄闄呯紪绋嬪憳
+                }else if(['unlockApproveTask'].includes(row.taskDefinitionKey)){
+                    //瑙i攣楂樺笀瀹℃壒鑺傜偣,涓婁竴姝ユ槸缂栫▼
+                    this.formApprove.assignee = row.variables.programmer;//缁欎富绠″伐鑹�
                 } else if(["check", 'cureCheckTask','repalceCheckTask','appendCheckTask'].includes(row.taskDefinitionKey)){
                     //鏍″鑺傜偣,涓婁竴姝ユ槸缂栫▼
                     //this.formApprove.assignee = row.variables.programmer;
@@ -541,7 +544,7 @@
                 }else if(["confirmIsUseableTask"].includes(row.taskDefinitionKey)) {
                     //鍒ゆ柇鏄惁鍙敤鑺傜偣锛屼笉鍙敤锛岀粰缂栧埗
                     this.formApprove.assignee = row.variables.programmer;
-                }if(['teamLeaderTask','repalceProgrammingTask','unlockProgramConfirm'].includes(row.taskDefinitionKey)){
+                }if(['teamLeaderTask','replaceProgrammingTask','unlockProgramConfirm'].includes(row.taskDefinitionKey)){
                     //鍒濆鑺傜偣涓嶉�氳繃灏辨槸缁撴潫娴佺▼锛屽鐞嗕汉涓虹┖
                     this.formApprove.assignee = '';
                 }
@@ -762,17 +765,20 @@
             //console.log('handleAction', row, index);
         },
         handleSubmit(form, done) {
-            if(this.row.taskDefinitionKey === 'programmingTask') {
-                // if(this.applist.length !== 1) {
-                //     done();
-                //     return this.$message.success('璇烽�夋嫨1涓▼搴�');
-                // }
+            
+            
+            //this.$alert(this.$refs.todolistLeft.programOnMachine)
+            //done();
+            //return;
+            let programOnMachine = 'N'
+            if(this.row.taskDefinitionKey==='programmingTask'){
+                programOnMachine = this.$refs.todolistLeft.programOnMachine?'Y':'N';
             }
             approve({
                 ...this.formApprove,
                 taskId: this.row.taskId,
                 processInstanceId: this.row.processInstanceId,
-                // programIds: this.row.taskDefinitionKey === 'programmingTask' ? this.applist.map(v => v.id).join(',') : '',
+                programOnMachine: programOnMachine
             }).then(res => {
                 if(res.data.code !== 200) {
                     this.$message.error(res.data.msg);

--
Gitblit v1.9.3