From c263fb316fc23d9db98ce711fda30d81c28d2d9c Mon Sep 17 00:00:00 2001 From: zouyu <2723363702@qq.com> Date: 星期四, 08 八月 2024 19:02:10 +0800 Subject: [PATCH] Merge branch 'master' of http://114.132.189.42:9002/r/center-lims-before --- /dev/null | 1 src/components/do/b1-ins-order/add.vue | 3 src/components/do/b1-inspect-order-plan/Inspection.vue | 19 src/components/view/b1-inspect-order-plan.vue | 2 src/components/do/b1-ins-order/fiberoptic-config.vue | 814 ++++++++++++++++++++++++++++++++++++++++++++++++--------- 5 files changed, 696 insertions(+), 143 deletions(-) diff --git a/.nvmdrc b/.nvmdrc deleted file mode 100644 index 421dc09..0000000 --- a/.nvmdrc +++ /dev/null @@ -1 +0,0 @@ -18.11.0 \ No newline at end of file diff --git a/src/components/do/b1-ins-order/add.vue b/src/components/do/b1-ins-order/add.vue index cb130d3..cc478e4 100644 --- a/src/components/do/b1-ins-order/add.vue +++ b/src/components/do/b1-ins-order/add.vue @@ -2995,9 +2995,8 @@ getTotal() { this.totalArr = [] this.total = 0; - // console.log(this.sampleList) this.sampleList.forEach(item => { - if (item.insProduct && item.insProduct.length > 0) { + if (item.insProduct && item.insProduct.length > 0) { item.insProduct.forEach(a => { this.totalArr.push(a) }) diff --git a/src/components/do/b1-ins-order/fiberoptic-config.vue b/src/components/do/b1-ins-order/fiberoptic-config.vue index f522a9c..543547e 100644 --- a/src/components/do/b1-ins-order/fiberoptic-config.vue +++ b/src/components/do/b1-ins-order/fiberoptic-config.vue @@ -22,7 +22,7 @@ <label style="width: 70px;">鏍峰搧鍨嬪彿</label> <span style="font-size: 14px;">{{models}}</span> </div> - <el-radio-group v-model="packageInfo.radio" size="small" @change="upNum()" :disabled="active!=1"> + <el-radio-group v-model="packageInfo.radio" size="small" @change="isInspection()" :disabled="active!=1"> <el-radio :label="0">鍏ㄦ</el-radio> <el-radio :label="1">鎶芥</el-radio> </el-radio-group> @@ -31,15 +31,15 @@ style="display: flex;align-items: center;justify-content: space-between;margin-bottom: 8px;padding: 0 12px;box-sizing: border-box;"> <div class="search-item" style="margin-right: 10px;"> <label>濂楃鏁扮洰</label> - <el-input v-model="packageInfo.num1" placeholder="璇疯緭鍏�" size="small" @change="upNum" :disabled="active!=1"></el-input> + <el-input v-model="packageInfo.num1" placeholder="璇疯緭鍏�" size="small" @blur="addBushing" :disabled="active!=1"></el-input> </div> <div class="search-item" style="margin-right: 10px;"> <label style="width: 70px;">鏍囧噯閲�</label> - <el-input v-model="packageInfo.standNum" placeholder="璇疯緭鍏�" size="small" @change="upNum" :disabled="active!=1"></el-input> + <el-input v-model="packageInfo.standNum" placeholder="璇疯緭鍏�" size="small" @blur="addStandNum" :disabled="active!=1"></el-input> </div> <div class="search-item"> <label style="width: 70px;">妫�娴嬮噺</label> - <el-input v-model="packageInfo.testNum" placeholder="璇疯緭鍏�" size="small" @change="upNum" + <el-input v-model="packageInfo.testNum" placeholder="璇疯緭鍏�" size="small" @blur="addTestNum" :disabled="packageInfo.radio===0||active!=1"></el-input> </div> </div> @@ -107,21 +107,22 @@ <el-col :span="12" v-if="packageInfo.ismiers"> <div class="grid-content"> <h5>鍏夌氦甯� - <!-- <el-button size="mini" type="primary" class="btns" @click="addFibers" - :disabled="miresModel===null||miresStandard===null" v-if="active==1">鐢熸垚鍏夌氦甯�</el-button> --> - <el-button size="mini" class="btns" @click="clearFibers" :disabled="selectBushing.length === 0" v-if="active==1">娓呴櫎</el-button> + <el-button size="mini" type="primary" class="btns" @click="addFibers" + v-if="active==1">鐢熸垚鍏夌氦甯�</el-button> + <!-- <el-button size="mini" class="btns" @click="clearFibers" :disabled="selectBushing.length === 0" v-if="active==1">娓呴櫎</el-button> --> </h5> <div style="display: flex;align-items: center;justify-content: space-between;margin:4px 0 6px 0;padding: 0 12px;box-sizing: border-box;"> - <div class="search-item" style="width: 50%;margin-right: 16px;"> + <!-- <div class="search-item" style="width: 50%;margin-right: 16px;"> <label style="width: 80px;">绾ゅ甫绫诲瀷</label> <el-select v-model="miresModel" placeholder="璇烽�夋嫨" size="small" style="width: 100%;" - :disabled="selectBushing.length===0||active!=1"> + :disabled="selectBushing.length===0||active!=1" + > <el-option v-for="(item,a) in miresModels" :key="a" :label="item.label" :value="item.value"> </el-option> </el-select> - </div> - <div class="search-item" style="width: 50%;"> + </div> --> + <!-- <div class="search-item" style="width: 50%;"> <label style="width: 80px;">鍙傝�冩爣鍑�</label> <el-select v-model="miresStandard" placeholder="璇烽�夋嫨" size="small" style="width: 100%;" :disabled="miresModel===null||active!=1" @focus="selectsStandardMethodByFLSSM2()" @@ -129,10 +130,30 @@ <el-option v-for="item in miresStandards" :key="item.id" :label="item.code" :value="item.id"> </el-option> </el-select> + </div> --> + <div class="search-item" style="width: 50%;margin-right: 16px;"> + <label style="width: 80px;">绾ゅ甫绫诲瀷</label> + <el-select v-model="miresModel" placeholder="璇烽�夋嫨" size="small" style="width: 100%;" + :disabled="selectBushing.length===0||active!=1" + > + <el-option v-for="(item,a) in miresModels" :key="a" :label="item.label" :value="item.value"> + </el-option> + </el-select> </div> + <div class="search-item" style="width: 50%;"> + <label style="width: 80px;">鍙傝�冩爣鍑�</label> + <el-select v-model="miresStandard" placeholder="璇烽�夋嫨" size="small" style="width: 100%;" + :disabled="miresModel===null||active!=1" + @focus="selectsStandardMethodByFLSSM2()" + @change="(value)=>methodChange2(value)"> + <el-option v-for="item in miresStandards" :key="item.id" :label="item.code" :value="item.id"> + </el-option> + </el-select> + </div> + </div> <el-table ref="table2" :data="fibersList" tooltip-effect="dark" style="width: 100%" height="270px" - size="small" @selection-change="handleSelectionChange" highlight-current-row @row-click="(row, column, event)=>rowClickFiber(row, column, event,0)" + size="small" @selection-change="handleSelectionChange" highlight-current-row @row-click="(row, column, event)=>rowClickFiber(row, column, event,1)" :header-cell-class-name="setClassName0"> <el-table-column type="selection" @@ -140,12 +161,24 @@ :selectable="()=>(active==1)"> </el-table-column> <el-table-column prop="code" label="鍏夌氦甯︾紪鍙�" show-overflow-tooltip align="center"> + <template slot-scope="scope"> + <el-input v-model="scope.row.code" placeholder="璇疯緭鍏�" size="mini" ></el-input> + </template> </el-table-column> <el-table-column prop="model" label="鍏夌氦甯﹁鏍�" show-overflow-tooltip align="center"> + <template slot-scope="scope"> + <el-input v-model="scope.row.model" placeholder="璇疯緭鍏�" size="mini" ></el-input> + </template> </el-table-column> <el-table-column prop="standard" label="鍙傝�冩爣鍑�" show-overflow-tooltip align="center"> + <template slot-scope="scope"> + <el-input v-model="scope.row.standard" placeholder="璇疯緭鍏�" size="mini" ></el-input> + </template> </el-table-column> <el-table-column prop="num" label="鍏夌氦妫�娴嬮噺" show-overflow-tooltip align="center"> + <template slot-scope="scope"> + <el-input v-model="scope.row.num" placeholder="璇疯緭鍏�" size="mini" ></el-input> + </template> </el-table-column> </el-table> </div> @@ -153,12 +186,12 @@ <el-col :span="!packageInfo.ismiers?24:12"> <div class="grid-content"> <h5>鍏夌氦 - <!-- <el-button size="mini" type="primary" class="btns" @click="addFiber" - :disabled="mireModel===null||mireStandard===null" v-if="active==1">鍏夌氦閰嶈壊</el-button> --> + <el-button size="mini" type="primary" class="btns" @click="addFiber" + v-if="active==1">鍏夌氦閰嶈壊</el-button> </h5> <div style="display: flex;align-items: center;justify-content: space-between;margin: 4px 0 6px 0;padding: 0 12px;box-sizing: border-box;"> - <div class="search-item" style="width: 50%;margin-right: 16px;"> + <!-- <div class="search-item" style="width: 50%;margin-right: 16px;"> <label style="width: 80px;">鍏夌氦绫诲瀷</label> <el-select v-model="mireModel" placeholder="璇烽�夋嫨" size="small" style="width: 100%;" :disabled="selectBushing.length===0||active!=1"> @@ -174,11 +207,29 @@ <el-option v-for="item in mireStandards" :key="item.id" :label="item.code" :value="item.id"> </el-option> </el-select> + </div> --> + <div class="search-item" style="width: 50%;margin-right: 16px;"> + <label style="width: 80px;">鍏夌氦绫诲瀷</label> + <el-select v-model="mireModel" placeholder="璇烽�夋嫨" size="small" style="width: 100%;" + > + <el-option v-for="(item,a) in mireModels" :key="a" :label="item.label" :value="item.value"> + </el-option> + </el-select> + </div> + <div class="search-item" style="width: 50%;"> + <label style="width: 80px;">鍙傝�冩爣鍑�</label> + <el-select v-model="mireStandard" placeholder="璇烽�夋嫨" size="small" style="width: 100%;" + :disabled="mireModel===null||active!=1" + @focus="selectsStandardMethodByFLSSM()" + @change="(value)=>methodChange(value)" :loading="mireStandardLoading"> + <el-option v-for="item in mireStandards" :key="item.id" :label="item.code" :value="item.id"> + </el-option> + </el-select> </div> </div> <el-table ref="table3" :data="fiberList" tooltip-effect="dark" style="width: 100%" height="270px" size="small" highlight-current-row @selection-change="handleSelectionChange4" - @row-click="(row, column, event)=>rowClickFiber(row, column, event,1)" + @row-click="(row, column, event)=>rowClickFiber(row, column, event,0)" :header-cell-class-name="setClassName0"> <el-table-column type="selection" @@ -295,6 +346,7 @@ </template> <script> +import { set } from 'vue' export default { props: { active: { @@ -304,6 +356,8 @@ }, data() { return { + detectionType: null, + detectionSelect: [], type:1, saveLoad: false, packageInfo: { @@ -337,7 +391,7 @@ fiberList: [], fibersList: [], selectFibers: [], - detectionItems:[], + detectionItems: [], currentDetectionItems:null, mireStandardLoading:false, multiFiberList:[], @@ -363,23 +417,23 @@ }, }, watch: { - mireModel(val1,val0) { - if(val1!=val0){ - this.mireStandards = [] - this.fiberList = [] - this.multiFiberList = [] - this.detectionItems = [] - this.currentDetectionItems = null; - } - }, - mireStandard(val1,val0) { - if(val1!=val0){ - this.fiberList = [] - this.multiFiberList = [] - this.detectionItems = [] - this.currentDetectionItems = null; - } - } + // mireModel(val1,val0) { + // if(val1!=val0){ + // this.mireStandards = [] + // this.fiberList = [] + // this.multiFiberList = [] + // this.detectionItems = [] + // this.currentDetectionItems = null; + // } + // }, + // mireStandard(val1,val0) { + // if(val1!=val0){ + // this.fiberList = [] + // this.multiFiberList = [] + // this.detectionItems = [] + // this.currentDetectionItems = null; + // } + // } }, mounted() { this.$parent.sampleIds.forEach(a => { @@ -391,6 +445,7 @@ } } }) + console.log(111, this.sample); this.models = this.models.replace(',', '') this.packageInfo.ismiers = this.models.split(',').every(e=>(e.indexOf('d')>-1||e.indexOf('D')>-1)) if(this.sample[0].bushing === undefined || this.sample[0].bushing === null){ @@ -401,15 +456,27 @@ this.packageInfo.standNum = this.sample[0].bushing[0].standNum this.packageInfo.testNum = this.sample[0].bushing[0].testNum this.bushing.forEach(a=>{ - if(a.fibers===null)a.fibers=[] - if(a.fiber===null)a.fiber=[] + if(a.fibers==null || a.fibers.length ==0)a.fibers=[] + if(a.fiber==null || a.fiber.length == 0)a.fiber=[] + // 鍒ゆ柇鏄惁鍚湁鍏夌氦甯� if(this.packageInfo.ismiers){ - a.fibers.forEach(b=>{ + this.fibersList = [] // 鏂板 + this.fiberList = [] // 鏂板 + if(a.fibers.length>0){ + a.fibers.forEach(b=>{ + // 鍏夌氦甯� this.fibersList.push(b) + // 鍏夌氦 b.fiber.forEach(c=>{ this.fiberList.push(c) }) }) + } else { + a.fiber.forEach(b=>{ + this.fiberList.push(b) + }) + } + }else{ a.fiber.forEach(b=>{ this.fiberList.push(b) @@ -417,9 +484,11 @@ } }) } + this.getTypeDicts1() this.getStandTreeBySampleType() this.getStandTreeBySampleType2() + this.selectsStandardMethodByFLSSM2() }, methods: { handleSelectionChange(val) { @@ -429,7 +498,29 @@ handleSelectionChange1(val) { this.selectBushing = val }, - handleSelectionChange2(val){}, + handleSelectionChange2(val){ + this.detectionSelect = val + // 璧嬪�兼娴嬮」淇℃伅 鍏夌氦甯� + if(this.detectionItems.type == 1) { + for(let i= 0; i < this.fibersList.length; i++){ + this.multiFiberList.forEach(item => { + if(this.fibersList[i].ident == item.ident){ + this.fibersList.find(a => a.ident == item.ident).productList = this.detectionSelect + } + }) + } + } + if(this.detectionItems.type == 0) { + // 璧嬪�兼娴嬮」淇℃伅 鍏夌氦 + this.multiFiberList.forEach(item => { + this.fiberList.forEach(a => { + if(a.ident == item.ident){ + this.fiberList.find(a => a.ident == item.ident).productList = this.detectionSelect + } + }) + }) + } + }, handleSelectionChange4(val){ this.multiFiberList = val }, @@ -442,6 +533,96 @@ }).then(res => { this.colors = res.data }) + }, + // 濂楃鏁扮洰鐢熸垚琛ㄦ牸鏁版嵁 + addBushing() { + this.bushing = [] + for(let i = 0; i < this.packageInfo.num1; i++){ + let bushing = { + ident: this.bushing.length + 1, + color: this.colors[i].label, + standNum: null, + testNum: null, + fibers: [], + fiber: [] + } + this.bushing.push(bushing) + } + }, + // 濂楃鏍囧噯閲忚祴鍊� + addStandNum() { + if(this.selectBushing.length > 0) { + this.bushing.forEach(item => { + this.selectBushing.forEach(a => { + if(item.ident == a.ident) { + item.standNum = this.packageInfo.standNum + } + }) + }) + } + }, + // 濂楃妫�娴嬮噺璧嬪�� + addTestNum() { + if(this.selectBushing.length > 0) { + this.bushing.forEach(item => { + this.selectBushing.forEach(a => { + if(item.ident == a.ident) { + item.testNum = this.packageInfo.testNum + } + }) + }) + } + }, + isInspection() { + this.fiberList = [] + this.fibersList = [] + this.detectionItems = [] + + // 椤甸潰鏄惁鍚湁鍏夌氦甯� + if(this.packageInfo.ismiers) { + // 鍏ㄦ + if (this.packageInfo.radio == 0) { + // 鏍规嵁鏍囧噯閲忚祴鍊兼娴嬮噺 + if(parseInt(this.packageInfo.standNum) > 0 ) { + // 缁欏厜绾ゅ甫璧嬪�� + this.packageInfo.testNum = this.packageInfo.standNum + this.selectBushing = this.bushing + this.addFibers() + this.selectFibers = this.fibersList + // 榛樿鍕鹃�� + setTimeout(() => { + this.selectBushing.forEach(item =>{ + let rowToSelect = this.bushing.find(a => a.ident == item.ident) + this.$refs.table0.toggleRowSelection(rowToSelect, true) + }) + + this.selectFibers.forEach(item =>{ + let rowToSelect = this.fibersList.find(a => a.ident == item.ident) + this.$refs.table2.toggleRowSelection(rowToSelect, true) + }) + }, 200) + } + } + }else { + if(this.packageInfo.radio == 0) { + if(parseInt(this.packageInfo.standNum) > 0 ) { + this.packageInfo.testNum = this.packageInfo.standNum + this.selectBushing = this.bushing + this.addFiber() + + // 榛樿鍕鹃�� + setTimeout(() => { + this.selectBushing.forEach(item =>{ + let rowToSelect = this.bushing.find(a => a.ident == item.ident) + this.$refs.table0.toggleRowSelection(rowToSelect, true) + }) + }, 200) + } + } + } + + + }, upNum() { this.fiberList = [] @@ -477,7 +658,34 @@ } this.bushing.push(bushing) } - } else { + // 缁欏厜绾ゅ甫璧嬪�� + if(this.selectBushing.length===0){ + this.selectBushing = this.bushing + } + // this.miresModels 绾ゅ甫绫诲瀷 + // this.miresStandards 鍙傝�冩爣鍑� + this.fibersList = [] + this.packageInfo.ismiers = true + this.fiberList = [] + this.selectBushing.forEach(a => { + a.fiber = [] + a.fibers = [] + for(let j = 0; j < parseInt(a.testNum); j++){ + let fibers = { + id: this.fibersList.length + 1, + code: null, + color: a.color, + model: null, + standard: null, + num: a.testNum, + productList: this.HaveJson(this.productList2), + fiber: [] + } + a.fibers.push(fibers) + this.fibersList.push(fibers) + } + }) + } else { this.bushing = [] } }, @@ -528,7 +736,46 @@ }) }, methodChange(val) { - if (val === null || val === '') return + // if (val === null || val === '') return + // this.$axios.post(this.$api.standardTree.selectStandardProductList, { + // model: this.mireModel.split(' - ')[1], + // standardMethodListId: val, + // factory: '' + // }, { + // headers: { + // 'Content-Type': 'application/json' + // } + // }).then(res => { + // res.data.forEach(a => { + // a.state = 0 + // }) + // this.productList = res.data + // setTimeout(() => { + // this.productList.forEach(a => { + // if (a.state == 1) this.toggleSelection(a) + // }) + // this.addFiber() + // }, 200) + // }) + + // 灏嗕笅鎷夋鍊艰祴鍊肩粰鍏夌氦 鐩戝惉鍘婚櫎 + if(this.multiFiberList.length == 0) { + this.$message.error('璇烽�夋嫨鏁版嵁') + return + } + this.multiFiberList.forEach(item => { + this.fiberList.forEach(a => { + if(a.ident == item.ident){ + a.model = this.mireModel.split(' - ')[1] // 鍏夌氦瑙勬牸 + a.noSplitModel = this.mireModel // 鍏夌氦瑙勬牸 + if(this.mireStandards != null) { + a.standard = this.mireStandards.find(a => a.id == this.mireStandard).code // 鍙傝�冩爣鍑� + } + } + }) + }) + if (val === null || val === '') return + if(this.mireStandards == null ) return this.$axios.post(this.$api.standardTree.selectStandardProductList, { model: this.mireModel.split(' - ')[1], standardMethodListId: val, @@ -538,19 +785,45 @@ 'Content-Type': 'application/json' } }).then(res => { - res.data.forEach(a => { + this.detectionItems = [] + if(res.data != null && res.data.length != 0){ + res.data.forEach(a => { a.state = 0 }) - this.productList = res.data - setTimeout(() => { - this.productList.forEach(a => { - if (a.state == 1) this.toggleSelection(a) - }) - this.addFiber() - }, 200) + this.detectionItems = res.data + this.detectionType = 0 + this.$set(this.detectionItems,'type',0) + } + }) }, methodChange2(val) { + // if (val === null || val === '') return + // this.$axios.post(this.$api.standardTree.selectStandardProductList, { + // model: '', + // standardMethodListId: val, + // factory: '涓ぉ绉戞妧妫�娴嬩腑蹇� - 閫氫俊浜у搧瀹為獙瀹� - 鍏夌氦甯� - ' + this.miresModel + ' - ', + // }, { + // headers: { + // 'Content-Type': 'application/json' + // } + // }).then(res => { + // res.data.forEach(a => { + // a.state = 0 + // }) + // this.productList2 = res.data + // setTimeout(() => { + // this.productList2.forEach(a => { + // if (a.state == 1) this.toggleSelection(a) + // }) + // this.addFibers() + // }, 200) + // }) + + if(this.multiFiberList.length == 0) { + this.$message.error('璇烽�夋嫨闇�瑕佹洿鏀圭殑鏁版嵁') + return + } if (val === null || val === '') return this.$axios.post(this.$api.standardTree.selectStandardProductList, { model: '', @@ -561,19 +834,37 @@ 'Content-Type': 'application/json' } }).then(res => { - res.data.forEach(a => { - a.state = 0 - }) - this.productList2 = res.data - setTimeout(() => { - this.productList2.forEach(a => { - if (a.state == 1) this.toggleSelection(a) + // 灏嗚幏鍙栫殑妫�娴嬮」淇℃伅璧嬪�� + this.detectionItems = [] + if(res.data != null && res.data.length != 0){ + res.data.forEach(a => { + a.state = 0 }) - this.addFibers() - }, 200) - }) + this.detectionItems = res.data + this.detectionType = 1 + this.$set(this.detectionItems,'type',1) + } + + // 缁欓�変腑鐨勫厜绾ゅ甫璧嬪�� + for(let i= 0; i < this.fibersList.length; i++){ + this.multiFiberList.forEach(item => { + if(this.fibersList[i].ident == item.ident){ + this.fibersList[i].model = this.miresModel // 绾ゅ甫瑙勬牸 + this.fibersList[i].num = this.miresModel.replace('鑺�','') // 鍏夌氦妫�娴嬮噺 + this.fibersList[i].productList = this.detectionItems // 妫�娴嬮」 + this.miresStandards.forEach(a => { + if(a.id == this.miresStandard) { + this.fibersList[i].standard = a.code // 鍙傝�冩爣鍑� + } + }) + } + }) + } + }) }, addFiber() { + + // 鏈�鏂� let colors2 = [] if (this.packageInfo.num1 / this.colors.length > 1) { let num = this.packageInfo.num1 / this.colors.length @@ -585,25 +876,23 @@ colors2 = colors2.concat(this.colors) } this.fiberList = [] - let model = this.mireModel.split(' - ')[1] - let standard = this.mireStandards.find(a => a.id == this.mireStandard).code + // 閫夋嫨浜嗗厜绾ゅ甫 if (this.packageInfo.ismiers) { - if(this.selectFibers.length === 0){ - this.$message.error('鏈�夋嫨鍏夌氦甯�') - return - } + if(this.selectFibers.length != 0){ this.selectFibers.forEach((a,index) => { a.fiber = [] for (var i = 0; i < parseInt(a.num); i++) { let fiber = { + ident: this.fiberList.length + 1, bushColor: a.color, color: colors2[(i+(parseInt(a.num)*index))>colors2.length?0:i+(parseInt(a.num)*index)*index].label, - model: model, - standard: standard, - productList: this.HaveJson(this.productList) + model: null, + noSplitModel: null, + standard: null, + fibersIdent: a.ident, + productList: [] } - a.fiber.push(fiber) - this.fiberList.push(fiber) + this.fiberList.push(fiber) } }) } else { @@ -611,85 +900,321 @@ a.fiber = [] for (var i = 0; i < parseInt(a.testNum); i++) { let fiber = { + ident: this.fiberList.length + 1, bushColor: a.color, color: colors2[(i+(parseInt(a.testNum))*index)>colors2.length?0:i+(parseInt(a.testNum))*index].label, - model: model, - standard: standard, - productList: this.HaveJson(this.productList) + model: null, + standard: null, + productList: [] } - a.fiber.push(fiber) this.fiberList.push(fiber) } }) } + }else { + this.fiberList = [] + let flag = true + // 鎸夌収椤哄簭鐢熸垚鍏夌氦鑹叉爣 + let colors2 = [] + if (this.packageInfo.num1 / this.colors.length > 1) { + let num = this.packageInfo.num1 / this.colors.length + if (this.packageInfo.num1 % this.colors.length > 0) num += 1 + for (var i = 0; i < num; i++) { + colors2 = colors2.concat(this.colors) + } + } else { + colors2 = colors2.concat(this.colors) + } + // 鏍规嵁濂楃鐨勬祴璇曢噺鐢熸垚瀵瑰簲鐨勬暟閲忕殑鍏夌氦鏁版嵁 + this.selectBushing.forEach((item,index) =>{ + if(item.testNum != null && item.testNum != ''){ + for(let i =0; i < parseInt(item.testNum); i++){ + let fiber = { + ident: this.fiberList.length + 1, + bushColor: item.color, + color: colors2[(i+(parseInt(item.testNum)*index))>colors2.length?0:i+(parseInt(item.testNum)*index)*index].label, + model: null, + standard: null, + productList: [] + } + this.fiberList.push(fiber) + } + }else { + flag = false + } + }) + if(!flag){ + this.$message.error('璇峰~鍐欏厜绾ゆ娴嬮噺') + return + } + } + // 浜屼唬 + // // 鏄惁閫夋嫨濂楃 + // if(this.selectBushing.length == 0) { + // this.$message.error('鏈�夋嫨濂楃') + // return + // } + // this.fiberList = [] + // let flag = true + // // 鎸夌収椤哄簭鐢熸垚鍏夌氦鑹叉爣 + // let colors2 = [] + // if (this.packageInfo.num1 / this.colors.length > 1) { + // let num = this.packageInfo.num1 / this.colors.length + // if (this.packageInfo.num1 % this.colors.length > 0) num += 1 + // for (var i = 0; i < num; i++) { + // colors2 = colors2.concat(this.colors) + // } + // } else { + // colors2 = colors2.concat(this.colors) + // } + // // 鏍规嵁濂楃鐨勬祴璇曢噺鐢熸垚瀵瑰簲鐨勬暟閲忕殑鍏夌氦鏁版嵁 + // this.selectBushing.forEach((item,index) =>{ + // if(item.testNum != null && item.testNum != ''){ + // for(let i =0; i < parseInt(item.testNum); i++){ + // let fiber = { + // ident: this.fiberList.length + 1, + // bushColor: item.color, + // color: colors2[(i+(parseInt(item.testNum)*index))>colors2.length?0:i+(parseInt(item.testNum)*index)*index].label, + // model: null, + // standard: null, + // productList: [] + // } + // this.fiberList.push(fiber) + // } + // }else { + // flag = false + // } + // }) + // if(!flag){ + // this.$message.error('璇峰~鍐欏厜绾ゆ娴嬮噺') + // return + // } + + + // 鏈�鍒� + // let colors2 = [] + // if (this.packageInfo.num1 / this.colors.length > 1) { + // let num = this.packageInfo.num1 / this.colors.length + // if (this.packageInfo.num1 % this.colors.length > 0) num += 1 + // for (var i = 0; i < num; i++) { + // colors2 = colors2.concat(this.colors) + // } + // } else { + // colors2 = colors2.concat(this.colors) + // } + // this.fiberList = [] + // let model = this.mireModel.split(' - ')[1] + // let standard = this.mireStandards.find(a => a.id == this.mireStandard).code + // if (this.packageInfo.ismiers) { + // if(this.selectFibers.length === 0){ + // this.$message.error('鏈�夋嫨鍏夌氦甯�') + // return + // } + // this.selectFibers.forEach((a,index) => { + // a.fiber = [] + // for (var i = 0; i < parseInt(a.num); i++) { + // let fiber = { + // bushColor: a.color, + // color: colors2[(i+(parseInt(a.num)*index))>colors2.length?0:i+(parseInt(a.num)*index)*index].label, + // model: model, + // standard: standard, + // productList: this.HaveJson(this.productList) + // } + // a.fiber.push(fiber) + // this.fiberList.push(fiber) + // } + // }) + // } else { + // this.selectBushing.forEach((a,index) => { + // a.fiber = [] + // for (var i = 0; i < parseInt(a.testNum); i++) { + // let fiber = { + // bushColor: a.color, + // color: colors2[(i+(parseInt(a.testNum))*index)>colors2.length?0:i+(parseInt(a.testNum))*index].label, + // model: model, + // standard: standard, + // productList: this.HaveJson(this.productList) + // } + // a.fiber.push(fiber) + // this.fiberList.push(fiber) + // } + // }) + // } }, addFibers() { - if(this.selectBushing.length===0){ + // if(this.selectBushing.length===0){ + // this.$message.error('鏈�夋嫨濂楃') + // return + // } + // this.fibersList = [] + // let standard = this.miresStandards.find(a => a.id == this.miresStandard).code + // this.packageInfo.ismiers = true + // this.fiberList = [] + // this.selectBushing.forEach(a => { + // a.fiber = [] + // a.fibers = [] + // for (var i = 0; i < parseInt(a.testNum); i++) { + // let fibers = { + // code: null, + // color: a.color, + // model: this.miresModel, + // standard: standard, + // num: a.testNum, + // productList: this.HaveJson(this.productList2), + // fiber: [] + // } + // a.fibers.push(fibers) + // this.fibersList.push(fibers) + // } + // }) + + if(this.selectBushing.length == 0) { this.$message.error('鏈�夋嫨濂楃') return } + // 濂楃鐨勬祴璇曢噺 * 閫夋嫨鐨勫厜绾ゅ甫鏁伴噺 this.fibersList = [] - let standard = this.miresStandards.find(a => a.id == this.miresStandard).code - this.packageInfo.ismiers = true - this.fiberList = [] - this.selectBushing.forEach(a => { - a.fiber = [] - a.fibers = [] - for (var i = 0; i < parseInt(a.testNum); i++) { - let fibers = { - code: null, - color: a.color, - model: this.miresModel, - standard: standard, - num: a.testNum, - productList: this.HaveJson(this.productList2), - fiber: [] - } - a.fibers.push(fibers) - this.fibersList.push(fibers) + this.selectBushing.forEach(item => { + for(let i = 0; i < parseInt(this.packageInfo.testNum); i++){ + let fibers = { + ident: this.fibersList.length + 1, + color: item.color, + code: null, + model: null, + standard: null, + num: null, + fiber: [], + productList: [] } + this.fibersList.push(fibers) + } }) }, rowClickFiber(row, column, event,type){ - this.type = type - if(this.active===1){ - if(type==0){ - let standard = null; - try{ - standard = this.miresStandards.find(a => a.id == this.miresStandards) - }catch(e){} - if(standard&&standard.code=='濮旀墭瑕佹眰'){ - this.isAskOnlyRead = false; - }else{ - this.isAskOnlyRead = true; - } - }else{ - let standard = null; - try{ - standard = this.mireStandards.find(a => a.id == this.mireStandard) - }catch(e){} - if(standard&&standard.code=='濮旀墭瑕佹眰'){ - this.isAskOnlyRead = false; - }else{ - this.isAskOnlyRead = true; - } - } + console.log('row',row); + // this.type = type + // if(this.active===1){ + // if(type==0){ + // let standard = null; + // try{ + // standard = this.miresStandards.find(a => a.id == this.miresStandards) + // }catch(e){} + // if(standard&&standard.code=='濮旀墭瑕佹眰'){ + // this.isAskOnlyRead = false; + // }else{ + // this.isAskOnlyRead = true; + // } + // }else{ + // let standard = null; + // try{ + // standard = this.mireStandards.find(a => a.id == this.mireStandard) + // }catch(e){} + // if(standard&&standard.code=='濮旀墭瑕佹眰'){ + // this.isAskOnlyRead = false; + // }else{ + // this.isAskOnlyRead = true; + // } + // } + // } + // if(this.type==1){ + // if (this.active !== 1) { + // this.sampleIds = [] + // this.sampleIds.push(row.id) + // } + // } + // this.currentDetectionItems = row + // this.detectionItems = row.productList + // if(this.detectionItems === null) return + // setTimeout(() => { + // this.detectionItems.forEach(a => { + // if (a.state == 1) this.toggleSelection(a) + // }) + // }, 200) + if(type == 1) { + if(row.model != null && row.model != ''){ + this.miresModel = row.model + this.selectsStandardMethodByFLSSM2() } - if(this.type==1){ - if (this.active !== 1) { - this.sampleIds = [] - this.sampleIds.push(row.id) - } - } - this.currentDetectionItems = row - this.detectionItems = row.productList - if(this.detectionItems === null) return setTimeout(() => { - this.detectionItems.forEach(a => { - if (a.state == 1) this.toggleSelection(a) + if(row.standard !=null && row.standard != ''){ + this.miresStandard = this.miresStandards.find(a => a.code == row.standard).id + } + this.$axios.post(this.$api.standardTree.selectStandardProductList, { + model: '', + standardMethodListId: this.miresStandard, + factory: '涓ぉ绉戞妧妫�娴嬩腑蹇� - 閫氫俊浜у搧瀹為獙瀹� - 鍏夌氦甯� - ' + this.miresModel + ' - ', + }, { + headers: { + 'Content-Type': 'application/json' + } + }).then(res => { + // 灏嗚幏鍙栫殑妫�娴嬮」淇℃伅璧嬪�� + this.detectionItems = [] + if(res.data != null && res.data.length != 0){ + res.data.forEach(a => { + a.state = 0 + }) + this.detectionItems = res.data + this.detectionType = 1 + this.$set(this.detectionItems,'type',1) + + if (row.productList != null && row.productList.length > 0) { + setTimeout(() => { + row.productList.forEach(product => { + let rowToSelect = this.detectionItems.find(item => item.id === product.id); + if (rowToSelect) { + this.toggleSelection(rowToSelect); + } + }); + },200) + + } + } + }) + },1000) + }else if(type == 0) { + if(row.model != null && row.model != ''){ + this.mireModel = row.noSplitModel + this.selectsStandardMethodByFLSSM() + } + setTimeout(() => { + if(row.standard !=null && row.standard != ''){ + this.mireStandard = this.mireStandards.find(a => a.code == row.standard).id + } + this.$axios.post(this.$api.standardTree.selectStandardProductList, { + model: this.mireModel.split(' - ')[1], + standardMethodListId: this.mireStandard, + factory: '' + }, { + headers: { + 'Content-Type': 'application/json' + } + }).then(res => { + this.detectionItems = [] + if(res.data != null && res.data.length != 0){ + res.data.forEach(a => { + a.state = 0 }) - }, 200) - }, + this.detectionItems = res.data + this.detectionType = 0 + this.$set(this.detectionItems,'type',0) + + if (row.productList != null && row.productList.length > 0) { + setTimeout(() => { + row.productList.forEach(product => { + let rowToSelect = this.detectionItems.find(item => item.id === product.id); + if (rowToSelect) { + this.toggleSelection(rowToSelect); + } + }); + },200) + } + } + + }) + },1000); + } + }, toggleSelection(row) { this.$refs.productTable.toggleRowSelection(row, true); }, @@ -704,6 +1229,7 @@ }, handleAll(e) { if (e.length > 0) { + console.log(this.detectionItems); this.detectionItems.map(m => { m.state = 1 return m @@ -881,16 +1407,40 @@ }) }, save(){ - if(this.bushing.length === 0){ - this.$message.error('缂哄皯閰嶇疆鏃犳硶淇濆瓨') - return - } + // if(this.bushing.length === 0){ + // this.$message.error('缂哄皯閰嶇疆鏃犳硶淇濆瓨') + // return + // } // for(let a in this.bushing){ // if(this.bushing[a].fibers.length===0&&this.bushing[a].fiber.length===0){ // this.$message.error(this.bushing[a].color+'绠¤壊鏍囧绠$己灏戦厤缃棤娉曚繚瀛�') // return // } // } + // this.sample.forEach(a=>{ + // a.bushing = this.bushing + // }) + // this.$message.success('宸蹭繚瀛�') + // this.$emit('saveFiberopticConfig') + + if(this.bushing.length === 0){ + this.$message.error('缂哄皯濂楃鏃犳硶淇濆瓨') + return + } + this.bushing.forEach(item=>{ + // 濡傛灉鍏夌氦甯︽湁鍊� + if(this.fibersList.length != 0) { + this.fibersList.forEach(a=>{ + a.fiber = this.fiberList.filter(b=>b.fibersIdent == a.ident) + }) + item.fibers = this.fibersList // 鍏夌氦甯� + item.fiber = [] // 鍏夌氦 + }else { + // 濡傛灉鍏夌氦甯︽病鏈夊�� + item.fibers = [] // 鍏夌氦甯� + item.fiber = this.fiberList // 鍏夌氦 + } + }) this.sample.forEach(a=>{ a.bushing = this.bushing }) diff --git a/src/components/do/b1-inspect-order-plan/Inspection.vue b/src/components/do/b1-inspect-order-plan/Inspection.vue index 2f55a89..cf1bc9f 100644 --- a/src/components/do/b1-inspect-order-plan/Inspection.vue +++ b/src/components/do/b1-inspect-order-plan/Inspection.vue @@ -943,6 +943,7 @@ requiredUp: [] }, upIndex: 0, + changeType:null, getReportModelLoading:false, insOrder: {}, sampleProduct: [], @@ -1142,7 +1143,16 @@ }) }, currentTable(val1, val0) { - if (val0 != null && val1 != val0) { + if(val0 !=null && val1 != val0){ + if(this.tableLists.find(m=>m.templateId==val1)&&(this.tableLists.find(m=>m.templateId==val1).templateName=='鎴愬搧缂嗘楠屽師濮嬭褰�')){ + if(this.casing.length>0){ + this.handleChange(this.casing[0].id,3) + } + return + } + if(this.changeType && this.changeType>0){ + return + } this.tableLists.forEach(async (m, i) => { if (m.templateId == val1) { let list = await this.getCurrentProduct(this.currentSample.id,0) @@ -1185,11 +1195,6 @@ } }) this.handleCasing() - if(this.tableLists.find(m=>m.templateId==val1)&&(this.tableLists.find(m=>m.templateId==val1).templateName=='鎴愬搧缂嗘楠屽師濮嬭褰�')){ - if(this.casing.length>0){ - this.handleChange(this.casing[0].id,3) - } - } } }, equipForm:{ @@ -1351,7 +1356,6 @@ maxNum = num } } - console.log('data[i][j].equipName',data[i][j].equipName,'data[i][j].equipValue',data[i][j].equipValue,'m.v',m.v,'m.v.ps',m.v.ps,'m.v.ps.value',m.v.ps.value,'str0',str0,'str',str,'m.v.v',m.v.v) if(data[i][j].equipName&&data[i][j].equipValue&&m.v&&m.v.ps&&m.v.ps.value=='璁惧缂栫爜'&&str0==str){ if(!m.v.v){ this.changeEquip(data[i][j].equipValue,m,data[i][j].equipName) @@ -2094,6 +2098,7 @@ }) }, async handleChange(m,type){ + this.changeType = type; if(m){ let list = await this.getCurrentProduct(m,type) if(list.length>0){ diff --git a/src/components/view/b1-inspect-order-plan.vue b/src/components/view/b1-inspect-order-plan.vue index 03204c7..ea39299 100644 --- a/src/components/view/b1-inspect-order-plan.vue +++ b/src/components/view/b1-inspect-order-plan.vue @@ -345,7 +345,7 @@ type: 'text', method: 'claimFun', disabFun: (row, index) => { - return row.userName != null||(row.userName&&!row.userName.includes(JSON.parse(localStorage.getItem("user")).name)) + return row.userName != null || row.checkName!=null } } ], -- Gitblit v1.9.3