From a6a4092ce1899bd020bc15cff43f0977c87e6be8 Mon Sep 17 00:00:00 2001
From: zouyu <2723363702@qq.com>
Date: 星期五, 15 九月 2023 16:20:25 +0800
Subject: [PATCH] Merge branch 'master' of http://192.168.0.22:9001/r/mom-before

---
 src/components/view/processInspectionUpdate.vue |  167 ++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 114 insertions(+), 53 deletions(-)

diff --git a/src/components/view/processInspectionUpdate.vue b/src/components/view/processInspectionUpdate.vue
index decd795..1e40e84 100644
--- a/src/components/view/processInspectionUpdate.vue
+++ b/src/components/view/processInspectionUpdate.vue
@@ -103,8 +103,8 @@
             > -->
                 </el-col>
             </el-row>
-            <el-table :data="inspectionItems" max-height="420" :span-method="handleSpanMethod" height="calc(100vh - 550px)"
-                style="width: 100%">
+            <el-table border :data="inspectionItems"  max-height="420" :span-method="handleSpanMethod"
+                height="calc(100vh - 550px)" style="width: 100%">
                 <el-table-column type="index" label="搴忓彿" width="60"></el-table-column>
                 <el-table-column label="椤圭洰" prop="father"></el-table-column>
                 <el-table-column prop="name" label="鎸囨爣"></el-table-column>
@@ -123,9 +123,16 @@
                 </el-table-column>
                 <el-table-column prop="dname" label="璇曢獙璁惧" min-width="100">
                     <template slot-scope="scope">
