IPQC过程检验

This commit is contained in:
JinLu.Yin 2022-08-29 21:32:13 +08:00
parent 9281c35e5d
commit 277496f9eb

View File

@ -1,6 +1,6 @@
<template> <template>
<div class="app-container"> <div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="100px">
<el-form-item label="检验单编号" prop="ipqcCode"> <el-form-item label="检验单编号" prop="ipqcCode">
<el-input <el-input
v-model="queryParams.ipqcCode" v-model="queryParams.ipqcCode"
@ -9,14 +9,6 @@
@keyup.enter.native="handleQuery" @keyup.enter.native="handleQuery"
/> />
</el-form-item> </el-form-item>
<el-form-item label="检验单名称" prop="ipqcName">
<el-input
v-model="queryParams.ipqcName"
placeholder="请输入检验单名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="检验类型" prop="ipqcType"> <el-form-item label="检验类型" prop="ipqcType">
<el-select v-model="queryParams.ipqcType" placeholder="请选择检验类型" clearable> <el-select v-model="queryParams.ipqcType" placeholder="请选择检验类型" clearable>
<el-option <el-option
@ -52,12 +44,14 @@
/> />
</el-form-item> </el-form-item>
<el-form-item label="检测结果" prop="checkResult"> <el-form-item label="检测结果" prop="checkResult">
<el-input <el-select v-model="queryParams.checkResult" placeholder="请选择检验结果" clearable>
v-model="queryParams.checkResult" <el-option
placeholder="请输入检测结果" v-for="dict in dict.type.mes_qc_result"
clearable :key="dict.value"
@keyup.enter.native="handleQuery" :label="dict.label"
/> :value="dict.value"
/>
</el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
@ -113,17 +107,16 @@
<el-table v-loading="loading" :data="ipqcList" @selection-change="handleSelectionChange"> <el-table v-loading="loading" :data="ipqcList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" /> <el-table-column type="selection" width="55" align="center" />
<el-table-column label="检验单编号" align="center" prop="ipqcCode" /> <el-table-column label="检验单编号" width="120px" align="center" prop="ipqcCode" />
<el-table-column label="检验单名称" align="center" prop="ipqcName" />
<el-table-column label="检验类型" align="center" prop="ipqcType"> <el-table-column label="检验类型" align="center" prop="ipqcType">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag :options="dict.type.mes_ipqc_type" :value="scope.row.ipqcType"/> <dict-tag :options="dict.type.mes_ipqc_type" :value="scope.row.ipqcType"/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="工单编" align="center" prop="workorderCode" /> <el-table-column label="工单编" align="center" prop="workorderCode" />
<el-table-column label="产品物料编码" align="center" prop="itemCode" /> <el-table-column label="产品物料编码" width="120px" align="center" prop="itemCode" />
<el-table-column label="产品物料名称" align="center" prop="itemName" /> <el-table-column label="产品物料名称" width="150px" align="center" prop="itemName" :show-overflow-tooltip="true"/>
<el-table-column label="规格型号" align="center" prop="specification" /> <el-table-column label="规格型号" align="center" prop="specification" :show-overflow-tooltip="true"/>
<el-table-column label="单位" align="center" prop="unitOfMeasure" /> <el-table-column label="单位" align="center" prop="unitOfMeasure" />
<el-table-column label="检测数量" align="center" prop="quantityCheck" /> <el-table-column label="检测数量" align="center" prop="quantityCheck" />
<el-table-column label="检测结果" align="center" prop="checkResult" /> <el-table-column label="检测结果" align="center" prop="checkResult" />
@ -164,125 +157,178 @@
/> />
<!-- 添加或修改过程检验单对话框 --> <!-- 添加或修改过程检验单对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body> <el-dialog :title="title" :visible.sync="open" width="960px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="80px"> <el-form ref="form" :model="form" :rules="rules" label-width="100px">
<el-form-item label="检验单编号" prop="ipqcCode"> <el-row>
<el-input v-model="form.ipqcCode" placeholder="请输入检验单编号" /> <el-col :span="8">
</el-form-item> <el-form-item label="检验单编号" prop="ipqcCode">
<el-form-item label="检验单名称" prop="ipqcName"> <el-input v-model="form.ipqcCode" placeholder="请输入检验单编号" />
<el-input v-model="form.ipqcName" placeholder="请输入检验单名称" /> </el-form-item>
</el-form-item> </el-col>
<el-form-item label="检验类型" prop="ipqcType"> <el-col :span="4">
<el-select v-model="form.ipqcType" placeholder="请选择检验类型"> <el-form-item label-width="80">
<el-option <el-switch v-model="autoGenFlag"
v-for="dict in dict.type.mes_ipqc_type" active-color="#13ce66"
:key="dict.value" active-text="自动生成"
:label="dict.label" @change="handleAutoGenChange(autoGenFlag)" v-if="optType != 'view' && form.status =='PREPARE'">
:value="dict.value" </el-switch>
></el-option> </el-form-item>
</el-select> </el-col>
</el-form-item> <el-col :span="12">
<el-form-item label="检验模板ID" prop="templateId"> <el-form-item label="检验单名称" prop="ipqcName">
<el-input v-model="form.templateId" placeholder="请输入检验模板ID" /> <el-input v-model="form.ipqcName" placeholder="请输入检验单名称" />
</el-form-item> </el-form-item>
<el-form-item label="工单ID" prop="workorderId"> </el-col>
<el-input v-model="form.workorderId" placeholder="请输入工单ID" /> </el-row>
</el-form-item> <el-row>
<el-form-item label="工单编码" prop="workorderCode"> <el-col :span="8">
<el-input v-model="form.workorderCode" placeholder="请输入工单编码" /> <el-form-item label="检验类型" prop="ipqcType">
</el-form-item> <el-select v-model="form.ipqcType" placeholder="请选择检验类型">
<el-form-item label="工单名称" prop="workorderName"> <el-option
<el-input v-model="form.workorderName" placeholder="请输入工单名称" /> v-for="dict in dict.type.mes_ipqc_type"
</el-form-item> :key="dict.value"
<el-form-item label="任务ID" prop="taskId"> :label="dict.label"
<el-input v-model="form.taskId" placeholder="请输入任务ID" /> :value="dict.value"
</el-form-item> ></el-option>
<el-form-item label="任务编号" prop="taskCode"> </el-select>
<el-input v-model="form.taskCode" placeholder="请输入任务编号" /> </el-form-item>
</el-form-item> </el-col>
<el-form-item label="任务名称" prop="taskName"> <el-col :span="8">
<el-input v-model="form.taskName" placeholder="请输入任务名称" /> <el-form-item label="工单编码" prop="workorderCode">
</el-form-item> <el-input v-model="form.workorderCode" placeholder="请输入工单编码" />
<el-form-item label="工作站ID" prop="workstationId"> </el-form-item>
<el-input v-model="form.workstationId" placeholder="请输入工作站ID" /> </el-col>
</el-form-item> <el-col :span="8">
<el-form-item label="工作站编号" prop="workstationCode"> <el-form-item label="工单名称" prop="workorderName">
<el-input v-model="form.workstationCode" placeholder="请输入工作站编号" /> <el-input v-model="form.workorderName" placeholder="请输入工单名称" />
</el-form-item> </el-form-item>
<el-form-item label="工作站名称" prop="workstationName"> </el-col>
<el-input v-model="form.workstationName" placeholder="请输入工作站名称" /> </el-row>
</el-form-item> <el-row>
<el-form-item label="工序ID" prop="processId"> <el-col :span="8">
<el-input v-model="form.processId" placeholder="请输入工序ID" /> <el-form-item label="工作站编号" prop="workstationCode">
</el-form-item> <el-input v-model="form.workstationCode" placeholder="请输入工作站编号" />
<el-form-item label="工序编码" prop="processCode"> </el-form-item>
<el-input v-model="form.processCode" placeholder="请输入工序编码" /> </el-col>
</el-form-item> <el-col :span="8">
<el-form-item label="工序名称" prop="processName"> <el-form-item label="工作站名称" prop="workstationName">
<el-input v-model="form.processName" placeholder="请输入工序名称" /> <el-input v-model="form.workstationName" placeholder="请输入工作站名称" />
</el-form-item> </el-form-item>
<el-form-item label="产品物料ID" prop="itemId"> </el-col>
<el-input v-model="form.itemId" placeholder="请输入产品物料ID" /> <el-col :span="8">
</el-form-item> <el-form-item label="任务编号" prop="taskCode">
<el-form-item label="产品物料编码" prop="itemCode"> <el-input v-model="form.taskCode" placeholder="请输入任务编号" />
<el-input v-model="form.itemCode" placeholder="请输入产品物料编码" /> </el-form-item>
</el-form-item> </el-col>
<el-form-item label="产品物料名称" prop="itemName"> </el-row>
<el-input v-model="form.itemName" placeholder="请输入产品物料名称" /> <el-collapse>
</el-form-item> <el-collapse-item>
<el-form-item label="规格型号" prop="specification"> <template slot="title">
<el-input v-model="form.specification" type="textarea" placeholder="请输入内容" /> 更多信息<i class="header-icon el-icon-info"></i>
</el-form-item> </template>
<el-form-item label="单位" prop="unitOfMeasure"> <el-row>
<el-input v-model="form.unitOfMeasure" placeholder="请输入单位" /> <el-col :span="8">
</el-form-item> <el-form-item label="产品编码" prop="itemCode">
<el-form-item label="检测数量" prop="quantityCheck"> <el-input v-model="form.itemCode" placeholder="请输入产品编码" />
<el-input v-model="form.quantityCheck" placeholder="请输入检测数量" /> </el-form-item>
</el-form-item> </el-col>
<el-form-item label="不合格数" prop="quantityUnqualified"> <el-col :span="8">
<el-input v-model="form.quantityUnqualified" placeholder="请输入不合格数" /> <el-form-item label="产品名称" prop="itemName">
</el-form-item> <el-input v-model="form.itemName" placeholder="请输入产品名称" />
<el-form-item label="合格品数量" prop="quantityQualified"> </el-form-item>
<el-input v-model="form.quantityQualified" placeholder="请输入合格品数量" /> </el-col>
</el-form-item> <el-col :span="8">
<el-form-item label="致命缺陷率" prop="crRate"> <el-form-item label="规格型号" prop="specification">
<el-input v-model="form.crRate" placeholder="请输入致命缺陷率" /> <el-input v-model="form.specification" type="textarea" placeholder="请输入内容" />
</el-form-item> </el-form-item>
<el-form-item label="严重缺陷率" prop="majRate"> </el-col>
<el-input v-model="form.majRate" placeholder="请输入严重缺陷率" /> </el-row>
</el-form-item> <el-row>
<el-form-item label="轻微缺陷率" prop="minRate"> <el-col :span="8">
<el-input v-model="form.minRate" placeholder="请输入轻微缺陷率" /> <el-form-item label="单位" prop="unitOfMeasure">
</el-form-item> <el-input v-model="form.unitOfMeasure" placeholder="请输入单位" />
<el-form-item label="致命缺陷数量" prop="crQuantity"> </el-form-item>
<el-input v-model="form.crQuantity" placeholder="请输入致命缺陷数量" /> </el-col>
</el-form-item> <el-col :span="8">
<el-form-item label="严重缺陷数量" prop="majQuantity"> <el-form-item label="工序编码" prop="processCode">
<el-input v-model="form.majQuantity" placeholder="请输入严重缺陷数量" /> <el-input v-model="form.processCode" placeholder="请输入工序编码" />
</el-form-item> </el-form-item>
<el-form-item label="轻微缺陷数量" prop="minQuantity"> </el-col>
<el-input v-model="form.minQuantity" placeholder="请输入轻微缺陷数量" /> <el-col :span="8">
</el-form-item> <el-form-item label="工序名称" prop="processName">
<el-form-item label="检测结果" prop="checkResult"> <el-input v-model="form.processName" placeholder="请输入工序名称" />
<el-input v-model="form.checkResult" placeholder="请输入检测结果" /> </el-form-item>
</el-form-item> </el-col>
<el-form-item label="检测日期" prop="inspectDate"> </el-row>
<el-date-picker clearable </el-collapse-item>
v-model="form.inspectDate" </el-collapse>
type="date" <el-row>
value-format="yyyy-MM-dd" <el-col :span="8">
placeholder="请选择检测日期"> <el-form-item label="检测数量" prop="quantityCheck">
</el-date-picker> <el-input v-model="form.quantityCheck" placeholder="请输入检测数量" />
</el-form-item> </el-form-item>
<el-form-item label="检测人员" prop="inspector"> </el-col>
<el-input v-model="form.inspector" placeholder="请输入检测人员" /> <el-col :span="8">
</el-form-item> <el-form-item label="不合格数" prop="quantityUnqualified">
<el-form-item label="备注" prop="remark"> <el-input v-model="form.quantityUnqualified" placeholder="请输入不合格数" />
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" /> </el-form-item>
</el-form-item> </el-col>
<el-col :span="8">
<el-form-item label="合格品数量" prop="quantityQualified">
<el-input v-model="form.quantityQualified" placeholder="请输入合格品数量" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="致命缺陷数量" prop="crQuantity">
<el-input v-model="form.crQuantity" placeholder="请输入致命缺陷数量" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="严重缺陷数量" prop="majQuantity">
<el-input v-model="form.majQuantity" placeholder="请输入严重缺陷数量" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="轻微缺陷数量" prop="minQuantity">
<el-input v-model="form.minQuantity" placeholder="请输入轻微缺陷数量" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="检测日期" prop="inspectDate">
<el-date-picker clearable
v-model="form.inspectDate"
type="date"
value-format="yyyy-MM-dd"
placeholder="请选择检测日期">
</el-date-picker>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="检测结果" prop="checkResult">
<el-input v-model="form.checkResult" placeholder="请输入检测结果" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="检测人员" prop="inspector">
<el-input v-model="form.inspector" placeholder="请输入检测人员" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
</el-form-item>
</el-col>
</el-row>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button> <el-button type="primary" @click="cancel" v-if="optType =='view' || form.status !='PREPARE' ">返回</el-button>
<el-button type="primary" @click="submitForm" v-if="form.status =='PREPARE' && optType !='view' "> </el-button>
<el-button @click="cancel"> </el-button> <el-button @click="cancel"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
@ -291,12 +337,15 @@
<script> <script>
import { listIpqc, getIpqc, delIpqc, addIpqc, updateIpqc } from "@/api/mes/qc/ipqc"; import { listIpqc, getIpqc, delIpqc, addIpqc, updateIpqc } from "@/api/mes/qc/ipqc";
import {genCode} from "@/api/system/autocode/rule"
export default { export default {
name: "Ipqc", name: "Ipqc",
dicts: ['mes_ipqc_type'], dicts: ['mes_ipqc_type','mes_qc_result'],
data() { data() {
return { return {
autoGenFlag:false,
optType: undefined,
// //
loading: true, loading: true,
// //
@ -459,9 +508,9 @@ export default {
majQuantity: null, majQuantity: null,
minQuantity: null, minQuantity: null,
checkResult: null, checkResult: null,
inspectDate: null, inspectDate: new Date(),
inspector: null, inspector: null,
status: "0", status: "PREPARE",
remark: null, remark: null,
attr1: null, attr1: null,
attr2: null, attr2: null,
@ -495,6 +544,7 @@ export default {
this.reset(); this.reset();
this.open = true; this.open = true;
this.title = "添加过程检验单"; this.title = "添加过程检验单";
this.optType = "add";
}, },
/** 修改按钮操作 */ /** 修改按钮操作 */
handleUpdate(row) { handleUpdate(row) {
@ -504,6 +554,18 @@ export default {
this.form = response.data; this.form = response.data;
this.open = true; this.open = true;
this.title = "修改过程检验单"; this.title = "修改过程检验单";
this.optType = "edit";
});
},
//
handleView(row){
this.reset();
const ipqcIds = row.ipqcId
getIpqc(ipqcIds).then(response => {
this.form = response.data;
this.open = true;
this.title = "查看检验单信息";
this.optType = "view";
}); });
}, },
/** 提交按钮 */ /** 提交按钮 */
@ -541,6 +603,16 @@ export default {
this.download('qc/ipqc/export', { this.download('qc/ipqc/export', {
...this.queryParams ...this.queryParams
}, `ipqc_${new Date().getTime()}.xlsx`) }, `ipqc_${new Date().getTime()}.xlsx`)
},
//
handleAutoGenChange(autoGenFlag){
if(autoGenFlag){
genCode('IPQC_CODE').then(response =>{
this.form.ipqcCode = response;
});
}else{
this.form.ipqcCode = null;
}
} }
} }
}; };