From 729bb3b1bac72bd760638e6329ba77cf1a8fb43f Mon Sep 17 00:00:00 2001
From: loulijun2021 <1694218219@qq.com>
Date: 星期六, 07 十月 2023 15:16:05 +0800
Subject: [PATCH] 1.工序报工100%

---
 src/views/produce/stepReport.vue |  113 ++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 89 insertions(+), 24 deletions(-)

diff --git a/src/views/produce/stepReport.vue b/src/views/produce/stepReport.vue
index 055d33e..1275cd3 100644
--- a/src/views/produce/stepReport.vue
+++ b/src/views/produce/stepReport.vue
@@ -8,6 +8,7 @@
           v-waves
           icon="el-icon-thumb"
           type="primary"
+          :disabled="radioSelected===''"
           @click="report()"
         >鎶ュ伐
         </el-button>
@@ -16,7 +17,8 @@
           v-waves
           type="primary"
           icon="el-icon-thumb"
-          @click="sendOut"
+          :disabled="radioSelected===''"
+          @click="sendOut()"
         >鍙戞枡
         </el-button>
         <el-button
@@ -24,7 +26,8 @@
           v-waves
           type="primary"
           icon="el-icon-thumb"
-          @click="takeIn"
+          :disabled="radioSelected===''"
+          @click="takeIn()"
         >鏀舵枡
         </el-button>
         <el-button
@@ -32,7 +35,8 @@
           v-waves
           type="primary"
           icon="el-icon-thumb"
-          @click="handleBad"
+          :disabled="radioSelected===''"
+          @click="handleBad()"
         >澶勭悊
         </el-button>
       </div>
@@ -69,10 +73,20 @@
                   />
                 </el-form-item>
                 <el-form-item label="浜у搧缂栫爜" style=" display: flex;">
-                  <el-input v-model="form.partcode" placeholder="璇疯緭鍏�" style="width: 200px" />
+                  <el-input
+                    v-model="form.partcode"
+                    placeholder="璇疯緭鍏�"
+                    style="width: 200px"
+                    @keyup.enter.native="val=>enterNative(val,'produceCode' + item.code)"
+                  />
                 </el-form-item>
                 <el-form-item label="浜у搧鍚嶇О" style=" display: flex;">
-                  <el-input v-model="form.partname" placeholder="璇疯緭鍏�" style="width: 200px" />
+                  <el-input
+                    v-model="form.partname"
+                    placeholder="璇疯緭鍏�"
+                    style="width: 200px"
+                    @keyup.enter.native="val=>enterNative(val,'produceCode' + item.code)"
+                  />
                 </el-form-item>
                 <!--                <el-form-item label="瑙勬牸鍨嬪彿" style=" display: flex;">-->
                 <!--                  <el-input v-model="form.partspec" placeholder="璇疯緭鍏�" style="width: 200px" />-->
@@ -161,7 +175,7 @@
               <el-table-column
                 prop="wo_code"
                 label="宸ュ崟鍙�"
-                width="160"
+                min-width="160"
                 show-tooltip-when-overflow
                 sortable="custom"
               />
@@ -302,7 +316,8 @@
       @close="handleClose"
     >
       <el-form ref="dialogForm" inline :rules="dialogFormRules" :model="dialogForm" label-width="110px">
-        <el-divider v-if="activeName==='鐢熶骇鍒楄〃'||activeName==='澶栧崗鏀舵枡'||activeName==='涓嶈壇寰呭鐞�'" content-position="left">鍩烘湰淇℃伅</el-divider>
+        <el-divider v-if="activeName==='鐢熶骇鍒楄〃'||activeName==='澶栧崗鏀舵枡'||activeName==='涓嶈壇寰呭鐞�'" content-position="left">鍩烘湰淇℃伅
+        </el-divider>
         <el-form-item label="宸ュ崟缂栧彿" class="dialogFormItem">
           <div class="dialogFormItemDiv">{{ dialogForm.wo_code }}</div>
         </el-form-item>
@@ -313,13 +328,13 @@
           <div class="dialogFormItemDiv">{{ dialogForm.partname }}</div>
         </el-form-item>
         <el-form-item label="瑙勬牸鍨嬪彿" class="dialogFormItem">
-          <div class="dialogFormItemDiv">{{ dialogForm.partspec }}</div>
+          <div class="dialogFormItemDiv">{{ dialogForm.partspec? dialogForm.partspec:'/' }}</div>
         </el-form-item>
         <el-form-item label="褰撳墠宸ュ簭" class="dialogFormItem">
           <div class="dialogFormItemDiv">{{ dialogForm.stepname }}</div>
         </el-form-item>
         <el-form-item label="涓嬮亾宸ュ簭" class="dialogFormItem">
