From 729b698b17d7468acbc6c495746a72c9150fdaeb Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期二, 09 九月 2025 11:49:47 +0800
Subject: [PATCH] 按钮改名下传

---
 src/views/flowmgr/taskassign.vue |  191 +++++++++++++++++++++++++++++++++++++----------
 1 files changed, 149 insertions(+), 42 deletions(-)

diff --git a/src/views/flowmgr/taskassign.vue b/src/views/flowmgr/taskassign.vue
index 83f95b7..66c4599 100644
--- a/src/views/flowmgr/taskassign.vue
+++ b/src/views/flowmgr/taskassign.vue
@@ -8,13 +8,29 @@
 -->
 <template>
   <basic-container>
-    <avue-form ref="form" :option="attachOption" v-model="attachForm" @submit="formSubmit">
+    <avue-form ref="form" :option="attachOption" v-model="attachForm" @submit="formSubmit"><!-- -->
       <template #machineCode="{}">
         <el-tree-select ref="tree" filterable  v-model="attachForm.machineCode"
          node-key="machineCode"
           :data="treeData" :props="defaultProps">
           </el-tree-select>
       </template>
+      <template #drawingNo="{}">
+        <el-autocomplete   v-model="attachForm.drawingNo"
+        :fetch-suggestions="querySearchAsync"
+        :trigger-on-focus="false" @select="handleSelect"
+          >
+        </el-autocomplete>
+      </template>
+
+      <template #programmer="{}">
+        <el-autocomplete ref="autoProgrammer" :disabled="drawingNoMatch"  v-model="attachForm.programmer"
+        :fetch-suggestions="queryProgrammerAsync"
+        :trigger-on-focus="false" @select="handleProgrammerSelect"
+          >
+        </el-autocomplete>
+      </template>
+
     </avue-form>
   </basic-container>
 </template>
@@ -29,6 +45,8 @@
     'attachForm.drawingNo': function (val) {
       if(val && this.attachForm.processNo && this.attachForm.processEdition) {
         this.attachForm.title = `${val}-${this.attachForm.processNo}-${this.attachForm.processEdition}-璁″垝浠诲姟`;
+
+        
       }
     },
     'attachForm.processNo': function (val) {
@@ -45,10 +63,6 @@
     },
   },
   data() {
-    
-    //var isTempFlow = getQueryString("isTempFlow");
-    //isTempFlow = isTempFlow === 'Y'?'Y':'N';
-    
     var that = this;
     return {
       form: {},
@@ -60,7 +74,8 @@
         disabled: (data) => data.nodeType!=='machine',//浠呮満搴婅妭鐐瑰彲閫�
         isLeaf: (data) => !data.hasChildren
       },
-
+      timeout:0, //闆朵欢鍙峰姞杞界殑timeout
+      drawingNoMatch:true,//闆朵欢鍙锋槸鍚﹀尮閰嶅垎宸ヨ〃
       attachOption: {
         labelWidth: 160,
         submitBtn: true,
@@ -82,12 +97,13 @@
             span: 12,
             dataType: 'string',
             blur: (col) => {
-              this.handleTrim(col)
+              this.handleTrim(col);
+              
             },
             rules: [{ required: true, message: '蹇呭~', trigger: 'blur' }],
           },
           {
-            label: '鍥惧彿鐗堟',
+            label: '鍥剧焊鐗堟',
             prop: 'drawingNoEdition',
             type: 'input',
             span: 12,
@@ -146,7 +162,7 @@
           {
             label: '鎵规鍙�',
             prop: 'craftEdition',
-            placeholder:'濡�"A"',
+            placeholder:'濡�"2S24001"',
             type: 'input',
             span: 12,
             dataType: 'string',
@@ -155,29 +171,12 @@
               this.handleTrim(col)
             },
           },
-          /*{
-            label: '鍔犲伐鏈哄簥',
-            prop: 'machineCode',
-            type: 'select',
-			      filterable: true,
-            dicUrl: `/blade-mdm/machine/page?size=10000`,
-            dicFormatter: function (res) {
-              that.machineCodeList = res.data.records;
-              return res.data.records;
-            },
-            rules: [{ required: true, message: '蹇呭~', trigger: 'blur' }],
-            props: {
-              label: 'code',
-              value: 'code',
-            },
-            span: 12
-          },*/
+          
           {
             label: '鍔犲伐鏈哄簥',
             prop: 'machineCode',
             type: 'select',
             rules: [{ required: true, message: '蹇呭~', trigger: 'blur' }],
-            
             span: 12
           },
           {
@@ -209,12 +208,20 @@
             span: 12,
             dataType: 'string',
             class:'input_holder_warn',
-            placeholder:'闈炲亸绂诲崟浠诲姟璇风暀绌�',
+            placeholder:'鏃犲亸绂诲崟浠诲姟璇风暀绌�',
             blur: (col) => {
               this.handleTrim(col)
             },
             // rules: [{ required: true, message: '蹇呭~', trigger: 'blur' }],
-          }
+          },
+          {
+            label: '涓荤宸ヨ壓',
+            prop: 'programmer',
+            type: 'input',//column 12
+            disabled:true,
+            span: 12,
+            dataType: 'string',
+          },
         ],
       },
       attachForm: {planLockDays:7,planStartTime: this.$dayjs().format('YYYY-MM-DD')},//榛樿7澶�
