Merge branch 'master' of http://192.168.0.22:9001/r/mom-before
| | |
| | | finishedInspectChooseMater: "/finished-inspect/chooseMater",//根据订单号得到信息 |
| | | finishedInspectAddFinish: "/finished-inspect/addFinish", //新增成品检验 |
| | | finishedInspectUpdateFinishInspectsById: "/finished-inspect/updateFinishInspectsById",//上报 |
| | | finishedInspectSelectFinishInspectsListById: "/finished-inspect/selectFinishInspectsListById" |
| | | } |
| | | // 过程检验 |
| | | const processInspection = { |
| | |
| | | inspectionItemUpdateDevByInsId: "/inspection-item/updateDevByInsId",//更改设备 |
| | | inspectionItemlose_focus_update: "/inspection-item/lose_focus_update",//检验值 |
| | | processInspectUpdateProcessInspectsById: "/processInspect/updateProcessInspectsById",//上报 |
| | | inspectionItemChooseDev: "/inspection-item/chooseDev", |
| | | processInspectSelectProcessInspectsListById: "/processInspect/selectProcessInspectsListById" |
| | | } |
| | | // QMS实验室管理 |
| | | const laboratory = { |
| | |
| | | <el-row> |
| | | <el-col :span="7"> |
| | | <el-form-item label="产品名称:"> |
| | | <el-select @change="changeOptionsSamplename" style="width: 180px;" v-model="processInspectVo.material" size="small" |
| | | placeholder="请选择产品名称"> |
| | | <el-select @change="changeOptionsSamplename" style="width: 180px;" |
| | | v-model="processInspectVo.material" size="small" placeholder="请选择产品名称"> |
| | | <el-option v-for="item in optionsSamplename" :key="item.id" :label="item.name" |
| | | :value="item.id + '-' + item.name"> |
| | | </el-option> |
| | |
| | | </el-col> |
| | | <el-col :span="7"> |
| | | <el-form-item label="单位:"> |
| | | <el-input disabled style="width: 180px;" v-model="processInspectVo.unit" placeholder="请输入产品编码" |
| | | autocomplete="off" /> |
| | | <el-input disabled style="width: 180px;" v-model="processInspectVo.unit" |
| | | placeholder="请输入产品编码" autocomplete="off" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="7"> |
| | |
| | | </div> |
| | | <el-dialog title="请选择设备" :visible.sync="centerDialogVisible" width="20%"> |
| | | <div class="div_device_dialog"> |
| | | <el-input placeholder="输入关键字进行过滤" v-model="filterText" style="margin-bottom: 6px;"> |
| | | </el-input> |
| | | <el-tree class="filter-tree" :data="materialOptions" :props="defaultProps" default-expand-all |
| | | highlight-current @node-click="nodeClick" :filter-node-method="filterNode" ref="tree"> |
| | | <div class="custom-tree-node" slot-scope="{ data }"> |
| | | <span><i :class="`node_i ${data.children ? 'el-icon-folder-opened' : 'el-icon-tickets' |
| | | }` |
| | | "></i> |
| | | {{ data.name }}</span> |
| | | </div> |
| | | </el-tree> |
| | | <el-select style="width: 100%;" @change="clickNodeSure()" v-model="filterText" placeholder="请选择"> |
| | | <el-option v-for="item in materialOptions" :key="item.id" :label="item.device" :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="centerDialogVisible = false">取 消</el-button> |
| | | <el-button type="primary" @click="clickNodeSure()">确 定</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | |
| | | mcode: null, |
| | | prname: null, |
| | | sname: null, |
| | | orderNumber: "D-001", |
| | | orderNumber: "", |
| | | qualityTraceability: null, |
| | | quantity: null, |
| | | specificationsModel: null, |
| | |
| | | children: "children", |
| | | label: "name" |
| | | }, |
| | | nodeData: "", // node点击保存当前点击数据 |
| | | nodeData: { |
| | | id: 0, |
| | | name: null |
| | | }, // node点击保存当前点击数据 |
| | | clickSelectDevice: { |
| | | index: "", // 点击选择存储当前行索引 |
| | | rpId: "" // 点击选择存储当前行项目Id |
| | |
| | | }; |
| | | }, |
| | | watch: { |
| | | filterText(val) { |
| | | this.$refs.tree.filter(val); |
| | | } |
| | | // filterText(val) { |
| | | // this.$refs.tree.filter(val); |
| | | // } |
| | | }, |
| | | mounted() { |
| | | this.getTableData() |
| | | this.getOptions(); |
| | | // this.getOptions(); |
| | | }, |
| | | methods: { |
| | | changeOptionsSamplename(){ |
| | | let id=this.processInspectVo.material.split("-")[0] |
| | | let sample=this.optionsSamplename.filter(o=>{ |
| | | return o.id==id |
| | | changeOptionsSamplename() { |
| | | let id = this.processInspectVo.material.split("-")[0] |
| | | let sample = this.optionsSamplename.filter(o => { |
| | | return o.id == id |
| | | })[0] |
| | | this.processInspectVo.qualityTraceability=sample.qualityTraceability |
| | | this.processInspectVo.mcode=sample.mcode |
| | | this.processInspectVo.specificationsModel=sample.specifications |
| | | this.processInspectVo.unit=sample.unit |
| | | this.processInspectVo.qualityTraceability = sample.qualityTraceability |
| | | this.processInspectVo.mcode = sample.mcode |
| | | this.processInspectVo.specificationsModel = sample.specifications |
| | | this.processInspectVo.unit = sample.unit |
| | | }, |
| | | comBack(){ |
| | | comBack() { |
| | | this.$parent.comBackMain() |
| | | }, |
| | | handleClick(row) { |
| | |
| | | return data.name.indexOf(value) !== -1; |
| | | }, |
| | | // 获取设备树内容 |
| | | getOptions() { |
| | | this.$axios.get(this.$api.url.rawSelectDevice).then(res => { |
| | | getOptions(row) { |
| | | this.$axios.get(this.$api.url.inspectionItemChooseDev, { |
| | | params: { |
| | | father: row.father, |
| | | name: row.name, |
| | | technologyId: this.processInspectVo.technologyId |
| | | } |
| | | }).then(res => { |
| | | this.materialOptions = res.data; |
| | | }); |
| | | }, |
| | |
| | | this.centerDialogVisible = true; |
| | | this.clickSelectDevice.index = scope.$index; |
| | | this.clickSelectDevice.rpId = scope.row.id; |
| | | this.getOptions(scope.row); |
| | | }, |
| | | // 点击树里面的确定 |
| | | clickNodeSure() { |
| | | let select = this.materialOptions.filter(item => { |
| | | return item.id === this.filterText |
| | | })[0] |
| | | this.nodeData.id = select.id |
| | | this.nodeData.name = select.device |
| | | if (this.detailId == null) { |
| | | this.inspectionItems[ |
| | | this.clickSelectDevice.index |
| | |
| | | } |
| | | }, |
| | | changeState(row, index) { |
| | | console.log(row); |
| | | if (row.did != null && row.did != '') { |
| | | let val = row.empiricalValueAddss.filter(item => { |
| | | return item != '' && item != null |
| | | }) |
| | | let eq = val.filter(item => { |
| | | return /^[^><=]/.test(item) |
| | | }) |
| | | if (eq.length > 0) { |
| | | this.$message({ |
| | | message: "检测值[" + eq + "]格式首位应包含>,<或者=", |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | } |
| | | let str = "" |
| | | row.empiricalValueAddss.forEach(e => { |
| | | str += e + "," |
| | |
| | | // this.isAddProject = true |
| | | let val = JSON.parse(JSON.stringify(this.processInspectVo)) |
| | | val.material = this.processInspectVo.material.split("-")[1] |
| | | val.id=this.processInspectVo.material.split("-")[0] |
| | | val.id = this.processInspectVo.material.split("-")[0] |
| | | this.$axios.post(this.$api.url.finishedInspectAddFinish, val, { |
| | | headers: { "Content-Type": "application/json" } |
| | | }).then(res => { |
| | |
| | | }) |
| | | }, |
| | | getTableData() { |
| | | this.$axios.get(this.$api.url.finishedInspectSelectFinishInspectsListById, { |
| | | params: { |
| | | id: this.detailId |
| | | } |
| | | }).then(res => { |
| | | this.processInspectVo.technologyId = res.data[0].techId |
| | | }) |
| | | this.$axios.get(this.$api.url.inspectionItemListUser, { |
| | | params: { |
| | | id: this.detailId, |
| | |
| | | <el-row> |
| | | <el-col :span="7"> |
| | | <el-form-item label="产品名称:"> |
| | | <el-select disabled @change="changeOptionsSamplename" style="width: 180px;" v-model="processInspectVo.material" size="small" |
| | | placeholder="请选择产品名称"> |
| | | <el-select disabled @change="changeOptionsSamplename" style="width: 180px;" |
| | | v-model="processInspectVo.material" size="small" placeholder="请选择产品名称"> |
| | | <el-option v-for="item in optionsSamplename" :key="item.id" :label="item.name" |
| | | :value="item.id + '-' + item.name"> |
| | | </el-option> |
| | |
| | | </el-col> |
| | | <el-col :span="7"> |
| | | <el-form-item label="单位:"> |
| | | <el-input disabled style="width: 180px;" v-model="processInspectVo.unit" placeholder="请输入产品编码" |
| | | autocomplete="off" /> |
| | | <el-input disabled style="width: 180px;" v-model="processInspectVo.unit" |
| | | placeholder="请输入产品编码" autocomplete="off" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="7"> |
| | | <el-form-item label="数量:"> |
| | | <el-input disabled style="width: 180px;" v-model="processInspectVo.quantity" placeholder="请输入数量" |
| | | autocomplete="off" /> |
| | | <el-input disabled style="width: 180px;" v-model="processInspectVo.quantity" |
| | | placeholder="请输入数量" autocomplete="off" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="3" style="display: flex;justify-content: end;"> |
| | |
| | | <div class="inspectionProject"> |
| | | <el-row> |
| | | <el-col :span="12" class="inspectionProject_span">检验项目</el-col> |
| | | <el-col v-if="!isUpBtn" :span="12" class="inspectionProject_span" style="display: flex;justify-content: end;"> |
| | | <el-col v-if="!isUpBtn" :span="12" class="inspectionProject_span" |
| | | style="display: flex;justify-content: end;"> |
| | | <el-button size="mini" @click="clickDeleteInspectionColumn()">删除检验值列</el-button> |
| | | <el-button style="margin-right: 30px;" size="mini" |
| | | @click="clickAddInspectionColumn()">添加检验值列</el-button> |
| | |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column prop="operation" label="上报"> |
| | | <template slot-scope="scope"> |
| | | <el-button v-if="scope.row.conclusion === null || scope.row.conclusion === undefined" type="primary" @click="escalation" size="small">上报</el-button> |
| | | <template slot-scope="scope"> |
| | | <el-button v-if="scope.row.conclusion === null || scope.row.conclusion === undefined" type="primary" |
| | | @click="escalation" size="small">上报</el-button> |
| | | <el-button v-else type="success" size="small">已上报</el-button> |
| | | </template> |
| | | </el-table-column> |
| | |
| | | </div> |
| | | <el-dialog title="请选择设备" :visible.sync="centerDialogVisible" width="20%"> |
| | | <div class="div_device_dialog"> |
| | | <el-input placeholder="输入关键字进行过滤" v-model="filterText" style="margin-bottom: 6px;"> |
| | | </el-input> |
| | | <el-tree class="filter-tree" :data="materialOptions" :props="defaultProps" default-expand-all |
| | | highlight-current @node-click="nodeClick" :filter-node-method="filterNode" ref="tree"> |
| | | <div class="custom-tree-node" slot-scope="{ data }"> |
| | | <span><i :class="`node_i ${data.children ? 'el-icon-folder-opened' : 'el-icon-tickets' |
| | | }` |
| | | "></i> |
| | | {{ data.name }}</span> |
| | | </div> |
| | | </el-tree> |
| | | <el-select style="width: 100%;" @change="clickNodeSure()" v-model="filterText" placeholder="请选择"> |
| | | <el-option v-for="item in materialOptions" :key="item.id" :label="item.device" :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="centerDialogVisible = false">取 消</el-button> |
| | | <el-button type="primary" @click="clickNodeSure()">确 定</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | |
| | | qualityTraceability: null, |
| | | quantity: null, |
| | | specificationsModel: null, |
| | | unit: null |
| | | unit: null, |
| | | technologyId: null |
| | | }, |
| | | InspectioniD: null, |
| | | addInspectionform: [ |
| | |
| | | children: "children", |
| | | label: "name" |
| | | }, |
| | | nodeData: "", // node点击保存当前点击数据 |
| | | nodeData: { |
| | | id: 0, |
| | | name: null |
| | | }, // node点击保存当前点击数据 |
| | | clickSelectDevice: { |
| | | index: "", // 点击选择存储当前行索引 |
| | | rpId: "" // 点击选择存储当前行项目Id |
| | |
| | | }; |
| | | }, |
| | | watch: { |
| | | filterText(val) { |
| | | this.$refs.tree.filter(val); |
| | | } |
| | | // filterText(val) { |
| | | // this.$refs.tree.filter(val); |
| | | // } |
| | | }, |
| | | mounted() { |
| | | if(this.rowInfo.result!=null&&this.rowInfo.result!=''){ |
| | | this.isUpBtn=true |
| | | if (this.rowInfo.result != null && this.rowInfo.result != '') { |
| | | this.isUpBtn = true |
| | | } |
| | | this.processInspectVo.material=this.rowInfo.material |
| | | this.processInspectVo.mcode=this.rowInfo.material_code |
| | | this.processInspectVo.orderNumber=this.rowInfo.order_number |
| | | this.processInspectVo.qualityTraceability=this.rowInfo.quality_traceability |
| | | this.processInspectVo.specificationsModel=this.rowInfo.specifications_model |
| | | this.processInspectVo.unit=this.rowInfo.unit |
| | | this.processInspectVo.quantity=this.rowInfo.quantity |
| | | this.processInspectVo.prname=this.rowInfo.customer_name |
| | | this.processInspectVo.sname=this.rowInfo.project_name |
| | | this.inspectionResultForm[0].id=this.rowInfo.material_code |
| | | this.inspectionResultForm[0].name=this.rowInfo.material |
| | | this.inspectionResultForm[0].conclusion=this.rowInfo.result |
| | | this.detailId=this.rowInfo.id |
| | | this.processInspectVo.material = this.rowInfo.material |
| | | this.processInspectVo.mcode = this.rowInfo.material_code |
| | | this.processInspectVo.orderNumber = this.rowInfo.order_number |
| | | this.processInspectVo.qualityTraceability = this.rowInfo.quality_traceability |
| | | this.processInspectVo.specificationsModel = this.rowInfo.specifications_model |
| | | this.processInspectVo.unit = this.rowInfo.unit |
| | | this.processInspectVo.quantity = this.rowInfo.quantity |
| | | this.processInspectVo.prname = this.rowInfo.customer_name |
| | | this.processInspectVo.sname = this.rowInfo.project_name |
| | | this.inspectionResultForm[0].id = this.rowInfo.material_code |
| | | this.inspectionResultForm[0].name = this.rowInfo.material |
| | | this.inspectionResultForm[0].conclusion = this.rowInfo.result |
| | | this.detailId = this.rowInfo.id |
| | | this.getTableData() |
| | | this.getOptions(); |
| | | // this.getOptions(); |
| | | }, |
| | | methods: { |
| | | escalation() { |
| | |
| | | id: this.detailId |
| | | }).then(res => { |
| | | if (res.code == 200) { |
| | | if(res.message==='项目未检验完!'){ |
| | | if (res.message === '项目未检验完!') { |
| | | this.$message({ |
| | | message: res.message, |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | message: res.message, |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | } |
| | | this.$message({ |
| | | message: '上报成功', |
| | |
| | | }) |
| | | |
| | | }, |
| | | changeOptionsSamplename(){ |
| | | let id=this.processInspectVo.material.split("-")[0] |
| | | let sample=this.optionsSamplename.filter(o=>{ |
| | | return o.id==id |
| | | changeOptionsSamplename() { |
| | | let id = this.processInspectVo.material.split("-")[0] |
| | | let sample = this.optionsSamplename.filter(o => { |
| | | return o.id == id |
| | | })[0] |
| | | this.processInspectVo.qualityTraceability=sample.qualityTraceability |
| | | this.processInspectVo.mcode=sample.mcode |
| | | this.processInspectVo.specificationsModel=sample.specifications |
| | | this.processInspectVo.unit=sample.unit |
| | | this.processInspectVo.qualityTraceability = sample.qualityTraceability |
| | | this.processInspectVo.mcode = sample.mcode |
| | | this.processInspectVo.specificationsModel = sample.specifications |
| | | this.processInspectVo.unit = sample.unit |
| | | }, |
| | | comBack(){ |
| | | comBack() { |
| | | this.$parent.comBackMain() |
| | | }, |
| | | handleClick(row) { |
| | |
| | | return data.name.indexOf(value) !== -1; |
| | | }, |
| | | // 获取设备树内容 |
| | | getOptions() { |
| | | this.$axios.get(this.$api.url.rawSelectDevice).then(res => { |
| | | getOptions(row) { |
| | | this.$axios.get(this.$api.url.inspectionItemChooseDev, { |
| | | params: { |
| | | father: row.father, |
| | | name: row.name, |
| | | technologyId: this.processInspectVo.technologyId |
| | | } |
| | | }).then(res => { |
| | | this.materialOptions = res.data; |
| | | }); |
| | | }, |
| | |
| | | this.centerDialogVisible = true; |
| | | this.clickSelectDevice.index = scope.$index; |
| | | this.clickSelectDevice.rpId = scope.row.id; |
| | | this.getOptions(scope.row); |
| | | }, |
| | | // 点击树里面的确定 |
| | | clickNodeSure() { |
| | | let select = this.materialOptions.filter(item => { |
| | | return item.id === this.filterText |
| | | })[0] |
| | | this.nodeData.id = select.id |
| | | this.nodeData.name = select.device |
| | | if (this.detailId == null) { |
| | | this.inspectionItems[ |
| | | this.clickSelectDevice.index |
| | |
| | | } |
| | | }, |
| | | changeState(row, index) { |
| | | console.log(row); |
| | | if (row.did != null && row.did != '') { |
| | | let val = row.empiricalValueAddss.filter(item => { |
| | | return item != '' && item != null |
| | | }) |
| | | let eq = val.filter(item => { |
| | | return /^[^><=]/.test(item) |
| | | }) |
| | | if (eq.length > 0) { |
| | | this.$message({ |
| | | message: "检测值[" + eq + "]格式首位应包含>,<或者=", |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | } |
| | | let str = "" |
| | | row.empiricalValueAddss.forEach(e => { |
| | | str += e + "," |
| | |
| | | // this.isAddProject = true |
| | | let val = JSON.parse(JSON.stringify(this.processInspectVo)) |
| | | val.material = this.processInspectVo.material.split("-")[1] |
| | | val.id=this.processInspectVo.material.split("-")[0] |
| | | val.id = this.processInspectVo.material.split("-")[0] |
| | | this.$axios.post(this.$api.url.finishedInspectAddFinish, val, { |
| | | headers: { "Content-Type": "application/json" } |
| | | }).then(res => { |
| | |
| | | }) |
| | | }, |
| | | getTableData() { |
| | | console.log(this.rowInfo); |
| | | this.$axios.get(this.$api.url.finishedInspectSelectFinishInspectsListById, { |
| | | params: { |
| | | id: this.rowInfo.id |
| | | } |
| | | }).then(res => { |
| | | this.processInspectVo.technologyId = res.data[0].techId |
| | | }) |
| | | this.$axios.get(this.$api.url.inspectionItemListUser, { |
| | | params: { |
| | | id: this.detailId, |
| | |
| | | <template> |
| | | <div class="content-main"> |
| | | <div v-if="!showAddPage&&!showUp&&!showLook" class="rawPage"> |
| | | <div v-if="!showAddPage && !showUp && !showLook" class="rawPage"> |
| | | <div class="title"> |
| | | <el-row> |
| | | <el-col :span="12">过程检验</el-col> |
| | |
| | | <el-table-column label="操作" min-width="80"> |
| | | <template slot-scope="scope"> |
| | | <el-button type="text" size="small" @click="handleClick(scope.row)" style="margin-left: 0;">详情</el-button> |
| | | <el-button type="text" size="small" >查看</el-button> |
| | | <el-button v-if="scope.row.result == null" type="text" size="small" style="margin-left: 0;" @click="updateInsInfo(scope.row)">编辑</el-button> |
| | | <el-button type="text" size="small">查看</el-button> |
| | | <el-button v-if="scope.row.result == null" type="text" size="small" style="margin-left: 0;" |
| | | @click="updateInsInfo(scope.row)">编辑</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="10" style="display: flex;justify-content: end;"> |
| | | <el-button type="primary" :disabled="isAddProject" @click="addTestProjevt">生成检验项目</el-button> |
| | | <el-button type="primary" :disabled="isAddProject" @click="addTestProjevt">生成检验项目</el-button> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | |
| | | > --> |
| | | </el-col> |
| | | </el-row> |
| | | <el-table border :data="inspectionItems" max-height="420" :span-method="handleSpanMethod" height="calc(100vh - 550px)" |
| | | style="width: 100%"> |
| | | <el-table border :data="inspectionItems" max-height="420" :span-method="handleSpanMethod" |
| | | height="calc(100vh - 550px)" style="width: 100%"> |
| | | <el-table-column type="index" label="序号" width="60"></el-table-column> |
| | | <el-table-column label="项目" prop="father"></el-table-column> |
| | | <el-table-column prop="name" label="指标"></el-table-column> |
| | |
| | | </div> |
| | | <el-dialog title="请选择设备" :visible.sync="centerDialogVisible" width="20%"> |
| | | <div class="div_device_dialog"> |
| | | <el-input placeholder="输入关键字进行过滤" v-model="filterText" style="margin-bottom: 6px;"> |
| | | </el-input> |
| | | <el-tree class="filter-tree" :data="materialOptions" :props="defaultProps" default-expand-all highlight-current |
| | | @node-click="nodeClick" :filter-node-method="filterNode" ref="tree"> |
| | | <div class="custom-tree-node" slot-scope="{ data }"> |
| | | <span><i :class="`node_i ${data.children ? 'el-icon-folder-opened' : 'el-icon-tickets' |
| | | }` |
| | | "></i> |
| | | {{ data.name }}</span> |
| | | </div> |
| | | </el-tree> |
| | | <el-select style="width: 100%;" @change="clickNodeSure()" v-model="filterText" placeholder="请选择"> |
| | | <el-option v-for="item in materialOptions" :key="item.id" :label="item.device" :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="centerDialogVisible = false">取 消</el-button> |
| | | <el-button type="primary" @click="clickNodeSure()">确 定</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | </div> |
| | | <div class="newPage" v-if="showUp"> |
| | | <processInspectionUpdate :rowInfo="rowInfp"/> |
| | | <processInspectionUpdate :rowInfo="rowInfp" /> |
| | | </div> |
| | | <div class="newPage" v-if="showLook"> |
| | | <processInspectionLook :rowInfo="rowInfp"/> |
| | | <processInspectionLook :rowInfo="rowInfp" /> |
| | | </div> |
| | | </div> |
| | | </template> |
| | |
| | | import processInspectionUpdate from '../view/processInspectionUpdate.vue' |
| | | import processInspectionLook from '../view/processInspectionLook.vue' |
| | | export default { |
| | | components: { processInspectionUpdate,processInspectionLook }, |
| | | components: { processInspectionUpdate, processInspectionLook }, |
| | | data() { |
| | | return { |
| | | showUp: false, |
| | | isAddProject:false, |
| | | isAddProject: false, |
| | | showLook: false, |
| | | detailId: 28, |
| | | rowInfp:{}, |
| | | rowInfp: {}, |
| | | search: { |
| | | countSize: 10, |
| | | pageSize: 1, |
| | |
| | | children: "children", |
| | | label: "name" |
| | | }, |
| | | nodeData: "", // node点击保存当前点击数据 |
| | | nodeData: { |
| | | id: 0, |
| | | name: null |
| | | }, // node点击保存当前点击数据 |
| | | clickSelectDevice: { |
| | | index: "", // 点击选择存储当前行索引 |
| | | rpId: "" // 点击选择存储当前行项目Id |
| | |
| | | }, |
| | | mounted() { |
| | | // this.getTableData() |
| | | this.getOptions(); |
| | | // this.getOptions(); |
| | | }, |
| | | methods: { |
| | | handleClick(row){ |
| | | this.rowInfp=row |
| | | this.showLook=true |
| | | handleClick(row) { |
| | | this.rowInfp = row |
| | | this.showLook = true |
| | | }, |
| | | combackIndex(){ |
| | | this.showAddPage=false |
| | | combackIndex() { |
| | | this.showAddPage = false |
| | | this.defaultInitializationTable() |
| | | }, |
| | | updateInsInfo(row){ |
| | | this.rowInfp=row |
| | | this.showUp=true |
| | | updateInsInfo(row) { |
| | | this.rowInfp = row |
| | | this.showUp = true |
| | | }, |
| | | combackMain(val){ |
| | | this.showUp=false |
| | | this.showLook=false |
| | | combackMain(val) { |
| | | this.showUp = false |
| | | this.showLook = false |
| | | this.defaultInitializationTable(); // 初始化表格数据 |
| | | if(val){ |
| | | this.$parent.removeAllTab() |
| | | } |
| | | if (val) { |
| | | this.$parent.removeAllTab() |
| | | } |
| | | }, |
| | | searchPro(){ |
| | | this.search.countSize=this.pageSize |
| | | this.search.pageSize=this.currentPage |
| | | searchPro() { |
| | | this.search.countSize = this.pageSize |
| | | this.search.pageSize = this.currentPage |
| | | this.defaultInitializationTable() |
| | | }, |
| | | // 点击设备树保存点击记录 |
| | |
| | | return data.name.indexOf(value) !== -1; |
| | | }, |
| | | // 获取设备树内容 |
| | | getOptions() { |
| | | this.$axios.get(this.$api.url.rawSelectDevice).then(res => { |
| | | getOptions(row) { |
| | | this.$axios.get(this.$api.url.inspectionItemChooseDev, { |
| | | params: { |
| | | father: row.father, |
| | | name: row.name, |
| | | technologyId: this.processInspectVo.technologyId |
| | | } |
| | | }).then(res => { |
| | | this.materialOptions = res.data; |
| | | }); |
| | | }, |
| | |
| | | this.centerDialogVisible = true; |
| | | this.clickSelectDevice.index = scope.$index; |
| | | this.clickSelectDevice.rpId = scope.row.id; |
| | | this.options(scope.row) |
| | | }, |
| | | // 点击树里面的确定 |
| | | clickNodeSure() { |
| | | let select = this.materialOptions.filter(item => { |
| | | return item.id === this.filterText |
| | | })[0] |
| | | this.nodeData.id = select.id |
| | | this.nodeData.name = select.device |
| | | if (this.detailId == null) { |
| | | this.inspectionItems[ |
| | | this.clickSelectDevice.index |
| | |
| | | } |
| | | }, |
| | | changeState(row, index) { |
| | | console.log(row); |
| | | if(row.did!=null&&row.did!=''){ |
| | | let str="" |
| | | row.empiricalValueAddss.forEach(e=>{ |
| | | str+=e+"," |
| | | if (row.did != null && row.did != '') { |
| | | let val = row.empiricalValueAddss.filter(item => { |
| | | return item != '' && item != null |
| | | }) |
| | | let eq = val.filter(item => { |
| | | return /^[^><=]/.test(item) |
| | | }) |
| | | if (eq.length > 0) { |
| | | this.$message({ |
| | | message: "检测值[" + eq + "]格式首位应包含>,<或者=", |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | } |
| | | let str = "" |
| | | row.empiricalValueAddss.forEach(e => { |
| | | str += e + "," |
| | | }) |
| | | this.$axios.post(this.$api.url.inspectionItemlose_focus_update, { |
| | | deviceId: row.did, |
| | | inspectionItemId: row.id, |
| | | inspectionValue: str.slice(0,-1) |
| | | }, { |
| | | headers: { "Content-Type": "application/json" } |
| | | }).then(res => { |
| | | row.result=res.data.result |
| | | row.username=res.data.username |
| | | }) |
| | | }else{ |
| | | this.$message({ |
| | | inspectionValue: str.slice(0, -1) |
| | | }, { |
| | | headers: { "Content-Type": "application/json" } |
| | | }).then(res => { |
| | | if (res.message === '内控值输入格式有问题!') { |
| | | this.$message({ |
| | | message: res.message, |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | } |
| | | row.result = res.data.result |
| | | row.username = res.data.username |
| | | }) |
| | | } else { |
| | | this.$message({ |
| | | message: '请选择择设备!', |
| | | type: 'warning' |
| | | }); |
| | | } |
| | | } |
| | | }, |
| | | // 每页条数改变时触发 选择一页显示多少行 |
| | | handleSizeChange(val) { |
| | |
| | | this.optionTechnology = working.children |
| | | }, |
| | | addTestProjevt() { |
| | | this.isAddProject=true |
| | | this.isAddProject = true |
| | | let val = JSON.parse(JSON.stringify(this.processInspectVo)) |
| | | val.techname = this.processInspectVo.techname.split("-")[1] |
| | | val.technologyId = this.processInspectVo.techname.split("-")[0] |
| | |
| | | specificationsModel: val.specificationsModel, |
| | | techfather: val.techfather, |
| | | techname: val.techname, |
| | | technologyId: val.technologyId, |
| | | techId: Number(val.technologyId), |
| | | unit: val.unit |
| | | }, { |
| | | headers: { "Content-Type": "application/json" } |
| | |
| | | return |
| | | } |
| | | this.detailId = res.data |
| | | this.inspectionResultForm[0].id=val.materialCode |
| | | this.inspectionResultForm[0].name=val.material |
| | | this.inspectionResultForm[0].id = val.materialCode |
| | | this.inspectionResultForm[0].name = val.material |
| | | this.getTableData() |
| | | }) |
| | | }, |
| | |
| | | this.inspectionItems = res.data |
| | | let arr = [] |
| | | let val = JSON.parse(JSON.stringify(this.inspectionItems)) |
| | | const uName=[] |
| | | const uName = [] |
| | | //转成一维数组 |
| | | val.forEach(l => { |
| | | let father = l.father |
| | |
| | | let arrSort = JSON.parse(JSON.stringify(arr)) |
| | | //根据集合对象数组长度排序 |
| | | arrSort.sort((a, b) => { |
| | | if (a.empiricalValueAddss.length < b.empiricalValueAddss.length) { |
| | | return -1; // a排在b前面 |
| | | } else if (a.empiricalValueAddss.length > b.empiricalValueAddss.length) { |
| | | return 1; // a排在b后面 |
| | | } else { |
| | | return 0; // 保持相对顺序不变 |
| | | } |
| | | }); |
| | | // console.log(arrSort); |
| | | console.log(uName); |
| | | let name=[...new Set(uName)].filter(item => item !== null); |
| | | let rname='' |
| | | name.forEach(m=>{ |
| | | rname+=m+"," |
| | | }) |
| | | this.inspectionResultForm[0].inspecter=rname.slice(0,-1) |
| | | this.empiricalValueAdd=arrSort[arrSort.length-1].empiricalValueAddss.length |
| | | if (a.empiricalValueAddss.length < b.empiricalValueAddss.length) { |
| | | return -1; // a排在b前面 |
| | | } else if (a.empiricalValueAddss.length > b.empiricalValueAddss.length) { |
| | | return 1; // a排在b后面 |
| | | } else { |
| | | return 0; // 保持相对顺序不变 |
| | | } |
| | | }); |
| | | // console.log(arrSort); |
| | | console.log(uName); |
| | | let name = [...new Set(uName)].filter(item => item !== null); |
| | | let rname = '' |
| | | name.forEach(m => { |
| | | rname += m + "," |
| | | }) |
| | | this.inspectionResultForm[0].inspecter = rname.slice(0, -1) |
| | | this.empiricalValueAdd = arrSort[arrSort.length - 1].empiricalValueAddss.length |
| | | this.mergeTable(arr) |
| | | }) |
| | | }, |
| | |
| | | .node_i { |
| | | color: orange; |
| | | } |
| | | |
| | | .div_device_dialog { |
| | | min-height: 400px; |
| | | overflow: auto; |
| | | } |
| | | |
| | | .nav { |
| | | display: flex; |
| | | padding: 20px 20px; |
| | |
| | | .inspectionProject_span .el-button { |
| | | float: right; |
| | | font-size: 13px !important; |
| | | } |
| | | </style> |
| | | }</style> |
| | |
| | | > --> |
| | | </el-col> |
| | | </el-row> |
| | | <el-table border :data="inspectionItems" max-height="420" :span-method="handleSpanMethod" height="calc(100vh - 550px)" |
| | | style="width: 100%"> |
| | | <el-table border :data="inspectionItems" max-height="420" :span-method="handleSpanMethod" |
| | | height="calc(100vh - 550px)" style="width: 100%"> |
| | | <el-table-column type="index" label="序号" width="60"></el-table-column> |
| | | <el-table-column label="项目" prop="father"></el-table-column> |
| | | <el-table-column prop="name" label="指标"></el-table-column> |
| | |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column prop="operation" label="上报"> |
| | | <template slot-scope="scope"> |
| | | <el-button v-if="scope.row.conclusion === null || scope.row.conclusion === undefined" type="primary" @click="escalation" size="small">上报</el-button> |
| | | <template slot-scope="scope"> |
| | | <el-button v-if="scope.row.conclusion === null || scope.row.conclusion === undefined" type="primary" |
| | | @click="escalation" size="small">上报</el-button> |
| | | <el-button v-else type="success" size="small">已上报</el-button> |
| | | </template> |
| | | </el-table-column> |
| | |
| | | </div> |
| | | <el-dialog title="请选择设备" :visible.sync="centerDialogVisible" width="20%"> |
| | | <div class="div_device_dialog"> |
| | | <el-input placeholder="输入关键字进行过滤" v-model="filterText" style="margin-bottom: 6px;"> |
| | | </el-input> |
| | | <el-tree class="filter-tree" :data="materialOptions" :props="defaultProps" default-expand-all |
| | | highlight-current @node-click="nodeClick" :filter-node-method="filterNode" ref="tree"> |
| | | <div class="custom-tree-node" slot-scope="{ data }"> |
| | | <span><i :class="`node_i ${data.children ? 'el-icon-folder-opened' : 'el-icon-tickets' |
| | | }` |
| | | "></i> |
| | | {{ data.name }}</span> |
| | | </div> |
| | | </el-tree> |
| | | <el-select style="width: 100%;" @change="clickNodeSure()" v-model="filterText" placeholder="请选择"> |
| | | <el-option v-for="item in materialOptions" :key="item.id" :label="item.device" :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <!-- <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="centerDialogVisible = false">取 消</el-button> |
| | | <el-button type="primary" @click="clickNodeSure()">确 定</el-button> |
| | | </span> |
| | | </span> --> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | |
| | | children: "children", |
| | | label: "name" |
| | | }, |
| | | nodeData: "", // node点击保存当前点击数据 |
| | | nodeData: { |
| | | id: 0, |
| | | name: null |
| | | }, // node点击保存当前点击数据 |
| | | clickSelectDevice: { |
| | | index: "", // 点击选择存储当前行索引 |
| | | rpId: "" // 点击选择存储当前行项目Id |
| | |
| | | }; |
| | | }, |
| | | watch: { |
| | | filterText(val) { |
| | | this.$refs.tree.filter(val); |
| | | } |
| | | // filterText(val) { |
| | | // this.$refs.tree.filter(val); |
| | | // } |
| | | }, |
| | | created() { |
| | | if(this.rowInfo.result!=null&&this.rowInfo.result!=''){ |
| | | this.isUpBtn=true |
| | | if (this.rowInfo.result != null && this.rowInfo.result != '') { |
| | | this.isUpBtn = true |
| | | } |
| | | this.processInspectVo.orderNumber = this.rowInfo.order_number |
| | | this.processInspectVo.material = this.rowInfo.material |
| | |
| | | // console.log(this.detailId); |
| | | }, |
| | | mounted() { |
| | | this.getOptions(); |
| | | this.getTableData() |
| | | }, |
| | | methods: { |
| | |
| | | id: this.detailId |
| | | }).then(res => { |
| | | if (res.code == 200) { |
| | | if(res.message==='项目未检验完!'){ |
| | | if (res.message === '项目未检验完!') { |
| | | this.$message({ |
| | | message: res.message, |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | message: res.message, |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | } |
| | | this.$message({ |
| | | message: '上报成功', |
| | |
| | | return data.name.indexOf(value) !== -1; |
| | | }, |
| | | // 获取设备树内容 |
| | | getOptions() { |
| | | this.$axios.get(this.$api.url.rawSelectDevice).then(res => { |
| | | getOptions(row) { |
| | | this.$axios.get(this.$api.url.inspectionItemChooseDev, { |
| | | params: { |
| | | father: row.father, |
| | | name: row.name, |
| | | technologyId: this.processInspectVo.technologyId |
| | | } |
| | | }).then(res => { |
| | | this.materialOptions = res.data; |
| | | }); |
| | | }, |
| | |
| | | this.centerDialogVisible = true; |
| | | this.clickSelectDevice.index = scope.$index; |
| | | this.clickSelectDevice.rpId = scope.row.id; |
| | | this.getOptions(scope.row); |
| | | }, |
| | | // 点击树里面的确定 |
| | | clickNodeSure() { |
| | | let select = this.materialOptions.filter(item => { |
| | | return item.id === this.filterText |
| | | })[0] |
| | | this.nodeData.id = select.id |
| | | this.nodeData.name = select.device |
| | | if (this.detailId == null) { |
| | | this.inspectionItems[ |
| | | this.clickSelectDevice.index |
| | |
| | | } |
| | | }, |
| | | changeState(row, index) { |
| | | console.log(row); |
| | | if (row.did != null && row.did != '') { |
| | | let val = row.empiricalValueAddss.filter(item => { |
| | | return item != '' && item != null |
| | | }) |
| | | let eq = val.filter(item => { |
| | | return /^[^><=]/.test(item) |
| | | }) |
| | | if (eq.length > 0) { |
| | | this.$message({ |
| | | message: "检测值[" + eq + "]格式首位应包含>,<或者=", |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | } |
| | | let str = "" |
| | | row.empiricalValueAddss.forEach(e => { |
| | | str += e + "," |
| | |
| | | }) |
| | | }, |
| | | getTableData() { |
| | | this.$axios.get(this.$api.url.processInspectSelectProcessInspectsListById, { |
| | | params: { |
| | | id: this.rowInfo.id |
| | | } |
| | | }).then(res => { |
| | | // console.log(res.data); |
| | | this.processInspectVo.technologyId = res.data[0].techId |
| | | // console.log(this.processInspectVo); |
| | | }) |
| | | this.$axios.get(this.$api.url.inspectionItemListUser, { |
| | | params: { |
| | | id: this.detailId, |
| | |
| | | |
| | | // 修改项目的检测值改变结论 |
| | | async changeState(row, index) { |
| | | let val=row.testValueList.filter(item=>{ |
| | | return item!=''&&item!=null |
| | | }) |
| | | let eq=val.filter(item=>{ |
| | | return /^[^><=]/.test(item) |
| | | }) |
| | | if(eq.length>0){ |
| | | this.$message({ |
| | | message: "输入值["+eq+"]格式首位应包含>,<或者=", |
| | | type: 'warning' |
| | | }); |
| | | return |
| | | } |
| | | if (this.detailId !== null) { |
| | | const res = await this.$axios.post(this.$api.url.updaterawInsProduct, { |
| | | DevId: row.deviceId, |
| | |
| | | </span> |
| | | </el-dialog> |
| | | <!-- 新增弹窗 --> |
| | | <el-dialog title="生产记录新增" :visible.sync="dialogVisible" ref="ruleForm" width="35%"> |
| | | <el-dialog title="生产记录新增" :visible.sync="dialogVisible" :rules="Rules" |
| | | ref="ruleForm" width="35%"> |
| | | <div> |
| | | <el-form ref="form" :model="form" label-width="80px"> |
| | | <el-form-item label="类型"> |
| | | <template> |
| | | <el-select v-model="form.type" :rules="Rules" |
| | | <el-select v-model="form.type" |
| | | @change="edittype" placeholder="请选择" style="width: 480px;"> |
| | | <el-option label="橡胶连接器" :value="0"></el-option> |
| | | <el-option label="金属连接器" :value="1"></el-option> |
| | |
| | | >元件:</el-col |
| | | > |
| | | <el-col :span="16" :offset="1"> |
| | | <el-select |
| | | <el-input v-model="cell" |
| | | placeholder="请输入元件名称" |
| | | style="width: 200px"> |
| | | </el-input> |
| | | <!-- <el-select |
| | | v-model="cell" |
| | | style="width: 310px" |
| | | disabled |
| | |
| | | :value="item.id" |
| | | > |
| | | </el-option> |
| | | </el-select> |
| | | </el-select> --> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row style="line-height: 46px"> |
| | |
| | | this.$api.url.writeTechById + `?id=${this.upData.id}`, |
| | | { |
| | | deviceGroup: this.upData.device_group, |
| | | elementId:this.cell.join(','), |
| | | element:JSON.stringify(this.cell.split(',')), |
| | | // element:JSON.stringify(this.form.elementId.split(',')) |
| | | father: this.edit.father, |
| | | name: this.edit.name, |
| | | type: this.edit.type |
| | |
| | | }) |
| | | .then((res) => { |
| | | this.edit = res.data[0]; |
| | | console.log(this.edit.children); |
| | | this.cell = this.edit.children.map(el => { |
| | | return el.id |
| | | }) |
| | | // this.cell = this.cell.join(',') |
| | | // this.cell = nn |
| | | // console.log(this.cell); |
| | | this.cell = this.edit.element |
| | | console.log(this.cell); |
| | | let cc = JSON.parse(this.cell).join(",") |
| | | console.log(cc); |
| | | this.cell = cc |
| | | console.log(this.cell); |
| | | // this.cell = this.edit.children.map(el => { |
| | | // return el.id |
| | | // }) |
| | | // this.cell = this.cell.join(',') |
| | | // this.cell = nn |
| | | // console.log(this.cell); |
| | | |
| | | |
| | | |
| | | // let cc = this.edit.element.join(", ") |
| | | // let str = cc.join(", "); |
| | | // let cc = JSON.parse(this.edit.element) |
| | | // console.log(cc); |
| | | // console.log(gg); |
| | | // console.log(json.parse(gg)); |
| | | |
| | | }); |
| | | }, |