-                        <el-button type="text" @click="clickTableSelect(scope)">{{
+                        <el-col>
+                            <el-button v-if="!scope.row.isSelectDevice" type="text" @click="clickTableSelect(scope)">{{
                             scope.row.dname == null ? "璇烽�夋嫨" : scope.row.dname
                         }}</el-button>
+                        <el-select @blur="blurNode(scope)" v-else-if="scope.row.isSelectDevice" style="width: 100%;" @change="clickNodeSure(scope.row)"
+                            v-model="filterText" placeholder="璇烽�夋嫨">
+                            <el-option v-for="item in materialOptions" :key="item.id" :label="item.device" :value="item.id">
+                            </el-option>
+                        </el-select>
+                        </el-col>
                     </template>
                 </el-table-column>
                 <el-table-column label="缁撹">
@@ -156,8 +163,9 @@
                     </template>
                 </el-table-column>
                 <el-table-column prop="operation" label="涓婃姤">
-                    <template slot-scope="scope"> 
-                        <el-button v-if="scope.row.conclusion === null || scope.row.conclusion === undefined" type="primary" @click="escalation" size="small">涓婃姤</el-button>
+                    <template slot-scope="scope">
+                        <el-button v-if="scope.row.conclusion === null || scope.row.conclusion === undefined" type="primary"
+                            @click="escalation" size="small">涓婃姤</el-button>
                         <el-button v-else type="success" size="small">宸蹭笂鎶�</el-button>
                     </template>
                 </el-table-column>
@@ -165,22 +173,15 @@
         </div>
         <el-dialog title="璇烽�夋嫨璁惧" :visible.sync="centerDialogVisible" width="20%">
             <div class="div_device_dialog">
-                <el-input placeholder="杈撳叆鍏抽敭瀛楄繘琛岃繃婊�" v-model="filterText" style="margin-bottom: 6px;">
-                </el-input>
-                <el-tree class="filter-tree" :data="materialOptions" :props="defaultProps" default-expand-all
-                    highlight-current @node-click="nodeClick" :filter-node-method="filterNode" ref="tree">
-                    <div class="custom-tree-node" slot-scope="{ data }">
-                        <span><i :class="`node_i ${data.children ? 'el-icon-folder-opened' : 'el-icon-tickets'
-                            }`
-                            "></i>
-                            {{ data.name }}</span>
-                    </div>
-                </el-tree>
+                <!-- <el-select style="width: 100%;" @change="clickNodeSure()" v-model="filterText" placeholder="璇烽�夋嫨">
+                    <el-option v-for="item in materialOptions" :key="item.id" :label="item.device" :value="item.id">
+                    </el-option>
+                </el-select> -->
             </div>
-            <span slot="footer" class="dialog-footer">
+            <!-- <span slot="footer" class="dialog-footer">
                 <el-button @click="centerDialogVisible = false">鍙� 娑�</el-button>
                 <el-button type="primary" @click="clickNodeSure()">纭� 瀹�</el-button>
-            </span>
+            </span> -->
         </el-dialog>
     </div>
 </template>
@@ -266,21 +267,24 @@
                 children: "children",
                 label: "name"
             },
-            nodeData: "", // node鐐瑰嚮淇濆瓨褰撳墠鐐瑰嚮鏁版嵁
+            nodeData: {
+                id: 0,
+                name: null
+            }, // node鐐瑰嚮淇濆瓨褰撳墠鐐瑰嚮鏁版嵁
             clickSelectDevice: {
-                index: "", // 鐐瑰嚮閫夋嫨瀛樺偍褰撳墠琛岀储寮�
-                rpId: "" // 鐐瑰嚮閫夋嫨瀛樺偍褰撳墠琛岄」鐩甀d
+                index: null, // 鐐瑰嚮閫夋嫨瀛樺偍褰撳墠琛岀储寮�
+                rpId: null // 鐐瑰嚮閫夋嫨瀛樺偍褰撳墠琛岄」鐩甀d
             }
         };
     },
     watch: {
-        filterText(val) {
-            this.$refs.tree.filter(val);
-        }
+        // filterText(val) {
+        //     this.$refs.tree.filter(val);
+        // }
     },
     created() {
-        if(this.rowInfo.result!=null&&this.rowInfo.result!=''){
-            this.isUpBtn=true
+        if (this.rowInfo.result != null && this.rowInfo.result != '') {
+            this.isUpBtn = true
         }
         this.processInspectVo.orderNumber = this.rowInfo.order_number
         this.processInspectVo.material = this.rowInfo.material
@@ -297,10 +301,13 @@
         // console.log(this.detailId);
     },
     mounted() {
-        this.getOptions();
         this.getTableData()
     },
     methods: {
+        blurNode(scope){
+            // console.log(11);
+            // this.$set(this.inspectionItems[scope.$index],'isSelectDevice',false)
+        },
         escalation() {
             let arr = this.inspectionItems
             let bl = false
@@ -323,18 +330,26 @@
             this.$axios.post(this.$api.url.processInspectUpdateProcessInspectsById, {
                 id: this.detailId
             }).then(res => {
-                console.log(res);
                 if (res.code == 200) {
+                    if (res.message === '椤圭洰鏈楠屽畬!') {
+                        this.$message({
+                            message: res.message,
+                            type: 'warning'
+                        });
+                        return
+                    }
                     this.$message({
                         message: '涓婃姤鎴愬姛',
                         type: 'success'
                     });
+                    this.$parent.combackMain(true)
                 } else {
                     this.$message({
                         message: res.message,
                         type: 'warning'
                     });
                 }
+
             })
         },
         handleClick() { },
@@ -353,9 +368,25 @@
             return data.name.indexOf(value) !== -1;
         },
         // 鑾峰彇璁惧鏍戝唴瀹�
-        getOptions() {
-            this.$axios.get(this.$api.url.rawSelectDevice).then(res => {
+        getOptions(row) {
+            this.filterText = 0
+            this.$axios.get(this.$api.url.inspectionItemChooseDev, {
+                params: {
+                    father: row.father,
+                    name: row.name,
+                    technologyId: this.processInspectVo.technologyId
+                }
+            }).then(res => {
                 this.materialOptions = res.data;
+                if(this.materialOptions.length===1){
+                    this.$message({
+                    message: '璇ラ」鐩笅鍙湁涓�涓瘯楠岃澶囷紝鏃犻渶閫夋嫨锛�',
+                    type: 'warning'
+                });
+                    return
+                }
+                row.isSelectDevice = true
+                this.filterText = row.did
             });
         },
         //杩斿洖
@@ -364,40 +395,59 @@
         },
         // 鐐瑰嚮琛ㄦ牸閫夋嫨瑙﹀彂
         clickTableSelect(scope) {
-            this.centerDialogVisible = true;
+            // return scope;
+            // this.centerDialogVisible = true;
+            if(this.clickSelectDevice.index!=null){
+                this.$set(this.inspectionItems[this.clickSelectDevice.index],'isSelectDevice',false)
+            }
             this.clickSelectDevice.index = scope.$index;
             this.clickSelectDevice.rpId = scope.row.id;
+            this.getOptions(scope.row);
         },
         // 鐐瑰嚮鏍戦噷闈㈢殑纭畾
-        clickNodeSure() {
-            if (this.detailId == null) {
-                this.inspectionItems[
-                    this.clickSelectDevice.index
-                ].did = this.nodeData.id;
-                this.inspectionItems[
-                    this.clickSelectDevice.index
-                ].dname = this.nodeData.name;
-                this.centerDialogVisible = false;
-            } else {
-                this.$axios
-                    .post(this.$api.url.inspectionItemUpdateDevByInsId, {
-                        id: this.clickSelectDevice.rpId,
-                        type: 1,
-                        devId: this.nodeData.id
-                    })
-                    .then(res => {
-                        this.getTableData()
-                        this.centerDialogVisible = false;
-                    });
-            }
+        clickNodeSure(row) {
+            console.log(row);
+            let select = this.materialOptions.filter(item => {
+                return item.id === this.filterText
+            })[0]
+            this.nodeData.id = select.id
+            this.nodeData.name = select.device
+            this.$axios
+                .post(this.$api.url.inspectionItemUpdateDevByInsId, {
+                    id: this.clickSelectDevice.rpId,
+                    type: 1,
+                    devId: this.nodeData.id
+                })
+                .then(res => {
+                    row.isSelectDevice = false
+                    console.log("row", row);
+                    this.filterText = 0
+                    this.getTableData()
+                    this.centerDialogVisible = false;
+                });
         },
         changeState(row, index) {
-            console.log(row);
             if (row.did != null && row.did != '') {
+                // let val = row.empiricalValueAddss.filter(item => {
+                //     return item != '' && item != null
+                // })
+                // let eq = val.filter(item => {
+                //     return /^[^><=]/.test(item)
+                // })
+                // if (eq.length > 0) {
+                //     this.$message({
+                //         message: "妫�娴嬪�糩" + eq + "]鏍煎紡棣栦綅搴斿寘鍚�>,<鎴栬��=",
+                //         type: 'warning'
+                //     });
+                //     return
+                // }
                 let str = ""
                 row.empiricalValueAddss.forEach(e => {
                     str += e + ","
                 })
+                if (str.slice(0, -1) === '' || str.slice(0, -1) === null || str.slice(0, -1) === undefined) {
+                    return
+                }
                 this.$axios.post(this.$api.url.inspectionItemlose_focus_update, {
                     deviceId: row.did,
                     inspectionItemId: row.id,
@@ -497,6 +547,15 @@
             })
         },
         getTableData() {
+            this.$axios.get(this.$api.url.processInspectSelectProcessInspectsListById, {
+                params: {
+                    id: this.rowInfo.id
+                }
+            }).then(res => {
+                // console.log(res.data);
+                this.processInspectVo.technologyId = res.data[0].techId
+                // console.log(this.processInspectVo);
+            })
             this.$axios.get(this.$api.url.inspectionItemListUser, {
                 params: {
                     id: this.detailId,
@@ -522,6 +581,8 @@
                             c.empiricalValueAddss.push("")
                         }
                         uName.push(c['username'])
+                        c.isSelectDevice = false
+                        this.filterText = 0
                         arr.push(c)
                     })
                 })

--
Gitblit v1.9.3