@@ -269,6 +276,68 @@
       return node;
     },
     
+    querySearchAsync(query, cb) {//闆剁粍浠跺彿鎼滅储寤鸿
+      axios({
+        url: '/blade-mdm/producedivision/select-data',
+        method: 'get',
+        params: {drawingNo: query},
+      }).then(
+        res => {
+          if(res.data.code == 200){
+            let list = res.data.data;
+            for(let i of list){
+              i.value = i.ljh;
+            }
+
+            clearTimeout(this.timeout)
+            this.timeout = setTimeout(() => {
+              cb(list);
+            }, 1000)
+            
+          }
+        },
+        error => {
+          console.log(error);
+        }
+      );
+      
+    },
+    handleSelect(item) {
+      this.attachForm.productModel = item.cph;
+    },
+
+    queryProgrammerAsync(query, cb) {//涓荤宸ヨ壓鎼滅储寤鸿
+      axios({
+        url: '/blade-mdm/producedivision/select-programmer',
+        method: 'get',
+        params: {programmer: query},
+      }).then(
+        res => {
+          if(res.data.code == 200){
+            let list = res.data.data;
+            for(let i of list){
+              i.value = '涓荤宸ヨ壓锛�'+i.programmerName+',鏍″锛�'+i.checkerName;
+            }
+
+            clearTimeout(this.timeout)
+            this.timeout = setTimeout(() => {
+              cb(list);
+            }, 600)
+            
+          }
+        },
+        error => {
+          console.log(error);
+        }
+      );
+      
+    },
+    handleProgrammerSelect(item){
+      this.attachForm.producePlanId = item.id;
+      this.attachForm.planDrawingNo = this.attachForm.drawingNo;//璁板綍姝ゆ椂鐨勯浂缁勪欢鍙�
+      console.log('productid',this.attachForm )
+
+    },
     handleTrim(col){
       //console.log(col)
       let value = this.attachForm[col.column.prop];
@@ -283,25 +352,63 @@
     },
     formSubmit(form, done) {
       var form = { ...form };
-      /*
-      this.machineCodeList.forEach(item => {
-        if (form.machineCode == item.code) {
-          form.machineMode = item.name;
-        }
-      })
-      */
+      console.log('submit',form);
+      if(this.attachForm.planDrawingNo == this.attachForm.drawingNo && this.attachForm.producePlanId){
+        //鎵嬪姩鎸囧畾浜嗕汉鍛樿亴璐h〃id锛屼笉鐢ㄧ户缁粠鏈嶅姟绔獙璇�
+         this.startDispatch(form,done);
+      }else{
+        axios({
+          url: '/blade-mdm/producedivision/select-by-drawingno',
+          method: 'get',
+          params: {drawingNo:this.attachForm.drawingNo},
+        }).then(
+          res => {
+            
+            if(res.data.code == 200){
+              this.$message({
+                type: 'success',
+                message: '鎿嶄綔鎴愬姛!',
+              });
+            
+              this.attachForm.producePlanId = res.data.data.id;
+              this.drawingNoMatch = true;
+              console.log('planid',this.attachForm.productPlanId)
+              this.startDispatch(form,done);
+            }else{
+              this.drawingNoMatch = false;
+             
+              this.$alert(res.data.msg+".鎴栬�呮墜鍔ㄩ�夋嫨涓荤宸ヨ壓銆�", '鍙戣捣浠诲姟澶辫触',{type:'error',confirmButtonText:'鍏抽棴'});
+            }
+            done();
+          },
+          error => {
+            console.log(error);
+            done();
+          }
+        );
+      }
+      
+    },
+    startDispatch(form,done){
+      //楠岃瘉閮介�氳繃浜嗭紝鎵ц鍚姩娴佺▼
       axios({
         url: '/blade-mdm/flow/dispatch/start',
         method: 'post',
         data: form,
       }).then(
         res => {
-          this.$message({
-            type: 'success',
-            message: '鎿嶄綔鎴愬姛!',
-          });
-          this.$refs.form.resetForm();
-          this.attachForm = this.defaultForm;
+          
+          if(res.data.code == 200){
+            this.$message({
+              type: 'success',
+              message: '鎿嶄綔鎴愬姛!',
+            });
+            this.$refs.form.resetForm();
+            this.attachForm = this.defaultForm;
+            this.drawingNoMatch = true;
+          }else{
+            this.$alert(res.data.msg, '鍙戣捣浠诲姟澶辫触',{type:'error',confirmButtonText:'鍏抽棴'});
+          }
           done();
         },
         error => {

--
Gitblit v1.9.3