From 2514ee4fe0471be59f67723a85a64dee88db8c67 Mon Sep 17 00:00:00 2001 From: licp <lichunping@guanfang.com.cn> Date: 星期三, 27 三月 2024 10:52:01 +0800 Subject: [PATCH] 表格坐标转换 --- src/components/do/b1-inspect-order-plan/Inspection.vue | 459 ++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 407 insertions(+), 52 deletions(-) diff --git a/src/components/do/b1-inspect-order-plan/Inspection.vue b/src/components/do/b1-inspect-order-plan/Inspection.vue index 917a0a4..749da2f 100644 --- a/src/components/do/b1-inspect-order-plan/Inspection.vue +++ b/src/components/do/b1-inspect-order-plan/Inspection.vue @@ -7,13 +7,11 @@ .search { width: 100%; margin-bottom: 10px; - height: 140px; background-color: #fff; border-radius: 3px; } .search .form-inline { - height: 50px; padding-top: 20px; padding-left: 50px; } @@ -24,6 +22,52 @@ background-color: #fff; border-radius: 3px; padding: 20px; + display: flex; + align-items: center; + justify-content: center; + flex-wrap: wrap; + } + .tables{ + /* width: 800px; */ + margin-bottom: 16px; + } + .tables td{ + height: 40px; + width: 100px; + text-align: center; + font-size: 14px; + } + .content{ + display: flex; + width: 100%; + height: 100%; + align-items: center; + justify-content: left; + padding: 5px; + box-sizing: border-box; + } + .content-h-0{ + justify-content: center; + } + .content-h-1{ + justify-content: start; + } + .content-h-2{ + justify-content: end; + } + .content-v-0{ + align-items: center; + } + .content-v-1{ + align-items: start; + } + .content-v-2{ + align-items: end; + } + + .table_input{ + width: 100%; + height: 100%; } </style> <style> @@ -45,9 +89,9 @@ } </style> <template> - <div> + <div v-loading="loading"> <el-row class="title"> - <el-col :span="12" style="padding-left: 20px;">鏍峰搧璇︽儏</el-col> + <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> @@ -55,81 +99,105 @@ </el-col> </el-row> <div class="search"> - <el-form :inline="true" :model="searchForm" class="form-inline" label-width="90px"> + <el-form :inline="true" :model="searchForm" class="form-inline" label-width="100px"> <el-form-item label="濮旀墭缂栧彿:"> - <el-input clearable v-model="searchForm.sampleName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> + <el-input clearable v-model="insOrder.entrustCode" disabled size="small" placeholder="璇疯緭鍏�"></el-input> </el-form-item> <el-form-item label="鏍峰搧缂栧彿:"> - <el-input clearable v-model="searchForm.sampleName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> + <el-input clearable v-model="currentSample.sampleCode" disabled size="small" placeholder="璇疯緭鍏�"></el-input> </el-form-item> <el-form-item label="鏍峰搧鍚嶇О:"> - <el-input clearable v-model="searchForm.sampleName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> + <el-input clearable v-model="currentSample.sample" disabled size="small" placeholder="璇疯緭鍏�"></el-input> </el-form-item> <el-form-item label="鏍峰搧鏁伴噺:"> - <el-input clearable v-model="searchForm.sampleName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> + <el-input clearable v-model="sampleProduct.length" disabled size="small" placeholder="璇疯緭鍏�"></el-input> </el-form-item> <el-form-item label="涓嬪彂鏃堕棿:"> - <el-input clearable v-model="searchForm.sampleName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> + <el-input clearable v-model="insOrder.sendTime" disabled size="small" placeholder="璇疯緭鍏�"></el-input> </el-form-item> <el-form-item label="绱ф�ョ▼搴�:"> - <el-input clearable v-model="searchForm.sampleName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> + <el-input clearable v-model="insOrder.typeName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> </el-form-item> <el-form-item label="绾﹀畾鏃堕棿:"> - <el-input clearable v-model="searchForm.sampleName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> + <el-input clearable v-model="insOrder.appointed" disabled size="small" placeholder="璇疯緭鍏�"></el-input> </el-form-item> - <el-form-item label="褰撳墠鏍峰搧鏁�:"> - <el-input clearable v-model="searchForm.sampleName" disabled size="small" placeholder="璇疯緭鍏�"></el-input> - </el-form-item> + <el-form-item label="褰撳墠鏍峰搧浣嶆暟:" > + <el-tag v-if="currentSample.index">{{ `NO.${currentSample.index}` }}</el-tag> + </el-form-item> </el-form> </div> <div class="center"> + <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' + 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}`"> + <el-input v-if="n.v.ps!=undefined && n.v.ps.value==='妫�楠屽��'" class="table_input" v-model="n.v.v" @change="m=>changeInput(m,`${item.templateId}-${n.r}-${n.c}`)" /> + <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> + <span v-else :style="`font-family:${n.v.ff} !important;`">{{n.v.v}}</span> + </div> + </td> + </tr> + </tbody> + </table> </div> <el-drawer title="鏍峰搧鍒囨崲" :visible.sync="sampleVisible" - :destroy-on-close="true" - size="55%"> - <el-table class="el-table" ref="productTable" :data="productList" height="100%" tooltip-effect="dark" border highlight-current-row @row-click="handleChangeSample"> - <el-table-column type="index" align="center" label="搴忓彿" width="70" :key="Math.random()"> + :size="500"> + <el-table class="el-table" ref="productTable" :data="sampleProduct" height="100%" tooltip-effect="dark" border highlight-current-row @row-click="handleChangeSample" :row-class-name="tableRowClassName" + :current-row-key="currentKey" :row-key="record=>record.index" + v-if="sampleVisible"> + <el-table-column type="index" align="center" label="搴忓彿" width="70px" :key="Math.random()"> </el-table-column> - <el-table-column prop="inspectionItemSubclass" label="鏍峰搧缂栧彿" min-width="100" + <el-table-column prop="sampleCode" label="鏍峰搧缂栧彿" min-width="100px" show-overflow-tooltip></el-table-column> - <el-table-column prop="sonLaboratory" label="妫�娴嬬姸鎬�" min-width="100" show-overflow-tooltip></el-table-column> - <el-table-column prop="method" label="妫�娴嬩汉" min-min-width="100" show-overflow-tooltip></el-table-column> - <el-table-column prop="unit" label="鏄惁鐣欐牱" min-width="100" show-overflow-tooltip></el-table-column> + <el-table-column prop="model" label="鏍峰搧鍨嬪彿" min-width="100px" show-overflow-tooltip></el-table-column> + <el-table-column prop="insState" label="妫�娴嬬姸鎬�" width="95px" show-overflow-tooltip> + <template slot-scope="scope"> + <el-tag v-for="(item, i) in typeList" :key="i" v-if="item.value == scope.row.insState" + :type="item.type" size="medium" style="margin-right: 5px;">{{item.label}}</el-tag> + </template> + </el-table-column> + <el-table-column prop="isLeave" label="鏄惁鐣欐牱" width="95px" show-overflow-tooltip align="center"> + <template slot-scope="scope"> + <span>{{ scope.row.isLeave==0?'鍚�':'鏄�' }}</span> + </template> + </el-table-column> + <!-- 妫�楠屽崟浼氭湁涓�涓槸鍚︽湁閰嶅鏍峰搧瀛楁鎺у埗鏄剧ず --> + <el-table-column prop="joinModel" label="閰嶅鏍峰搧鍨嬪彿" min-width="130px" show-overflow-tooltip v-if="insOrder.mating>0"></el-table-column> + <el-table-column prop="joinName" label="閰嶅鏍峰搧鍚嶇О" min-width="130px" show-overflow-tooltip v-if="insOrder.mating>0"></el-table-column> + <el-table-column prop="joinNum" label="閰嶅鏍峰搧鏁伴噺" min-width="130px" show-overflow-tooltip v-if="insOrder.mating>0"></el-table-column> </el-table> </el-drawer> <el-drawer title="浠诲姟鍒囨崲" :visible.sync="taskVisible" - :destroy-on-close="true" - size="55%"> - <el-table class="el-table" ref="productTable" :data="productList" height="100%" tooltip-effect="dark" border highlight-current-row @row-click="handleChangeTask"> - <el-table-column prop="inspectionItemSubclass" label="濮旀墭缂栧彿" min-width="100" - show-overflow-tooltip></el-table-column> - <el-table-column prop="sonLaboratory" label="鏍峰搧缂栧彿" min-width="100" show-overflow-tooltip></el-table-column> - <el-table-column prop="method" label="鏍峰搧鍚嶇О" min-min-width="100" show-overflow-tooltip></el-table-column> - <el-table-column prop="unit" label="绱ф�ョ▼搴�" min-width="100" show-overflow-tooltip> - <template slot-scope="scope"> - <el-tag - :type="scope.row.type" size="medium">{{scope.row.label}}</el-tag> - </template> - </el-table-column> - <el-table-column prop="unit" label="鐘舵��" min-width="100" show-overflow-tooltip> - <template slot-scope="scope"> - <el-tag - :type="scope.row.type" size="medium">{{scope.row.label}}</el-tag> - </template> - </el-table-column> - <el-table-column prop="method" label="绾﹀畾鏃堕棿" min-min-width="100" show-overflow-tooltip></el-table-column> - <el-table-column prop="method" label="涓嬪彂鏃堕棿" min-min-width="100" show-overflow-tooltip></el-table-column> - </el-table> + :size="500"> + <ValueTable class="value-table" ref="insOrderPlan" + :url="$api.insOrderPlan.selectInsOrderPlanList" :componentData="componentData" + :key="upIndex"/> </el-drawer> </div> </template> <script> + import ValueTable from '../../tool/value-table.vue' export default { + props: ['sonLaboratory','orderId'], + components: { + ValueTable, + }, data() { return { sampleVisible:false, @@ -138,20 +206,307 @@ sampleName: null, state: null }, - productList:[] + id: 0, + componentData: { + entity: { + sonLaboratory: null, + userId: 0 + }, + isIndex: false, + showSelect: false, + select: false, + selectMethod:'handleChangeTask', + sort: false, + do: [], + isPage:false, + linkEvent: {}, + tagField: { + type: { + select: [] + }, + insState: { + select: [] + }, + }, + currentId:'', + selectField: {}, + requiredAdd: [], + requiredUp: [] + }, + upIndex: 0, + insOrder: {}, + sampleProduct: [], + typeList:[], + urgentList:[], + currentSample:{},//褰撳墠鏍峰搧淇℃伅 + tableList:[], + loading: false, + ps: {}, + param: { + insValue:{}, + comValue: {}, + bestValue: {}, + result: {} + }, + currentKey:1, + comparisonList:[], + excelMethodList:[] } }, created() { + this.componentData.entity.sonLaboratory = this.sonLaboratory; + this.id = this.orderId; + }, + mounted() { + this.getTypeDicts() + this.getInsStateDicts() + this.getComparisonList() + }, + watch:{ + id(val){ + this.loading = true + this.$axios.post(this.$api.insOrderPlan.doInsOrder,{ + id: val + }).then(res=>{ + this.insOrder = res.data.insOrder; + this.urgentList.forEach(m=>{ + if(m.value==this.insOrder.type){ + this.insOrder.typeName = m.label + } + }) + this.sampleProduct = res.data.sampleProduct + this.currentSample = this.sampleProduct[0] + if(this.currentSample.index==undefined)this.currentSample['index'] = 1 + this.loading = false + this.handleTableData() + this.componentData.currentId = val; + this.currentKey = 1; + }) + } }, methods: { - handleChangeSample(row){ - console.log(1111111111,row) + handleChangeSample(row, column, event){ + this.currentSample = row; + this.handleTableData() this.sampleVisible = false; + this.currentKey=row.index }, handleChangeTask(row){ - console.log(222222222,row) + if(row.length > 0)this.id = row[0].id; this.taskVisible = false; - } - } - } + }, + getTypeDicts() { + this.$axios.post(this.$api.enums.selectEnumByCategory, { + category: "绱ф�ョ▼搴�" + }).then(res => { + let data = res.data + data.forEach(ele => { + if (ele.value === '0') { + ele.type = 'success' + } else if (ele.value === '1') { + ele.type = 'warning' + } else if (ele.value === '2') { + ele.type = 'danger' + } + }) + this.urgentList = data; + this.componentData.tagField.type.select = data + }) + }, + getInsStateDicts() { + this.$axios.post(this.$api.enums.selectEnumByCategory, { + category: "妫�楠屼换鍔$姸鎬�" + }).then(res => { + let data = res.data + data.forEach(ele => { + //0:寰呮楠� 1:妫�楠屼腑 2:宸叉楠� 3:寰呭鏍� 4:澶嶆牳鏈�氳繃 5:澶嶆牳閫氳繃 + if (['2', '5'].includes(ele.value)) { + ele.type = 'success' + } else if (['1', '3'].includes(ele.value)) { + ele.type = 'warning' + } else if (['0', '4'].includes(ele.value)) { + ele.type = 'danger' + } + }) + this.typeList = data + 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; + mySet1.add(JSON.stringify({ + inspectionItem:m.inspectionItem, + templateId:m.templateId + })) + let num1 = mySet1.size; + if(num1>num0){ + return m + } + }) + this.tableList.forEach(a=>{ + let dels = [] + let ids = [] + a.template.forEach(b=>{ + 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, + product: this.currentSample.insProduct[i] + }) + break + } + count++ + } + if(count === this.currentSample.insProduct.length){ + dels.push(b) + } + } + }) + 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 + } + } + }) + ids.forEach(id=>{ + 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 + } + } + } + }) + }) + this.tableList.forEach(a=>{ + let arrs = [] + let set = new Set() + let count1 = 0 + 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 = '' + } + set.add(b.r) + if(b.v.f){ + this.excelMethodList.push(b) + } + }) + 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.handleExcelMethod() + }, + changeInput(m,code){ + console.log(m,'code:',code,this.excelMethodList) + let r = code.split('-')[1] + let c = code.split('-')[2] + this.excelMethodList.forEach(item=>{ + if(item.valueList.find(m=>m.r==r&&m.c==c)){ + console.log('褰撳墠鐨勬柟娉�',item.methodName) + console.log('褰撳墠鐨勬暟鎹」',item.valueList) + console.log('褰撳墠鐨勬暟鍊奸」','r:',item.r,'c:',item.c) + this.changeInput('璁$畻鐨勭粨鏋�',`${code.split('-')[0]}-${item.r}-${item.c}`)//鏀瑰彉鏈�缁堝�� + } + }) + }, + handleExcelMethod(){ + if(this.excelMethodList.length>0){ + this.excelMethodList.map(item=>{ + if(item.v.f.includes(':')){} + item.methodName = 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.forEach(m=>{ + let r = m.split('')[1]-1 + let c = this.comparisonList.find(j=>j.label==m.split('')[0]).value + valueList.push({c,r}) + }) + } + return item; + }) + } + } + }, +} </script> -- Gitblit v1.9.3