From 2e078e11d17ac645df50117c17a8c129a65edeb2 Mon Sep 17 00:00:00 2001 From: licp <lichunping@guanfang.com.cn> Date: 星期三, 27 三月 2024 17:39:19 +0800 Subject: [PATCH] 修改结论 --- src/components/do/b1-inspect-order-plan/Inspection.vue | 421 +++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 366 insertions(+), 55 deletions(-) diff --git a/src/components/do/b1-inspect-order-plan/Inspection.vue b/src/components/do/b1-inspect-order-plan/Inspection.vue index afb0e58..fa0ff0f 100644 --- a/src/components/do/b1-inspect-order-plan/Inspection.vue +++ b/src/components/do/b1-inspect-order-plan/Inspection.vue @@ -22,11 +22,16 @@ background-color: #fff; border-radius: 3px; padding: 20px; + position: relative; + } + .center-box{ + height: 100%; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; - } + overflow-y: auto; + } .tables{ /* width: 800px; */ margin-bottom: 16px; @@ -69,6 +74,21 @@ width: 100%; height: 100%; } + + .collection{ + width: 50px; + height: 100%; + margin-left: 5px; + border-color: transparent; + background-color: #409eff; + color: #fff; + border-radius: 4px; + font-size: 12px; + } + + .collection:active{ + opacity: .7; + } </style> <style> .el-form-item__label{ @@ -91,13 +111,13 @@ <template> <div v-loading="loading"> <el-row class="title"> - <el-col :span="12" style="padding-left: 20px;">妫�楠屽崟璇︽儏</el-col> - <el-col :span="12" style="text-align: right;"> - <el-button size="small" type="primary" @click="sampleVisible=true">鏍峰搧鍒囨崲</el-button> - <el-button size="small" type="primary" @click="taskVisible=true">浠诲姟鍒囨崲</el-button> - <el-button size="small" @click="$emit('goback')">杩斿洖</el-button> - </el-col> - </el-row> + <el-col :span="12" style="padding-left: 20px;">妫�楠屽崟璇︽儏</el-col> + <el-col :span="12" style="text-align: right;"> + <el-button size="small" type="primary" @click="sampleVisible=true">鏍峰搧鍒囨崲</el-button> + <el-button size="small" type="primary" @click="taskVisible=true">浠诲姟鍒囨崲</el-button> + <el-button size="small" @click="$emit('goback')">杩斿洖</el-button> + </el-col> + </el-row> <div class="search"> <el-form :inline="true" :model="searchForm" class="form-inline" label-width="100px"> <el-form-item label="濮旀墭缂栧彿:"> @@ -127,24 +147,51 @@ </el-form> </div> <div class="center"> - <table border="1" class="tables" cellpadding="10" v-for="(item,index) in tableList" :key="index"> + <div class="center-box"> + <table border="1" class="tables" cellpadding="10" v-for="(item,index) in tableList" :key="index"> <tbody> <tr v-for="(m,i) in item.arr" :key="i"> <td - :id='item.templateId+"-"+n.r+"-"+n.c' + :id='item.templateId+"-"+n.i+"-"+n.r+"-"+n.c' v-for="(n,j) in m" :key="j" :colspan="n.v.mc&&n.v.mc.cs?n.v.mc.cs:1" :rowspan="n.v.mc&&n.v.mc.rs?n.v.mc.rs:1" :style="`background:${n.v.bg};color:${n.v.fc};font-size:${n.v.fs}px;width:${item.style.columnlen[n.c]}px;height:${item.style.rowlen[n.r]}px;font-wight:${n.v.bl?'bold':''};`"> <div class="content" :class="`content-h-${n.v.ht} content-v-${n.v.vt}`"> - <span v-if="n.v.ps===undefined || n.v.ps.value!='妫�楠屽��'" :style="`font-family:${n.v.ff} !important;`">{{ n.v.v}}</span> - <input v-else class="table_input"/> + <template v-if="n.v.ps!=undefined && n.v.ps.value==='妫�楠屽��'"> + <el-input v-if="getInspectionValueType(n.i) == 1" class="table_input" v-model="n.v.v" :disabled="getInspectionItemType(n.i) == 1" @change="m=>changeInput(m,`${item.templateId}-${n.r}-${n.c}-${n.i}`)" /> + <el-input v-else-if="getInspectionValueType(n.i) == 2" class="table_input" type="textarea" :autosize="{ minRows: 1}" v-model="n.v.v"/> + <el-select v-else-if="getInspectionValueType(n.i) == 5" class="table_input" v-model="n.v.v"> + <el-option label="鏄�" value="鏄�"></el-option> + <el-option label="鍚�" value="鍚�"></el-option> + </el-select> + <span :style="`font-family:${n.v.ff} !important;`" v-else-if="getInspectionValueType(n.i) == 4">/</span> + <el-button type="primary" icon="el-icon-edit" size="mini" circle v-if="getInspectionItemType(n.i) == 1" style="border: 0;margin-left: 2px;" @click="getSystemValue(n)"> + </el-button> + </template> + <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='缁撹'"> + <span v-if="n.v.v===1" :style="`font-family:${n.v.ff} !important;color: green;`">鍚堟牸</span> + <span v-else-if="n.v.v===0" :style="`font-family:${n.v.ff} !important;color: red;`">涓嶅悎鏍�</span> + <span v-else :style="`font-family:${n.v.ff} !important;`">寰呭畾</span> + </template> + <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='璁惧'"> + <el-select v-model="n.v.v" placeholder="璇烽�夋嫨" @visible-change="e=>getEquipOptions(e,n.i)"> + <el-option + v-for="item in equipOptions" + :key="item.value" + :label="item.label" + :value="item.value"> + </el-option> + </el-select> + </template> + <span v-else :style="`font-family:${n.v.ff} !important;`">{{n.v.v}}</span> </div> </td> </tr> </tbody> </table> + </div> </div> <el-drawer title="鏍峰搧鍒囨崲" @@ -237,13 +284,11 @@ tableList:[], loading: false, ps: {}, - param: { - insValue:{}, - comValue: {}, - bestValue: {}, - result: {} - }, + param: {}, currentKey:1, + comparisonList:[], + excelMethodList:[], + equipOptions:[], } }, created() { @@ -253,6 +298,7 @@ mounted() { this.getTypeDicts() this.getInsStateDicts() + this.getComparisonList() }, watch:{ id(val){ @@ -268,6 +314,15 @@ }) this.sampleProduct = res.data.sampleProduct this.currentSample = this.sampleProduct[0] + this.currentSample.insProduct.forEach(a=>{ + this.param[a.id] = { + insValue: [], + comValue: [], + resValue: [], + equipValue:null, + intResult: null + } + }) if(this.currentSample.index==undefined)this.currentSample['index'] = 1 this.loading = false this.handleTableData() @@ -279,6 +334,15 @@ methods: { handleChangeSample(row, column, event){ this.currentSample = row; + this.currentSample.insProduct.forEach(a=>{ + this.param[a.id] = { + insValue: [], + comValue: [], + resValue: [], + equipValue:null, + intResult: null + } + }) this.handleTableData() this.sampleVisible = false; this.currentKey=row.index @@ -324,10 +388,19 @@ this.componentData.tagField.insState.select = data }) }, + getComparisonList(){ + this.$axios.post(this.$api.enums.selectEnumByCategory, { + category: "琛ㄦ牸鍧愭爣杞崲" + }).then(res => { + let data = res.data + this.comparisonList = data; + }) + }, tableRowClassName({ row, rowIndex }){ row.index = rowIndex + 1; }, handleTableData(){ + this.excelMethodList = [] const mySet1 = new Set(); this.tableList = JSON.parse(JSON.stringify(this.currentSample.insProduct)).filter(m=>{ let num0 = mySet1.size; @@ -344,13 +417,14 @@ let dels = [] let ids = [] a.template.forEach(b=>{ - if(b.v.ps!=undefined&&b.v.ps.value==='妫�楠屽瓙椤�'){ + if (b.v.ps!=undefined&&b.v.ps.value==='妫�楠屽瓙椤�'){ let count = 0 for(let i in this.currentSample.insProduct){ if(this.currentSample.insProduct[i].inspectionItemSubclass === b.v.v && this.currentSample.insProduct[i].templateId === a.templateId){ ids.push({ r: b.r, - id: this.currentSample.insProduct[i].id + id: this.currentSample.insProduct[i].id, + product: this.currentSample.insProduct[i] }) break } @@ -364,6 +438,16 @@ dels.forEach(del=>{ for(let b=0;b<a.template.length;b++){ if(a.template[b].r === del.r){ + if(a.template[b].v.mc!=undefined){ + if(a.template[b].v.mc.rs!=undefined&&a.template[b].v.mc.rs>1){ + if(a.template[b].r === a.template[b].v.mc.r){ + a.template[b].r += 1 + a.template[b].v.mc.r += 1 + a.template[b].v.mc.rs -= 1 + continue + } + } + } a.template.splice(b, 1) b-=1 } @@ -373,48 +457,275 @@ for(let b=0;b<a.template.length;b++){ if(a.template[b].r === id.r){ a.template[b].i = id.id + if (a.template[b].v.ps!=undefined&&a.template[b].v.ps.value==='鍗曚綅'){ + a.template[b].v.v = id.product.unit + } } } }) }) - console.log(this.tableList); - // return - this.tableList.map(item=>{ - const mySet0 = new Set(); - let arr = []; - let arrItem = []; - item.template.forEach((m,i)=>{ - let num0 = mySet0.size; - mySet0.add(m.r) - let num1 = mySet0.size; - if(num0<num1){ - if(arrItem.length>0){ - arr.push(arrItem) - arrItem = [] + this.tableList.forEach(a=>{ + let arrs = [] + let set = new Set() + let count1 = 0 + let conclusionList=[];//缁撹鍒楄〃 + let finalList = [];//鏈�缁堝�煎垪琛� + conclusionList = a.template.filter(n=>n.v.ps!=undefined&&n.v.ps.value==='缁撹') + finalList = a.template.filter(n=>n.v.ps!=undefined&&n.v.ps.value==='鏈�缁堝��') + a.template.forEach(b=>{ + if (b.v.ps!=undefined&&b.v.ps.value==='搴忓彿'){ + count1++ + b.v.v = count1 + } + if (b.v.ps!=undefined&&b.v.ps.value==='瑕佹眰鍊�'){ + b.v.v = this.getAsk(b.i) + } + if (b.v.ps!=undefined&&b.v.ps.value==='妫�楠屽��'){ + b.v.v = '' + this.param[b.i].insValue.push(b) + } + if (b.v.ps!=undefined&&b.v.ps.value==='璁$畻鍊�'){ + b.v.v = '' + this.param[b.i].comValue.push(b) + } + if (b.v.ps!=undefined&&b.v.ps.value==='璁惧'){ + b.v.v = '' + this.param[b.i].equipValue = b + } + if (b.v.ps!=undefined&&b.v.ps.value==='鏈�缁堝��'){ + b.v.v = '' + if(b.i===undefined){ + for(var c in this.param){ + this.param[c].resValue.push(b) + } + }else{ + this.param[b.i].resValue.push(b) + } + } + if (b.v.ps!=undefined&&b.v.ps.value==='缁撹'){ + for(var c in this.param){ + this.param[c].insResult = b } - if(m.v.mc){ - if(m.v.mc.rs||m.v.mc.cs){ - arrItem.push(m) + conclusionList.forEach((n,i)=>{ + if(n.r==b.r&&n.c==b.c){ + console.log(b.r,b.c,) + b.v.f = `(${this.comparisonList.find(j=>j.value==(finalList[i].c)).label}${finalList[i].r+1})` } - }else{ - arrItem.push(m) - } - }else{ - if(m.v.mc){ - if(m.v.mc.rs||m.v.mc.cs){ - arrItem.push(m) - } - }else{ - arrItem.push(m) - } + }) + } + set.add(b.r) + if(b.v.f){ + this.excelMethodList.push(b) } - }) - arr.push(arrItem) - item.arr = arr; - return item + }) + set = Array.sort(set) + set.forEach(b=>{ + let arr = [] + a.template.forEach(c=>{ + if(c.r === b){ + if(arr.length===0){ + if(c.v.mc==undefined||Object.keys(c.v.mc).length==4) arr.push(c) + }else{ + for(let d=0;d<arr.length;d++){ + if(c.c<arr[d].c){ + if(c.v.mc==undefined||Object.keys(c.v.mc).length==4) arr.splice(d, 0, c) + break + } + if(d === arr.length-1){ + if(c.v.mc==undefined||Object.keys(c.v.mc).length==4) arr.push(c) + break + } + } + } + } + }) + arrs.push(arr) + }) + a.arr = arrs + }) + /* this.currentSample.insProduct.forEach(a=>{ + for(var i=0;i<a.param.comValue.length;i++){ + this.param[a.id].comValue[i].v.v = a.param.comValue[i].v.v + } + }) */ + this.handleExcelMethod() + }, + changeInput(m,code){ + let str = code.split('-') + let r = str[1] + let c = str[2] + let id = str[0] + let pId = str[3] + var list = [] + for(let a in this.tableList){ + if(this.tableList[a].templateId == id){ + list = this.tableList[a].arr + break + } + } + this.excelMethodList.forEach(item=>{ + if(item.valueList.find(m=>m.r==r&&m.c==c)){ + var comValue = {} + item.valueList.forEach(a=>{ + list.forEach(b=>{ + if(b[0].r==a.r){ + b.forEach(c=>{ + if(c.c==a.c){ + if(!isNaN(parseFloat(c.v.v))){ + var tableCode = '' + for(var d in this.comparisonList){ + if(c.c == this.comparisonList[d].value){ + tableCode = this.comparisonList[d].label + break + } + } + comValue[(tableCode + c.r)] = parseFloat(c.v.v) + } + } + }) + } + }) + }) + // console.log('褰撳墠鐨勬柟娉�',item.methodName,item.r,item.c,this.excelMethodList) + if(item.methodName=='鑷畾涔夋柟娉�'&&item.v.ps&&item.v.ps.value=='缁撹'){ + if(this.tableList.find(m=>m.id==item.i)){ + let ask = this.tableList.find(m=>m.id==item.i).ask.split('&'); + let res = Object.values(comValue)[0] + let comp = ask.map((m,i)=>{ + if(m.includes('=')){ + return res == m.split('=')[1] + } + if(m.includes('鈮�')){ + return res >= m.split('鈮�')[1] + } + if(m.includes('鈮�')){ + return res <= m.split('鈮�')[1] + } + if(m.includes('<')){ + return res < m.split('<')[1] + } + if(m.includes('>')){ + return res > m.split('>')[1] + } + }) + if(comp.every(m=>m)){ + item.v.v = 1 + }else{ + item.v.v = 0 + } + console.log(33333333333,this.param) + } + }else{ + let comResult = 0; + switch(item.methodName){ + case 'AVERAGE': + let sum = 0 + for(var a in comValue){ + sum += comValue[a] + } + comResult = sum / Object.keys(comValue).length + break; + default: + break; + } + list.forEach(a=>{ + if(a[0].r == item.r){ + for(var b in a){ + if(a[b].c == item.c){ + a[b].v.v = parseFloat(comResult.toFixed(2)) + break + } + } + } + }) + this.changeInput(comResult,`${code.split('-')[0]}-${item.r}-${item.c}-${pId}`)//鏀瑰彉鏈�缁堝�� + } + } }) - console.log(this.tableList); + }, + handleExcelMethod(){ + if(this.excelMethodList.length>0){ + this.excelMethodList.map(item=>{ + item.methodName = item.v.f.split('=').length>1&&item.v.f.split('=')[1].split('(')&&item.v.f.split('=')[1].split('(')[0]?item.v.f.split('=')[1].split('(')[0]:'鑷畾涔夋柟娉�'; + let valueList = []; + if(item.v.f.includes(':')){ + valueList = []; + let r0 = null; + let c0 = null; + let r1 = null; + let c1 = null; + let mode = item.v.f.split('(')[1].split(')')[0]; + let start = mode.split(':')[0] + let end = mode.split(':')[1] + c0 = this.comparisonList.find(j=>j.label==start.split('')[0]).value + r0 = start.split('')[1]-1 + c1 = this.comparisonList.find(j=>j.label==end.split('')[0]).value + r1 = end.split('')[1]-1 + for (let i=Number(r0);i<=r1;i++){ + for(let u=c0;u<=c1;u++){ + valueList.push({ + r:i, + c:u + }) + } + } + item.valueList = valueList; + }else{ + valueList = [] + let regex= /[=\+\-\*\%\(\)\s]/g + let mode = item.v.f.replace(regex, ' ').split(' '); + mode.filter(m=>m).forEach(m=>{ + let r = m.split('')[1]-1 + let c = this.comparisonList.find(j=>j.label==m.split('')[0]).value + valueList.push({c,r}) + }) + } + item.valueList = valueList; + return item; + }) + } + }, + getInspectionValueType(id){ + for(var a in this.currentSample.insProduct){ + if(this.currentSample.insProduct[a].id == id){ + return this.currentSample.insProduct[a].inspectionValueType + } + } + }, + getInspectionItemType(id){ + for(var a in this.currentSample.insProduct){ + if(this.currentSample.insProduct[a].id == id){ + return this.currentSample.insProduct[a].inspectionItemType + } + } + }, + getAsk(id){ + for(var a in this.currentSample.insProduct){ + if(this.currentSample.insProduct[a].id == id){ + return this.currentSample.insProduct[a].ask + } + } + }, + getSystemValue(n){ + this.$message.error('閲囬泦澶辫触銆愬凡寮�鏀炬墜鍔ㄦ柟寮忋��') + for(var a in this.currentSample.insProduct){ + if(this.currentSample.insProduct[a].id == n.i){ + this.currentSample.insProduct[a].inspectionItemType = 0 + } + } + }, + getEquipOptions(e,id){ + if(e){ + let category = this.tableList.find(m=>m.id==id).deviceGroup + this.$axios.post(this.$api.deviceScope.selectDeviceByCategory, {category}).then(res => { + if (res.code === 200 && res.data) { + console.log(1111111,res.data) + } + }).catch(error => { + console.error(error) + }) + } } - } - } + } +} </script> -- Gitblit v1.9.3