-          <div class="dialogFormItemDiv">{{ dialogForm.nextstepname }}</div>
+          <div class="dialogFormItemDiv">{{ dialogForm.nextstepname?dialogForm.nextstepname :'/' }}</div>
         </el-form-item>
         <el-form-item label="浠诲姟鏁伴噺" class="dialogFormItem">
           <div class="dialogFormItemDiv">{{ dialogForm.planqty }}</div>
@@ -487,6 +502,7 @@
         <el-table
           v-if="activeName==='鐢熶骇鍒楄〃'||activeName==='澶栧崗鏀舵枡'"
           ref="defectTableDataRef"
+          key="defectTableDataKey"
           :data="defectTableData"
           border
           row-class-name="custom-row"
@@ -575,12 +591,13 @@
           <div
             style="color: #fff;width: 22px;height: 22px;display: flex;justify-content: center;align-items: center;border-radius: 50%"
             :style="{backgroundColor:$store.state.settings.theme}"
-          >{{ index+1 }}</div>
+          >{{ index + 1 }}
+          </div>
           <div style="margin-left:30px;width: 160px;" class="ellipsis">
             {{ item.tp }}
           </div>
           <div style="margin-left:30px;">
-            鍙敹鏁伴噺锛歿{ item.fqty }}
+            鍙敹鏁伴噺锛歿{ item.acceptQty }}
           </div>
         </div>
 
@@ -588,6 +605,7 @@
         <el-table
           v-if="activeName==='涓嶈壇寰呭鐞�'"
           ref="badTableDataDataRef"
+          key="badTableDataDataKey"
           :data="badTableData"
           border
           row-class-name="custom-row"
@@ -751,6 +769,7 @@
 import elDragDialog from '@/directive/el-drag-dialog'
 import waves from '@/directive/waves'
 import {
+  EditOrderNgStepSeave,
   MesOrderNgStepSearch,
   MesOrderNgSubStepSearch,
   MesOrderStepSearch, MesOrderStepStart,
@@ -934,7 +953,7 @@
           break
       }
       this.enterNative(this.form.wocode, belong)
-      this.search()
+      // this.search()
       this.radioSelected = ''
     },
     enterNative(val, belong) {
@@ -958,6 +977,7 @@
           $('input[name=\'produceCodeBAD\']')[0].focus()
         })
       }
