From 142ba3ed00220dcadf2a94e59664d5f1f027dbf4 Mon Sep 17 00:00:00 2001 From: licp <lichunping@guanfang.com.cn> Date: 星期三, 05 六月 2024 14:58:26 +0800 Subject: [PATCH] 新增附件上传 --- src/components/do/b1-inspect-order-plan/Inspection.vue | 286 ++++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 264 insertions(+), 22 deletions(-) diff --git a/src/components/do/b1-inspect-order-plan/Inspection.vue b/src/components/do/b1-inspect-order-plan/Inspection.vue index d26207a..ba5a5bb 100644 --- a/src/components/do/b1-inspect-order-plan/Inspection.vue +++ b/src/components/do/b1-inspect-order-plan/Inspection.vue @@ -120,6 +120,19 @@ .collection:active { opacity: .7; } + .table_caret{ + font-size: 16px; + margin: 0 5px; + color: rgba(0, 0, 0, 0.1); + } + .table_caret:hover{ + color: #409eff; + cursor: pointer; + } + + .table_caret:active{ + opacity: .8; + } </style> <style> .inspection .el-form-item__label { @@ -168,6 +181,11 @@ .inspection .el-textarea__inner { min-height: 100% !important; + } + + .inspection .tables .el-input{ + display: flex; + align-items: center; } </style> <template> @@ -224,7 +242,7 @@ size="small">{{ item.templateName }}</el-radio-button> </el-radio-group> </div> - <div class="center-box" id="nav"> + <div class="center-box" id="nav" v-loading="tableLoading"> <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"> @@ -285,6 +303,16 @@ </el-select> --> <span :style="`font-family:${n.v.ff} !important;`">{{n.v.v}}</span> </template> + <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='鏍峰搧缂栧彿'"> + <div style="display: flex;flex-wrap: nowrap;align-items: center;"> + <i class="el-icon-caret-left table_caret" @click="caretSample(-1)"></i> + <div :style="`font-family:${n.v.ff} !important;`">{{currentSample.sampleCode}}</div> + <i class="el-icon-caret-right table_caret" @click="caretSample(1)"></i> + </div> + </template> + <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='鏍峰搧鍨嬪彿'"> + <div :style="`font-family:${n.v.ff} !important;`" v-if="currentSample.model!==undefined&¤tSample.model!==null">{{currentSample.model}}</div> + </template> <span v-else :style="`font-family:${n.v.ff} !important;`">{{n.v.v}}</span> </div> </td> @@ -292,6 +320,19 @@ </tbody> </table> </div> + <el-upload :action="action" + :data="{ + orderId:id + }" + v-show="state==1" + :on-success="handleSuccessUp" :show-file-list="false" + accept='.jpg,.jpeg,.png,.gif,.doc,.docx,.xls,.xlsx,.ppt,.pptx,.pdf,.zip,.rar' :headers="headers" :on-change="beforeUpload" + :on-error="onError" ref='upload'> + <el-button size="small" type="primary" :loading="upLoading">闄勪欢涓婁紶</el-button></el-upload> + <ValueTable class="value-table" ref="fileList" :url="$api.insOrderPlan.getFileList" + :componentData="componentData0" + :delUrl="$api.insOrderPlan.delfile" + :key="upIndex" style="height: 100%;margin-top: 16px;"/> </div> <el-drawer title="鍏夌氦鍒囨崲" :visible.sync="fiberOpticVisible" :size="500"> <el-table class="el-table" ref="fiberOpticTable" :data="fiberOptic" height="100%" tooltip-effect="dark" border @@ -325,9 +366,9 @@ :current-row-key="currentKey" :row-key="record=>record.index" v-if="bushingVisible"> <el-table-column type="index" align="center" label="搴忓彿" width="70px" :key="Math.random()"> </el-table-column> - <el-table-column prop="color" label="绠¤壊鏍�" min-width="110px" show-overflow-tooltip></el-table-column> - <el-table-column prop="num2" label="鏍囬噺" min-width="110px" show-overflow-tooltip></el-table-column> - <el-table-column prop="num3" label="娴嬭瘯閲�" min-width="90px" show-overflow-tooltip></el-table-column> + <el-table-column prop="color" label="绠¤壊鏍�" min-width="100px" show-overflow-tooltip></el-table-column> + <el-table-column prop="standNum" label="鏍囬噺" min-width="100px" show-overflow-tooltip></el-table-column> + <el-table-column prop="testNum" label="娴嬭瘯閲�" min-width="100px" show-overflow-tooltip></el-table-column> </el-table> </el-drawer> <el-drawer title="鏍峰搧鍒囨崲" :visible.sync="sampleVisible" :size="500"> @@ -394,6 +435,7 @@ <script> import ValueTable from '../../tool/value-table.vue' + import file from '../../../util/file' export default { props: ['sonLaboratory', 'orderId', 'state'], components: { @@ -435,6 +477,53 @@ requiredAdd: [], requiredUp: [] }, + componentData0: { + entity: { + insOrderId:'' + }, + isIndex: true, + showSelect: false, + select: false, + selectMethod: '', + sort: false, + init:false, + do: [ + { + id: 'delete', + font: '鍒犻櫎', + type: 'text', + method: 'doDiy', + disabFun: (row, index) => { + return this.state!=1 + } + }, { + id: 'handleDown', + font: '涓嬭浇', + type: 'text', + method: 'handleDown' + }, + ], + isPage: false, + linkEvent: {}, + tagField: { + type:{ + select:[ + { + value: 1, + label: '鍥剧墖' + }, + { + value: 2, + label: '鏂囦欢' + } + ] + } + }, + currentId: '', + selectField: {}, + requiredAdd: [], + requiredUp: [] + }, upIndex: 0, insOrder: {}, sampleProduct: [], @@ -470,8 +559,20 @@ currentFiberOpticTape:null,//褰撳墠鍏夌氦甯� currentFiberOptic:null,//褰撳墠鍏夌氦 currentBushing:null,//褰撳墠濂楃 + tableLoading:false, + upLoading:false } }, + computed: { + headers() { + return { + 'token': sessionStorage.getItem('token') + } + }, + action() { + return this.javaApi + this.$api.insOrderPlan.uploadFile + } + }, created() { this.componentData.entity.sonLaboratory = this.sonLaboratory; this.id = this.orderId; @@ -490,15 +591,19 @@ this.$axios.post(this.$api.insOrderPlan.doInsOrder, { id: val, laboratory: this.sonLaboratory - }).then(res => { + }).then(async res => { this.insOrder = res.data.insOrder; + this.componentData0.entity.insOrderId = val; + this.$refs.fileList.selectList() 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] + this.currentSample = this.HaveJson(this.sampleProduct[0]) + let list = await this.getCurrentProduct(this.currentSample.id,0) + this.currentSample.insProduct = this.HaveJson(list) this.currentSample.insProduct.forEach(a => { this.param[a.id] = { insValue: [], @@ -510,6 +615,7 @@ } }) if (this.currentSample.index == undefined) this.currentSample['index'] = 1 + let bushing = this.currentSample.bushing this.loading = false // this.handleTableData() this.getTableLists(); @@ -523,6 +629,9 @@ this.currentFiberOptic = null; this.bushing = [] this.currentBushing = null; + if(bushing&&bushing.length>0){ + this.bushing = bushing + } }) }, currentTable(val1, val0) { @@ -538,6 +647,12 @@ } }, methods: { + async getCurrentProduct(id,type){ + this.tableLoading = true; + let res = await this.$axios.post(this.$api.insOrderPlan.getInsProduct+'?id='+id+'&type='+type+'&laboratory='+this.sonLaboratory) + this.tableLoading = false; + return res.data + }, handleChangeBushing(row, column, event){ this.currentBushing = row; this.fiberOpticTape = [] @@ -553,7 +668,7 @@ } this.bushingVisible = false; }, - handleChangeOptic(row, column, event){ + async handleChangeOptic(row, column, event){ this.currentFiberOptic = row; this.currentFiberOptic.productList.forEach(a => { this.param[a.id] = { @@ -565,11 +680,12 @@ insResult: null } }) - this.getTableLists0(row) this.fiberOpticVisible = false; + let list = await this.getCurrentProduct(row.id,2) + this.getTableLists0(list) this.currentKey = row.index }, - handleChangeTape(row, column, event){ + async handleChangeTape(row, column, event){ this.currentFiberOpticTape = row; this.param = {} this.fiberOptic = [] @@ -584,16 +700,16 @@ insResult: null } }) - this.getTableLists0(row) + this.fiberOpticTapeVisible = false; + let list = await this.getCurrentProduct(row.id,1) + this.getTableLists0(list) if(row.fiber&&row.fiber.length>0){ // 閰嶇疆鍏夌氦 this.fiberOptic = row.fiber; } - this.fiberOpticTapeVisible = false; this.currentKey = row.index }, - handleChangeSample(row, column, event) { - this.currentSample = row; + async handleChangeSample(row, column, event) { this.param = {} // 娓呯┖鍏夌氦閰嶇疆鐩稿叧鏁版嵁 this.fiberOpticTape = [] @@ -602,7 +718,10 @@ this.currentFiberOptic = null; this.bushing = [] this.currentBushing = null; - + this.sampleVisible = false; + this.currentSample = this.HaveJson(row) + let list = await this.getCurrentProduct(row.id,0) + this.currentSample.insProduct = this.HaveJson(list) this.currentSample.insProduct.forEach(a => { this.param[a.id] = { insValue: [], @@ -613,13 +732,12 @@ insResult: null } }) - let bushing = this.currentSample.insProduct.bushing + let bushing = this.currentSample.bushing if(bushing&&bushing.length>0){ this.bushing = bushing } // this.handleTableData() this.getTableLists(); - this.sampleVisible = false; this.currentKey = row.index }, handleChangeTask(row) { @@ -711,9 +829,9 @@ } }, // 鍏夌氦閰嶇疆鐩稿叧妯℃澘table鍒楄〃 - getTableLists0(obj){ + getTableLists0(list){ const mySet1 = new Set(); - this.tableLists = obj.productList.filter(m => { + this.tableLists = list.filter(m => { let num0 = mySet1.size; if (m.templateId != null&&m.template != null) { mySet1.add(JSON.stringify({ @@ -730,6 +848,7 @@ this.tableList = null; this.tableList = [this.tableLists[0]] this.currentTable = this.tableLists[0].templateId; + this.currentSample.insProduct = this.HaveJson(list) this.handleTableData() } }, @@ -1021,6 +1140,15 @@ return res < m.split('<')[1] }else if (m.includes('>')) { return res > m.split('>')[1] + }else if (m.includes('~')) { + let k = m.split('~') + return res >= k[0] && res <= k[1] + }else if(m.includes('-')){ + let k = m.split('-') + return res >= k[0] && res <= k[1] + }else if(m.includes('卤')){ + let k = m.split('卤') + return res >= (k[0] - k[1]) && res <= (k[0] + k[1]) } }) if(this.getInspectionValueType(item.i)==1){ @@ -1360,20 +1488,67 @@ } this.addVerifyDia = false this.submitLoading = true; - this.$axios.post(this.$api.insOrderPlan.submitPlan, { + this.$axios.post(this.$api.insOrderPlan.checkSubmitPlan, { orderId: this.orderId, laboratory: this.sonLaboratory, - verifyUser: this.verifyUser }).then(res => { if (res.code === 200) { - this.$message.success("鎿嶄綔鎴愬姛") - this.$emit('goback') + console.log(res.data) + if(!res.data||res.data.length==0){ + this.$axios.post(this.$api.insOrderPlan.submitPlan, { + orderId: this.orderId, + laboratory: this.sonLaboratory, + verifyUser: this.verifyUser + }).then(res => { + if (res.code === 200) { + this.$message.success("鎿嶄綔鎴愬姛") + this.$emit('goback') + } + this.submitLoading = false; + }).catch(error => { + console.error(error) + this.submitLoading = false; + }) + }else{ + let newData = [] + const h = this.$createElement + for (let i in res.data) { + const lastChar = res.data[i].slice(-1); + if(lastChar=='-'){ + res.data[i] = res.data[i].slice(0, -1); + } + newData.push(h('p', {style: 'font-size: 12px;'}, (Number(i)+1)+'銆�'+res.data[i])) + } + newData.push(h('p', { style: 'font-size: 16px;color:#000;margin-top:12px' },'浠ヤ笂椤圭洰涓嶅悎鏍硷紝纭畾鎻愪氦锛�')) + this.$confirm('鎻愮ず',{ + title:'鎻愮ず', + message: h('div', null, newData), + confirmButtonText: "纭畾", + cancelButtonText: "鍙栨秷", + type: "" + }).then(() => { + this.$axios.post(this.$api.insOrderPlan.submitPlan, { + orderId: this.orderId, + laboratory: this.sonLaboratory, + verifyUser: this.verifyUser + }).then(res => { + if (res.code === 200) { + this.$message.success("鎿嶄綔鎴愬姛") + this.$emit('goback') + } + }).catch(error => { + console.error(error) + }) + }).catch(() => {}) + } + } this.submitLoading = false; }).catch(error => { console.error(error) this.submitLoading = false; }) + return }, saveInsContext() { this.$axios.post(this.$api.insOrderPlan.saveInsContext, { @@ -1436,6 +1611,73 @@ nav.addEventListener("mouseleave", function(event) { flag = false; }); + }, + async caretSample(num){ + let index = this.currentKey + num + if(index < 1){ + this.$message.error('褰撳墠鏄涓�涓牱鍝�') + return + } else if(index > this.sampleProduct.length){ + this.$message.error('褰撳墠鏄渶鍚庝竴涓牱鍝�') + return + } + this.currentKey = index + this.currentSample = this.HaveJson(this.sampleProduct[index - 1]) + let list = await this.getCurrentProduct(this.currentSample.id,0) + this.currentSample.insProduct = this.HaveJson(list) + this.currentSample.insProduct.forEach(a => { + this.param[a.id] = { + insValue: [], + comValue: [], + resValue: null, + equipValue: [], + equipName: [], + insResult: null + } + }) + this.getTableLists() + }, + handleSuccessUp(response, ) { + this.upLoading = false; + if (response.code == 200) { + this.$message.success('涓婁紶鎴愬姛'); + this.$refs.fileList.selectList() + } + }, + beforeUpload(file) { + if (file.size > 1024 * 1024 * 10) { + this.$message.error('涓婁紶鏂囦欢涓嶈秴杩�10M'); + this.$refs.upload.clearFiles() + return false; + } else { + this.upLoading = true; + return true; + } + }, + onError(err, file, fileList) { + this.$message.error('涓婁紶澶辫触') + this.$refs.upload.clearFiles() + }, + handleDown(row){ + this.$axios.post(this.$api.insOrderPlan.downFile, { + id: row.id, + }).then(res => { + if (res.code === 200) { + let url = ''; + if(res.data.type==1){ + url = this.javaApi+'/img/'+res.data.url + file.downloadIamge(url,row.fileName) + }else{ + url = this.javaApi+'/word/'+res.data.url + const link = document.createElement('a'); + link.href = url; + link.download = row.fileName; + link.click(); + } + } + }).catch(error => { + + }) } } } -- Gitblit v1.9.3