From a62d9ff3b7bebf15f1bee8827ed5c263d9a1776c Mon Sep 17 00:00:00 2001 From: licp <lichunping@guanfang.com.cn> Date: 星期四, 06 六月 2024 13:47:44 +0800 Subject: [PATCH] 在检验执行的模板渲染进行处理 --- src/components/do/b1-ins-order/add.vue | 312 ++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 280 insertions(+), 32 deletions(-) diff --git a/src/components/do/b1-ins-order/add.vue b/src/components/do/b1-ins-order/add.vue index f1cfa3f..82e3105 100644 --- a/src/components/do/b1-ins-order/add.vue +++ b/src/components/do/b1-ins-order/add.vue @@ -94,7 +94,7 @@ <div class="ins_order_add"> <div v-show="!configShow"> <el-row class="title"> - <el-col :span="6" style="padding-left: 20px;">濮旀墭鍗曚俊鎭�</el-col> + <el-col :span="6" style="padding-left: 20px;">濮旀墭鍗曚俊鎭� 鎬讳环锛�<span style="color: #3A7BFA">锟{total}}</span></el-col> <el-col :span="18" style="text-align: right;"> <el-select v-model="template" size="medium" placeholder="涓嬪崟妯℃澘" style="margin-right: 10px;" v-show="active==1" @change="selectInsOrderTemplateById"> @@ -107,7 +107,8 @@ <el-button size="medium" @click="templateDia=true" v-show="active==1"> <span style="color: #3A7BFA;">淇濆瓨妯℃澘</span> </el-button> - <el-button size="medium" type="primary" @click="openConfig">鍏夌氦閰嶇疆</el-button> + <el-button size="medium" type="primary" @click="openConfig" + v-if="this.addObj.sampleType==='鍏夌紗'">鍏夌氦閰嶇疆</el-button> <el-button size="medium" type="primary" @click="save" :loading="saveLoad" v-show="active==1">鎻愪氦</el-button> <!-- 瀹℃牳 --> <el-button size="medium" @click="upInsOrderOfState(2)" :loading="saveLoad" v-show="active==3" @@ -137,7 +138,7 @@ </div> </el-col> <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>濮旀墭瀹㈡埛锛�</div> + <div class="search_label"><span class="required-span">* </span>濮旀墭浜猴細</div> <div class="search_input"> <el-input readonly size="small" v-model="addObj.custom"> <template slot="append"><el-button slot="append" icon="el-icon-search" @click="selectUserDia = true" @@ -148,7 +149,7 @@ <el-col class="search_thing" :span="6"> <div class="search_label"><span class="required-span">* </span>濮旀墭鍗曚綅锛�</div> <div class="search_input"> - <el-input size="small" placeholder="閫夋嫨濮旀墭瀹㈡埛" clearable disabled v-model="addObj.company"></el-input> + <el-input size="small" placeholder="鈫愰�夋嫨濮旀墭瀹㈡埛" clearable disabled v-model="addObj.company"></el-input> </div> </el-col> <el-col class="search_thing" :span="6"> @@ -174,12 +175,12 @@ </el-input> </div> </el-col> - <el-col class="search_thing" :span="6"> + <!-- <el-col class="search_thing" :span="6"> <div class="search_label"><span class="required-span">* </span>鏍峰搧绫诲瀷锛�</div> <div class="search_input"> <el-input size="small" clearable disabled v-model="addObj.sampleType"></el-input> </div> - </el-col> + </el-col> --> <el-col class="search_thing" :span="6"> <div class="search_label"><span class="required-span">* </span>鏍峰搧鏁伴噺锛�</div> <div class="search_input"> @@ -280,6 +281,12 @@ v-model="addObj.remark" :readonly="active>1"></el-input> </div> </el-col> + <el-col class="search_thing" :span="6" v-if="active==1"> + <div class="search_label">RTS锛�</div> + <div class="search_input"> + <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="RTS"></el-input> + </div> + </el-col> </el-row> </div> <div v-show="!configShow"> @@ -324,21 +331,6 @@ </el-select> </template> </el-table-column> - <!-- <el-table-column prop="unit" label="鍗曚綅" align="center" min-width="100"> - <template slot-scope="scope"> - <el-select v-model="scope.row.unit" clearable size="small" style="width: 100%;" :disabled="active>1"> - <el-option v-for="(a, i) in units" :key="i" :label="a.label" :value="a.value"></el-option> - </el-select> - </template> - </el-table-column> --> - <!-- <el-table-column prop="isLeave" label="鏄惁鐣欐牱" align="center" min-width="100"> - <template slot-scope="scope"> - <el-select v-model="scope.row.isLeave" size="small" :disabled="active>1"> - <el-option label="鐣欐牱" :value="1"></el-option> - <el-option label="涓嶇暀鏍�" :value="0"></el-option> - </el-select> - </template> - </el-table-column> --> <el-table-column prop="joinName" label="閰嶅鏍峰搧鍚嶇О" width="140" align="center" v-if="addObj.mating==1"> <template slot-scope="scope"> <el-input size="small" type="textarea" :autosize="{ minRows: 1, maxRows: 1}" @@ -365,16 +357,16 @@ <el-table-column prop="inspectionItem" label="妫�楠岄」" min-width="140" show-overflow-tooltip></el-table-column> <el-table-column prop="inspectionItemSubclass" label="妫�楠岄」瀛愰」" min-width="140" show-overflow-tooltip></el-table-column> - <el-table-column prop="sonLaboratory" label="瀛愬疄楠屽" width="130" show-overflow-tooltip :filters="filters" + <el-table-column prop="sonLaboratory" label="瀛愬疄楠屽" min-width="130" show-overflow-tooltip :filters="filters" :filter-method="filterHandler"></el-table-column> <el-table-column prop="methodS" label="璇曢獙鏂规硶" min-width="120" show-overflow-tooltip> </el-table-column> <el-table-column prop="unit" label="璁¢噺鍗曚綅" width="100" show-overflow-tooltip></el-table-column> <el-table-column prop="price" label="鍗曚环" width="100" show-overflow-tooltip></el-table-column> - <el-table-column prop="manDay" label="棰勮鏃堕棿(澶�)" width="120" show-overflow-tooltip></el-table-column> - <el-table-column prop="manHour" label="宸ユ椂绯绘暟" width="100" show-overflow-tooltip></el-table-column> + <!-- <el-table-column prop="manDay" label="棰勮鏃堕棿(澶�)" width="120" show-overflow-tooltip></el-table-column> + <el-table-column prop="manHour" label="宸ユ椂绯绘暟" width="100" show-overflow-tooltip></el-table-column> --> <!-- <el-table-column prop="deviceGroup" label="璁惧缁�" width="120" show-overflow-tooltip></el-table-column> --> - <el-table-column prop="section" label="鍖洪棿" width="120" show-overflow-tooltip></el-table-column> + <el-table-column prop="section" label="鍖洪棿" min-width="120" show-overflow-tooltip></el-table-column> <el-table-column prop="ask" label="瑕佹眰鍊�" min-width="220px"> <template slot-scope="scope"> <el-input size="small" placeholder="瑕佹眰鍊�" v-model="scope.row.ask" clearable type="textarea" @@ -395,7 +387,7 @@ </span> </el-dialog> <el-dialog title="閫夋嫨鏍峰搧" :visible.sync="selectStandardTree" width="400px"> - <div class="body" style="height: 60vh;overflow-y: auto;" v-if="selectStandardTree"> + <div class="body" style="height: 60vh;overflow-y: auto;user-select: none;" v-if="selectStandardTree"> <el-row> <el-col :span="24"> <el-input placeholder="杈撳叆鍏抽敭瀛楄繘琛屾悳绱�" suffix-icon="el-icon-search" v-model="search" size="small" @@ -405,7 +397,7 @@ </el-row> <el-tree :data="list" ref="tree" :props="{ children: 'children', label: 'label' }" node-key="label" :filter-node-method="filterNode" @node-click="handleNodeClick" highlight-current @node-expand="nodeOpen" - @node-collapse="nodeClose" :default-expanded-keys="expandedKeys"> + @node-collapse="nodeClose" :default-expanded-keys="expandedKeys" @dblclick.native="activeStandardTree"> <div class="custom-tree-node" slot-scope="{ node, data }"> <el-row> <el-col :span="24"> @@ -481,7 +473,31 @@ </el-row> </span> </el-dialog> - <fiberOpticConfig :currentId="currentId" v-if="configShow" :active="active" /> + <fiberOpticConfig :currentId="currentId" + @saveFiberopticConfig="getTotal()" + v-if="configShow" :active="active" /> + <el-dialog title="妫�娴嬪埌鐗规畩椤癸紝璇蜂綔鍑轰互涓嬮�夋嫨" :visible.sync="bsm1Dia" width="500px" :show-close="false" :before-close="beforeClose"> + <div class="body" style="max-height: 60vh;"> + <el-row v-if="bsm1"> + <el-col class="search_thing" :span="22"> + <div class="search_label"><span class="required-span">* </span>鎶ゅ瀵嗗害锛�</div> + <div class="search_input"> + <el-radio-group v-model="bsm1Val" @input="upBsm1"> + <el-radio v-for="(a, ai) in JSON.parse(bsmRow.section)" :key="ai" :label="a"></el-radio> + </el-radio-group> + </div> + </el-col> + <el-col class="search_thing" :span="22"> + <div class="search_label">瑕佹眰鍊硷細</div> + <div class="search_input" v-show="bsm1Val!==null&&bsm1Val!==''"> + <el-radio-group v-model="bsm1Val" @input="upBsm1"> + <el-radio v-for="(a, ai) in JSON.parse(bsmRow.section)" :key="ai" :label="a">{{JSON.parse(bsmRow.ask)[ai]}}</el-radio> + </el-radio-group> + </div> + </el-col> + </el-row> + </div> + </el-dialog> </div> </template> @@ -615,13 +631,43 @@ configShow: false, currentMethod: null, isAskOnlyRead: false, - sampleId: null + sampleId: null, + bsmRow: null, + bsm1: false, + bsm1Val: null, + bsm1Dia: false, + total:0, + RTS:'', + totalArr:[] } }, watch: { sampleList() { this.addObj.method = null this.productList = [] + }, + productList:{ + deep:true, + handler(val){ + if(val&&val.length>0){ + let arr = []; + val.forEach(item => { + if(item.sonLaboratory&&!arr.find(a=>a.value==item.sonLaboratory)){ + arr.push({ + text: item.sonLaboratory, + value: item.sonLaboratory + }) + } + }) + this.filters = arr + } + } + }, + sampleList:{ + deep:true, + handler(val){ + this.getTotal() + } } }, mounted() { @@ -633,7 +679,7 @@ this.selectEnumByCategoryForUnit() this.selectStandardMethods() this.selectEnumByCategoryForOrderType() - this.selectEnumByCategoryForSonLaboratory() + // this.selectEnumByCategoryForSonLaboratory() this.selectEnumByCategoryForSampleForm() if (this.active != 1) { // 鏌ョ湅/瀹℃牳娴佺▼ @@ -688,6 +734,37 @@ this.addObj.companyId = selects.id this.selectUserDia = false }, + handleAsk(ask){ + let code = [">","<","=","锛�","锛�","鈮�","鈮�","卤"]; + if(ask.includes('RTS')){ + if(ask.includes('&')){ + // 澶氫釜鏉′欢 + let arr0 = ask.split('&') + let arr1 = [] + arr0.forEach(m=>{ + let index = code.findIndex(b=>m.includes(b)) + if(index>-1){ + let arr = m.split(code[index]).filter(b=>!!b) + let num = eval(this.replaceAll(arr[0],'RTS', this.RTS)) + m = code[index] + ''+ num + arr1.push(m) + } + }) + return arr1.join('&') + }else{ + // 鍗曚釜鏉′欢 + let index = code.findIndex(b=>ask.includes(b)) + if(index>-1){ + let arr = ask.split(code[index]).filter(b=>!!b) + let num = eval(this.replaceAll(arr[0],'RTS', this.RTS)) + return code[index] + ''+ num + } + } + } + }, + replaceAll(str, find, replace) { + return str.replace(new RegExp(find, 'g'), replace); + }, save() { if (!this.addObj.companyId) { this.$message.error('鏈�夋嫨瀹㈡埛鍗曚綅') @@ -711,11 +788,68 @@ this.$message.error('璇疯緭鍏ユ牱鍝佸瀷鍙�') } else if (!this.sampleList.every(m => m.standardMethodListId)) { this.$message.error('璇烽�夋嫨妫�楠屾爣鍑�') + }else if (this.totalArr.find(a=>a.ask.includes('RTS'))&&!this.RTS) { + this.$message.error('璇疯緭鍏TS') } else { + let sampleList = this.HaveJson(this.sampleList) + let isRTS = this.totalArr.find(a=>a.ask.includes('RTS')) + if(isRTS){ + sampleList.forEach(item=>{ + if(item.insProduct&&item.insProduct.length>0){ + item.insProduct.forEach(a=>{ + let ask = this.handleAsk(a.ask) + if(ask){ + a.ask = ask + } + }) + } + // 鍏夌氦甯﹂」鐩� + if(item.bushing&&item.bushing.length>0){ + item.bushing.forEach(a=>{ + if(a.fiber&&a.fiber.length>0){ + a.fiber.forEach(b=>{ + if(b.productList&&b.productList.length>0){ + b.productList.forEach(c=>{ + let ask = this.handleAsk(c.ask) + if(ask){ + c.ask = ask + } + }) + } + }) + } + if(a.fibers&&a.fibers.length>0){ + a.fibers.forEach(b=>{ + if(b.productList&&b.productList.length>0){ + b.productList.forEach(c=>{ + let ask = this.handleAsk(c.ask) + if(ask){ + c.ask = ask + } + }) + } + if(b.fiber&&b.fiber.length>0){ + b.fiber.forEach(c=>{ + if(c.productList&&c.productList.length>0){ + c.productList.forEach(d=>{ + let ask = this.handleAsk(d.ask) + if(ask){ + d.ask = ask + } + }) + } + }) + } + }) + } + }) + } + }) + } this.saveLoad = true this.$axios.post(this.$api.insOrder.addInsOrder, { insOrder: this.addObj, - list: JSON.stringify(this.sampleList.map(a => { + list: JSON.stringify(sampleList.map(a => { a.model = a.model + ((a.modelNum == null || a.modelNum == '' || a.modelNum == 'null') ? '' : ( '-' + a.modelNum)) return a @@ -812,6 +946,8 @@ this.addObj.code = selects.code this.addObj.phone = selects.phone this.addObj.companyId = selects.departId + this.addObj.production = '/' + this.addObj.productionEn = '/' }) }, searchFilter() { @@ -823,7 +959,7 @@ nodeClose(data, node, el) { $($(el.$el).find('.node_i')[0]).attr('class', 'node_i el-icon-folder') }, - handleNodeClick(val, node, el) { //鏍戠殑鍊� + handleNodeClick(val, node, el) { this.selectTree = '' this.models = val.children this.getNodeParent(node) @@ -970,6 +1106,15 @@ }, upProductSelect(selection, row) { row.state = row.state == 1 ? 0 : 1 + if (row.bsm === '1' && row.section !== '' && row.section !== null && row.state === 1) { + if(row.section.indexOf('[') > -1){ + this.bsmRow = this.HaveJson(row) + } + this.bsm1 = true + this.bsm1Dia = true + } else if (row.bsm === '1' && row.section !== '' && row.section !== null && row.state === 0) { + this.bsm1 = false + } this.sampleList.map(item => { if (this.sampleIds.indexOf(item.id) > -1) { item.insProduct.map(m => { @@ -1167,6 +1312,17 @@ return m }) } + this.productList.forEach(p=>{ + if (p.bsm === '1' && p.section !== '' && p.section !== null && p.state === 1) { + if(p.section.indexOf('[') > -1){ + this.bsmRow = this.HaveJson(p) + } + this.bsm1 = true + this.bsm1Dia = true + } else if (p.bsm === '1' && p.section !== '' && p.section !== null && p.state === 0) { + this.bsm1 = false + } + }) if (e.length > 0) { this.sampleList.map(item => { if (this.sampleIds.indexOf(item.id) > -1) { @@ -1260,6 +1416,98 @@ this.configShow = true }) } + }, + upBsm1(val) { + let sections = JSON.parse(this.bsmRow.section); + let asks = JSON.parse(this.bsmRow.ask); + let tells = JSON.parse(this.bsmRow.tell); + let manHours = JSON.parse(this.bsmRow.manHour); + let prices = JSON.parse(this.bsmRow.price); + for (var a in sections) { + if(val === sections[a]){ + this.productList.forEach(p=>{ + if(p.id === this.bsmRow.id){ + p.section = sections[a] + p.ask = asks[a] + p.tell = tells[a] + p.manHour = manHours[a] + p.price = prices[a] + } + }) + break + } + } + }, + beforeClose(done){ + if(this.bsm1){ + if(this.bsm1Val===null || this.bsm1Val === ''){ + this.$message.error('鐗规畩椤圭洰蹇呴』澶勭悊') + return + } + } + done() + }, + getTotal(){ + this.totalArr = [] + this.total = 0; + this.sampleList.forEach(item=>{ + if(item.insProduct&&item.insProduct.length>0){ + item.insProduct.forEach(a=>{ + this.totalArr.push(a) + }) + } + if(item.bushing&&item.bushing.length>0){ + item.bushing.forEach(a=>{ + if(a.fiber&&a.fiber.length>0){ + a.fiber.forEach(b=>{ + if(b.productList&&b.productList.length>0){ + b.productList.forEach(c=>{ + this.totalArr.push(c) + }) + } + }) + } + if(a.fibers&&a.fibers.length>0){ + a.fibers.forEach(b=>{ + if(b.productList&&b.productList.length>0){ + b.productList.forEach(c=>{ + this.totalArr.push(c) + }) + } + if(b.fiber&&b.fiber.length>0){ + b.fiber.forEach(c=>{ + if(c.productList&&c.productList.length>0){ + c.productList.forEach(d=>{ + this.totalArr.push(d) + }) + } + }) + } + }) + } + }) + } + }) + let mySet = new Set(); + let arr0 = this.totalArr.filter(item=>{ + if(item.state == 1){ + let num1= mySet.size + if(item.manHourGroup===''||!item.manHourGroup){ + return true + }else{ + mySet.add(item.manHourGroup) + let num2= mySet.size + if(num2 > num1){ + return true + }else{ + return false + } + } + } + }) + arr0.forEach(item=>{ + this.total += Number(item.price) + }) } } } -- Gitblit v1.9.3