+      this.search()
     },
     // 鎺掑簭鏀瑰彉鏃�
     sortChange({ column, prop, order }) {
@@ -1021,8 +1041,8 @@
     // 涓嶈壇澶勭悊    鐢熶骇寮�鎶ュ伐鎵爜鑾峰彇宸ュ崟瀵瑰簲宸ュ簭浠诲姟(涓嶈壇鏄庣粏)
     async handleBad(row) {
       const data = {
-        wocode: row.wo_code,
-        stepcode: row.stepcode
+        wocode: row ? row.wo_code : this.tableData.find(i => i.id === this.radioSelected).wo_code,
+        stepcode: row ? row.stepcode : this.tableData.find(i => i.id === this.radioSelected).stepcode
       }
       let res = await MesOrderNgSubStepSearch(data)
       if (res.code === '200') {
@@ -1049,13 +1069,13 @@
         this.dialogForm.eqpcode = res.data1.eqpcode
         this.dialogForm.eqpname = res.data1.eqpname
 
-        this.badTableData = res.data2
-
-        // 涓嬪懆鍥炴潵鍐欎笉鑹鐞嗕繚瀛樻帴鍙�
-        this.badTableData.forEach(item => {
+        res.data2.forEach(item => {
           item.repair_qty = 0
-          item.bad_qty = 0
+          item.laborbad_qty = 0
+          item.materielbad_qty = 0
         })
+
+        this.badTableData = res.data2
 
         this.dialogVisible = true
       }
@@ -1090,7 +1110,15 @@
         this.dialogForm.eqpcode = res.eqpcode
         this.dialogForm.eqpname = res.eqpname
 
-        this.dialogForm.list = res.list
+        this.dialogForm.list = []
+        res.list.forEach(i => {
+          i.acceptQty = parseFloat(i.fqty) - parseFloat(i.sqty) - parseFloat(i.ng_qty) - parseFloat(i.laborbad_qty) - parseFloat(i.materielbad_qty)
+          if (i.acceptQty > 0) {
+            this.dialogForm.list.push(i)
+          }
+        })
+
+        // this.dialogForm.list = res.list
 
         this.dialogVisible = true
       }
@@ -1209,7 +1237,8 @@
             const res = await SavaMesOrderStepReport(data)
             if (res.code === '200') {
               this.$notify.success('鎶ュ伐鎴愬姛锛�')
-              await this.search()
+              // await this.search()
+              await this.tabClick()
               this.$store.state.app.buttonIsDisabled = false
               this.dialogVisible = false
             } else {
@@ -1221,6 +1250,9 @@
           if (this.activeName === '澶栧崗鍙戞枡') {
             if (parseFloat(this.dialogForm.fqty) < 1) {
               return this.$message.info('鍙戞枡鏁伴噺涓嶈兘涓洪浂锛�')
+            }
+            if (parseFloat(this.dialogForm.fqty) > parseFloat(this.dialogForm.noreportqty)) {
+              return this.$message.info('鍙戞枡鏁伴噺涓嶈兘澶т簬鏈彂鏁伴噺!')
             }
             const data = {
               mesordercode: this.dialogForm.wo_code,
@@ -1239,7 +1271,8 @@
             const res = await SavaMesOrderStepOut(data)
             if (res.code === '200') {
               this.$notify.success('鍙戞枡鎴愬姛锛�')
-              await this.search()
+              // await this.search()
+              await this.tabClick()
               this.$store.state.app.buttonIsDisabled = false
               this.dialogVisible = false
             } else {
@@ -1261,7 +1294,7 @@
             }
 
             if (this.dialogForm.list.find(i => i.name === this.dialogForm.wxcode)) {
-              if (this.dialogForm.list.find(i => i.name === this.dialogForm.wxcode).fqty < parseFloat(this.dialogForm.sqty) + parseFloat(this.dialogForm.noputqty)) {
+              if (this.dialogForm.list.find(i => i.name === this.dialogForm.wxcode).acceptQty < parseFloat(this.dialogForm.sqty) + parseFloat(this.dialogForm.noputqty)) {
                 return this.$message.info('鏀舵枡鏁伴噺鍔犱笉鑹暟閲忎笉鑳藉ぇ浜庤渚涘簲鍟嗗彲鏀舵暟閲�!')
               }
             } else {
@@ -1307,12 +1340,37 @@
             const res = await SavaMesOrderStepIn(data)
             if (res.code === '200') {
               this.$notify.success('鏀舵枡鎴愬姛锛�')
-              await this.search()
+              // await this.search()
+              await this.tabClick()
               this.$store.state.app.buttonIsDisabled = false
               this.dialogVisible = false
             } else {
               this.$store.state.app.buttonIsDisabled = false
               this.$notify.error('鏀舵枡澶辫触锛�')
+            }
+          }
+
+          if (this.activeName === '涓嶈壇寰呭鐞�') {
+            let flag = false
+            this.badTableData.forEach(i => {
+              if (parseFloat(i.repair_qty) + parseFloat(i.laborbad_qty) + parseFloat(i.materielbad_qty) > parseFloat(i.ng_qty)) {
+                flag = true
+              }
+            })
+            if (flag) {
+              return this.$message.info('缁翠慨鍚堟牸鏁伴噺+宸ュ簾鏁伴噺+鏂欏簾鏁伴噺涓嶈兘澶т簬涓嶈壇鏁伴噺锛�')
+            }
+            this.$store.state.app.buttonIsDisabled = true
+            const res = await EditOrderNgStepSeave({ Data: this.badTableData })
+            if (res.code === '200') {
+              this.$notify.success('鎻愪氦鎴愬姛锛�')
+              // await this.search()
+              await this.tabClick()
+              this.$store.state.app.buttonIsDisabled = false
+              this.dialogVisible = false
+            } else {
+              this.$store.state.app.buttonIsDisabled = false
+              this.$notify.error('鎻愪氦澶辫触锛�')
             }
           }
         }
@@ -1371,6 +1429,7 @@
       this.form.partcode = ''
       this.form.partname = ''
       this.form.partspec = ''
+      this.search()
     },
 
     headerCellStyle() {
@@ -1396,4 +1455,10 @@
   width: 200px;
 }
 
+::v-deep .el-select__caret {
+  display: flex;
+  align-items: center;
+  justify-content: center;
+}
+
 </style>

--
Gitblit v1.9.3