From 53a636b260e4a879d51e526cd8e98a72e8b1b6a5 Mon Sep 17 00:00:00 2001 From: zss <zss@example.com> Date: 星期一, 04 十二月 2023 17:14:48 +0800 Subject: [PATCH] 修复工序 --- src/views/quality/packageinspect/packageInspect-form.vue | 288 ++++++++++++++++++++++++++++----------------------------- 1 files changed, 140 insertions(+), 148 deletions(-) diff --git a/src/views/quality/packageinspect/packageInspect-form.vue b/src/views/quality/packageinspect/packageInspect-form.vue index 5fbff88..891b0dd 100644 --- a/src/views/quality/packageinspect/packageInspect-form.vue +++ b/src/views/quality/packageinspect/packageInspect-form.vue @@ -3,10 +3,10 @@ <div class="page-header"> <div class="header-left"> <a @click="$router.go(-1)"><i class="icon-btn-back"></i></a> - <h2>缂栬緫-鍖呰妫�楠�</h2> + <h2 v-if="resultVal=='' || resultVal==null">缂栬緫-鍖呰妫�楠�</h2> + <h2 v-else>鏌ョ湅-鍖呰妫�楠�</h2> </div> <div class="btn-group header-right"> - <el-button @click="save()" type="primary">淇濆瓨</el-button> </div> </div> <div class="page-main"> @@ -63,10 +63,14 @@ </el-form> </div> <div class="packageInspect-detail"> - <el-row style="width:100%;z-index: 10;height:50px;"> - <el-col :span="22">妫�楠岄」鐩�</el-col> + <el-row :gutter="10" style="width:100%;z-index: 10;height:50px;"> + <el-col :span="20">妫�楠岄」鐩�</el-col> <el-col :span="2"> - <el-button style="width:100%" size="small" @click="clickAddLine()">娣诲姞妫�楠岄」鐩�</el-button> + <el-button v-if="resultVal=='' || resultVal==null" style="width:100%" size="small" @click="clickAddLine()">娣诲姞妫�楠岄」鐩�</el-button> + </el-col> + <el-col :span="2"> + <el-button v-if="resultVal=='' || resultVal==null" style="width:100%" type="primary" size="small" + @click="savePackIns()">淇濆瓨</el-button> </el-col> </el-row> <el-row style="width:100%;"> @@ -86,40 +90,41 @@ </el-table-column> <el-table-column prop="name" label="椤圭洰" width="260"> <template slot-scope="scope"> - <el-input v-if="scope.row.children" class="inline-input" style="width:90%;" v-model="scope.row.name" + <el-input :readonly="resultVal!=null" v-if="scope.row.children" class="inline-input" style="width:90%;" v-model="scope.row.name" placeholder="璇疯緭鍏ラ」鐩悕绉�"></el-input> </template> </el-table-column> <el-table-column prop="required" label="瑕佹眰" width="260"> <template slot-scope="scope"> - <div> - <el-input v-model="scope.row.required" + <div v-if="!scope.row.children"> + <el-input :readonly="resultVal!=null" v-model="scope.row.required" placeholder="璇疯緭鍏ヨ姹�"></el-input> </div> </template> </el-table-column> <el-table-column prop="note" label="妫�楠屾弿杩�" width="260" > <template slot-scope="scope"> - <div> - <el-input v-model="scope.row.note" placeholder="妫�楠屾弿杩�"></el-input> + <div v-if="!scope.row.children"> + <el-input :readonly="resultVal!=null" v-model="scope.row.note" placeholder="妫�楠屾弿杩�"></el-input> </div> </template> </el-table-column> - <el-table-column fixed="right" prop="testState" label="缁撹" min-width="150"> + <el-table-column prop="testState" label="缁撹" min-width="150"> <template slot-scope="scope"> - <el-select v-model="scope.row.result"> + <el-select style="width:100%" :disabled="resultVal!=null" @change="changeResult" v-model="scope.row.result" v-if="!scope.row.children"> <el-option label="鍚堟牸" value="鍚堟牸"></el-option> <el-option label="涓嶅悎鏍�" value="涓嶅悎鏍�"></el-option> </el-select> </template> </el-table-column> - <el-table-column fixed="right" style="background-color: white;" label="鎿嶄綔" width="200"> + <el-table-column v-if="resultVal=='' || resultVal==null" fixed="right" style="background-color: white;" label="鎿嶄綔" width="200"> <template slot-scope="scope"> - <el-button icon="el-icon-circle-check" type="text" @click="savePackIns(scope.row,scope.$index)">淇濆瓨</el-button> <el-button v-if="scope.row.children" icon="el-icon-circle-plus-outline" type="text" @click="clickAddChildren(scope.row,scope.$index)">娣诲姞琛�</el-button> - <el-button v-if="!scope.row.children || scope.row.children.length==0" - icon="el-icon-circle-close" type="text" + <el-button v-if="!scope.row.children" icon="el-icon-circle-close" type="text" @click="clickDelLine(scope.row,scope.$index,scope.row.children!=null)">鍙栨秷</el-button> + <el-button v-if="scope.row.children" icon="el-icon-circle-close" type="text" + @click="clickDelLine(scope.row,scope.$index,scope.row.children!=null)">鍒犻櫎椤圭洰</el-button> + </template> </el-table-column> </el-table> @@ -132,21 +137,22 @@ </el-row> <el-row style="width:100%"> <el-col :span="24"> - <el-table border height="90" :data="conclusionTable" ref="conclusion" v-model="conclusion" + <el-table class="l-mes" border height="90" :data="conclusionTable" ref="conclusion" v-model="conclusion" :header-cell-style="{textAlign:'center',color:'black',backgroundColor:'#fafafa'}" :cell-style="{textAlign:'center'}"> <el-table-column prop="packageNo" label="鍖呰缂栧彿"></el-table-column> - <el-table-column prop="name" label="鐗╂枡鍚嶇О"></el-table-column> <el-table-column prop="userName" label="妫�楠屽憳"></el-table-column> - <el-table-column prop="judgeState" label="妫�楠岀粨璁�"> + <el-table-column prop="result" label="妫�楠岀粨璁�"> <template slot-scope="scope"> - <el-tag type="success" v-if="scope.row.testState == '1'">鍚堟牸</el-tag> - <el-tag type="danger" v-else-if="scope.row.testState == '0'">涓嶅悎鏍�</el-tag> + <el-select :disabled="resultVal!=null" style="width:100%" v-model="scope.row.result"> + <el-option label="鍚堟牸" value="鍚堟牸"></el-option> + <el-option label="涓嶅悎鏍�" value="涓嶅悎鏍�"></el-option> + </el-select> </template> </el-table-column> <el-table-column label="鎿嶄綔"> <template> - <el-button type="text" :disabled="resultVal!=null && dataForm.id!=null" @click="showDialog()" size="small">涓婃姤</el-button> + <el-button type="text" :disabled="resultVal!=null" @click="submitSave()" size="small">涓婃姤</el-button> </template> </el-table-column> </el-table> @@ -154,21 +160,6 @@ </el-row> </div> </div> - <el-dialog - title="涓婃姤" - :visible.sync="dialogVisible" - width="30%" class="l-mes"> - <el-row> - <el-col> - <span>涓嶅悎鏍兼暟閲�:</span> - <el-input type="number" v-model="unqualifiedNum" placeholder="璇疯緭鍏ヤ笉鍚堟牸鏁伴噺"/> - </el-col> - </el-row> - <span slot="footer" class="dialog-footer"> - <el-button @click="dialogVisible = false">鍙� 娑�</el-button> - <el-button type="primary" @click="submitSave()">纭� 瀹�</el-button> - </span> - </el-dialog> </div> </template> @@ -176,6 +167,7 @@ import { fetchListById, updatePackageInsProduct, + updatePackageInspectById, } from '@/api/quality/packageInspect' export default { computed:{}, @@ -184,15 +176,7 @@ data(){ return{ loading: false, - unqualifiedNum: null, - dialogVisible:false, resultVal: null, - projectList: [], - // 娣诲姞鍒� - empiricalValueAdd: 1, - // 缂栬緫鏃跺瓨鍌ㄦ渶闀跨殑鍒楁暟瀛楋紝鍋氬垹闄ゅ垽鏂� - empiricalValueAddMaxNumber: 0, - columnList: [], dataForm:{ id: null, packInsNo: null, @@ -215,9 +199,8 @@ conclusion: null, conclusionTable: [{ packageNo: '', - name: '', userName: '', - testState: '' + result: '' }], dataRule: {}, } @@ -229,80 +212,76 @@ }, created(){ this.dataForm.id = this.$route.query.id + this.resultVal = this.$route.params.resultVal + if(!this.resultVal){ + let val = sessionStorage.getItem("packIns-resultVal-"+this.dataForm.id) + if(val){ + this.resultVal=val + } + } this.init() }, watch:{ - dialogVisible(newVal){ - if(newVal){ - this.unqualifiedNum = null - } - }, }, methods:{ - checkTestState(){ - let resultVal = '1' - this.list.forEach(item=>{ - if(item.children){ - item.children.forEach(ele=>{ - if(ele.testState == 0){ - resultVal = '0' - } - }) - } + changeResult(){ + let result = '' + let data = this.list + if(data){ + result='鍚堟牸' + data.forEach(item=>{ + if(item.children){ + item.children.forEach(ele=>{ + if(ele.result=='涓嶅悎鏍�'){ + result='涓嶅悎鏍�' + } + }) + } }) - this.resultVal = resultVal - this.conclusionTable[0].testState = resultVal - sessionStorage.setItem("raw-resultVal-"+this.dataForm.id,resultVal) - }, - showDialog(){ - let size = 0 //涓嶅悎鏍奸」鐩暟閲� - this.list.forEach(item=>{ - if(item.children){ - let num = item.children.filter(e=>{ - return e.testState == 0 - }).length - size+=num - } - }) - if (size > 0) { - this.dialogVisible = true - }else{ - this.submitSave() } + this.conclusionTable[0].result = result }, //涓婃姤 submitSave(){ - let data = { - id: this.dataForm.id, - number: this.unqualifiedNum, + const _than = this + this.$confirm('涓婃姤鍓嶏紝璇风‘璁ゆ楠岄」鐩槸鍚﹀凡淇濆瓨!', '鎻愮ず', { + confirmButtonText: '纭涓婃姤', + cancelButtonText: '鍙栨秷', + type: 'warning' + }).then(() => { + let data = { + id: _than.dataForm.id, + result: _than.conclusionTable[0].result, } - updateRawInspectsById(data).then(res => { - if(res.data.code == 0 && (res.data.data=='1'|| res.data.data=='0')){ - sessionStorage.setItem("raw-resultVal-"+this.dataForm.id,res.data.data) - this.$message.success("涓婃姤鎴愬姛"); + updatePackageInspectById(data).then(res => { + if(res.data.code === 0){ + _than.resultVal = res.data.data + sessionStorage.setItem("packIns-resultVal-"+_than.dataForm.id,res.data.data) + _than.$message.success("涓婃姤鎴愬姛"); }else{ - this.$message.error("涓婃姤澶辫触锛�",res.data.data); + _than.$message.error("涓婃姤澶辫触",res.data.data); } - this.dialogVisible = false - this.checkTestState() - }); + }) + }).catch(() => {}) }, // 娣诲姞琛� - clickAddLine(row) { + clickAddLine() { this.list.push({ - pId: '', name: '', - note: '', - required: '', - result: '', randomId: Math.random(), - children: [] + children: [{ + name: '', + note: '', + required: '', + result: '', + randomId: Math.random(), + }] }) }, //娣诲姞瀛愮骇 clickAddChildren(row,index){ - console.log(row,index); row.children.push({ + name: row.name, note: '', required: '', result: '', @@ -327,19 +306,34 @@ } }, //淇濆瓨妫�鏌ラ」 - savePackIns(row,index){ - if(row){ - let obj = { - name: row.anme, - note: row.note, - packageInspectId: row.packageInspectId, - required: row.required, - result: row.result, - } - updatePackageInsProduct(obj).then(res=>{ - console.log(res); + savePackIns(){ + if(this.list.length==0){ + this.$message.error("妫�楠岄」鐩负绌�!") + return + }else{ + let dataList = [] + this.list.forEach(item=>{ + if(item.children){ + item.children.forEach(ele=>{ + let obj = { + id: ele.pid || null, + name: item.name, + note: ele.note, + packageInspectId: this.dataForm.id, + required: ele.required, + result: ele.result, + } + dataList.push(obj) + }) + } + }) + updatePackageInsProduct(dataList).then(res=>{ + if(res.status===200){ + this.$message.success("淇濆瓨鎴愬姛") + } }).catch(error=>{ console.log(error); + this.$message.error("淇濆瓨澶辫触") }) } }, @@ -354,51 +348,49 @@ this.dataForm.projectName = data.projectName this.dataForm.createTime = data.createTime this.dataForm.createUser = data.createUser - this.list = data.packageInsProductS - + this.list = [] + let userNameList = [] + data.packageInsProductS.forEach(item => { + if (item.children) { + let ele = { + randomId: Math.random(), + name: null, + children: [] + } + ele.name = item.name + item.children.forEach(obj => { + if(obj.userName){ + userNameList.push(obj.userName) + } + let o = { + name: item.name, + randomId: Math.random(), + required: obj.required, + pid: obj.pid, + note: obj.note?obj.note:'', + result: obj.presult + } + ele.children.push(o) + }) + this.list.push(ele) + } + }) + this.conclusionTable = [{ + packageNo: data.packageNo, + userName: Array.from(new Set(userNameList)).join(','), + result: null + }] + this.$nextTick(()=>{ + if(this.list.length>0){ + this.changeResult() + } + }) }).catch(error=>{ this.$message.error("鑾峰彇澶辫触",error) }) }else{ this.conclusionTable = [] } - }, - changeState(row, index) { - if (row.rpId != null && row.rpId != '') { - let val = row.testValueList.join(",") - if (val === undefined || val === '' || val === null) { - return - } - let obj = { - deviceId: row.deviceId, - rpId: row.rpId, - testValue: val, - note: row.note - } - updateRawInsProduct(obj).then(res => { - if (res.data.code == 0) { - this.$message.success("鏇存柊鎴愬姛") - } else { - this.$message.error("鏇存柊澶辫触") - } - this.init() - }) - } - }, - save(){ - let data = this.dataForm - this.list.forEach(item=>{ - item.children.forEach(c=>{ - c.testValue=c.testValueList.join(",") - }) - }) - data.packageInsProductS = this.list - addRawInspects(data).then(res=>{ - this.$message.success("淇濆瓨鎴愬姛") - this.$router.go(-1) - }).catch(error=>{ - this.$message.error(error) - }) }, }, } -- Gitblit v1.9.3