Files
2025-11-17 10:01:33 +08:00

463 lines
16 KiB
Vue

<template>
<view>
<uni-collapse>
<uni-forms ref="form" :modelValue="formData" :rules="rules">
<uni-collapse-item title="生产过程检单" :open="true">
<uni-forms-item label="来源单" :labelWidth='90' name="sourceCode">
<uni-easyinput suffixIcon="scan" @iconClick="scanBar1" @confirm="scanBarSourceCode"
v-model="formData.sourceCode" type="text" />
</uni-forms-item>
<uni-forms-item label="质检单" :labelWidth='90' name="qualityCode">
<uni-combox-re labelKey="qualityCode" valueKey="id" :candidates="qualityCodeList" emptyTips="无"
@input="scanBarCode" v-model="formData.qualityCode"></uni-combox-re>
<!-- <uni-easyinput suffixIcon="scan" @iconClick="scanBar" @confirm="scanBarCode"
v-model="formData.qualityCode" type="text" /> -->
</uni-forms-item>
<uni-forms-item label="单据类型" :labelWidth='90' name="type">
<uni-tag :text="formData.typeText" type="success"></uni-tag>
</uni-forms-item>
<!-- <uni-forms-item label="仓库编码" :labelWidth='90' name="warehouseCode">
<uni-easyinput type="text" v-model="formData.warehouseCode" />
</uni-forms-item> -->
<uni-forms-item label="工单" :labelWidth='90' name="pwoCode">
{{formData.pwoCode}}
<!-- <uni-easyinput type="text" v-model="formData.warehouseCode" /> -->
</uni-forms-item>
<uni-forms-item label="物料编码" :labelWidth='90' name="ptNoTar">
{{formData.ptNoTar}}
<!-- <uni-easyinput type="text" v-model="formData.warehouseCode" /> -->
</uni-forms-item>
<uni-forms-item label="物料名称" :labelWidth='90' name="ptTitleTar">
{{formData.ptTitleTar}}
<!-- <uni-easyinput type="text" v-model="formData.warehouseCode" /> -->
</uni-forms-item>
</uni-collapse-item>
<uni-collapse-item title="生产过程检单明细" :open="true">
<uni-swipe-action>
<uni-swipe-action-item :rightOptions="rightOptions" :key="index"
v-for="(item, index) in formData.qcQualityBillDetailList"
@click="(data) => clickDetail(index,data)" @change="swipChange">
<view>
<uni-badge :text="index+1" class="uni-badge-left-margin" type="primary"></uni-badge>
<button @click="open(index)" size="mini" type="primary">编辑</button>
</view>
<uni-forms-item label="物料编码" :labelWidth='80'
:name="'qcQualityBillDetailList.'+ index +'.materialCode'">
<uni-easyinput type="text" disabled v-model="item.materialCode"></uni-easyinput>
</uni-forms-item>
<uni-forms-item label="物料名称" :labelWidth='80'
:name="'qcQualityBillDetailList.'+ index +'.materialName'">
<uni-easyinput type="text" disabled v-model="item.materialName"></uni-easyinput>
</uni-forms-item>
<uni-forms-item label="物料规格" :labelWidth='80'
:name="'qcQualityBillDetailList.'+ index +'.specification1'">
<uni-easyinput type="text" disabled v-model="item.specification1"></uni-easyinput>
</uni-forms-item>
<uni-forms-item label="制程编码" :labelWidth='80'
:name="'qcQualityBillDetailList.'+ index +'.opCode'">
<uni-easyinput type="text" disabled v-model="item.opCode"></uni-easyinput>
</uni-forms-item>
<uni-forms-item label="物料批号" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.materialBatchNo'">
<uni-easyinput disabled type="text" v-model="item.materialBatchNo" />
</uni-forms-item>
<uni-forms-item label="物料箱号" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.materialLotNo'">
<uni-easyinput disabled type="text" v-model="item.materialLotNo" />
</uni-forms-item>
<uni-forms-item label="质检员" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'qualityBy'">
<!-- <uni-easyinput type="text" v-model="item.qualityBy" suffixIcon="scan"
@iconClick="scanBarqualityBy" /> -->
<uni-easyinput type="text" suffixIcon="scan" @iconClick="scanBarqualityBy"
v-model="item.qualityBy" @confirm="(data) => isEmp(index,data)" />
<uni-data-select style="margin-top: 10px;" v-model="item.qualityBy" :localdata="empList"
@change="qualityByChange"></uni-data-select>
</uni-forms-item>
<!-- <uni-forms-item label="质检方案编码" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.qualityTypeCode'">
<uni-easyinput type="text" suffixIcon="scan" @iconClick="scanBar3"
v-model="item.qualityTypeCode" />
</uni-forms-item> -->
<uni-forms-item label="质检标准编码" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.qualityStandardCode'">
<uni-easyinput type="text" disabled
v-model="item.qualityStandardCode+':'+item.qualityStandardName" />
</uni-forms-item>
<uni-row>
<uni-col :span="24">
<uni-forms-item label="计划质检数量" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.planNumber'">
<u-number-box inputWidth="120" button-size="36" v-model="item.planNumber"
min="0"></u-number-box>
</uni-forms-item>
</uni-col>
<uni-col :span="24">
<uni-forms-item label="实收数量" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.actualNumber'">
<u-number-box inputWidth="120" button-size="36" v-model="item.actualNumber"
min="0"></u-number-box>
</uni-forms-item>
</uni-col>
<uni-col :span="24">
<uni-forms-item label="质检数量" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.number'">
<u-number-box inputWidth="120" button-size="36" v-model="item.number"
min="0"></u-number-box>
</uni-forms-item>
</uni-col>
<uni-col :span="24">
<uni-forms-item label="质检合格数量" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.passNumber'">
<u-number-box inputWidth="120" button-size="36" v-model="item.passNumber"
min="0"></u-number-box>
</uni-forms-item>
</uni-col>
</uni-row>
<uni-forms-item label="质检不通过原因" :labelWidth='80'
name="'qcQualityBillDetailList.'+ index +'.failReason'">
<uni-easyinput type="textarea" v-model="item.failReason" />
</uni-forms-item>
</uni-swipe-action-item>
</uni-swipe-action>
</uni-collapse-item>
</uni-forms>
<uni-forms-item label="失败自动补单" :labelWidth='100' name="failRemake" style="margin-top: 10px;">
<u-switch v-model="formData.failRemake" activeColor="#5AC725" inactiveColor="#ff4949"
style="float: left;"></u-switch>
</uni-forms-item>
<uni-forms-item label="检验结果" :labelWidth='90' name="result" style="margin-top: 10px;">
<uni-data-select v-model="formData.result" :localdata="resultOptions"></uni-data-select>
</uni-forms-item>
</uni-collapse>
<u-button type="primary" @click="submit">提交</u-button>
</view>
</template>
<script>
import {
listQualityBill,
addQualityBill,
getQualityBill,
updateQualityBill,
listQualityBillByBatchNo,
getStandardList,
listStandardList
} from "@/api/qc/qc.js";
import {
listPwoJob
} from "../../api/mes/jobReport";
import {
listPwo
} from "../../api/mes/pwoDraw";
import uniComboxRe from "../../uni_modules/uni-combox/components/uni-combox/uni-combox-re.vue"
import {
getDicts
} from "@/api/system/dict/dictData.js";
import {
listEmployee
} from "@/api/mes/jobIn.js";
export default {
mounted() {
listStandardList().then(async res => {
this.StandardList = res.rows;
})
getDicts("qc_bill_result").then(res => {
this.resultOptions = res.data.map(dict => {
return {
text: dict.dictLabel,
value: dict.dictValue,
diasble: false
}
});
})
getDicts("qc_bill_type").then(res => {
this.typeOptions = res.data.map(dict => {
return {
text: dict.dictLabel,
value: dict.dictValue,
diasble: false
}
});
});
listEmployee().then((res) => {
this.empList = res.rows.map(item => {
let obj = {
text: item.name,
value: item.empCode
}
return obj
})
})
},
components: {
uniComboxRe
},
data() {
return {
empList: [],
resultOptions: [],
typeOptions: [],
formData: {
qualityCode: null,
warehouseCode: null,
qcQualityBillDetailList: [],
ptNoTar: null,
ptTitleTar: null,
typeText: null
},
qualityCodeList: [],
StandardList: null,
rightOptions: [{
text: '删除',
style: {
backgroundColor: '#ff2a17'
}
}, ],
rules: {
sourceCode: {
rules: [{
required: true,
errorMessage: '请输入来源单!'
}]
},
}
}
},
methods: {
qualityByChange(e) {
console.log(e)
this.formData.qualityBy = e;
},
//验证是否为员工
isEmp(i, code) {
listEmployee({
empCode: code
}).then(res => {
if (res.total == 0) {
this.$modal.msg("未查询到该员工!");
this.formData.qcQualityBillDetailList[i].qualityBy = null;
this.formData.qualityBy = null;
}
})
},
otherFun(object) {
console.log(object)
this.formData.qcQualityBillDetailList.find(item => item.id == object.did).number = object.number;
this.formData.qcQualityBillDetailList.find(item => item.id == object.did).passNumber = object.passNumber;
},
open(index) {
let qscid = null;
if (this.formData.qcQualityBillDetailList[index].qualityStandardCode && this.formData
.qcQualityBillDetailList[index].qualityStandardCode != "") {
const result = this.StandardList.find(item => item.qualityStandardCode == this.formData
.qcQualityBillDetailList[index].qualityStandardCode);
if (result !== undefined) {
console.log(result)
// 找到了匹配项,进行后续逻辑
qscid = result.id
let did = this.formData.qcQualityBillDetailList[index].id;
let mbn = this.formData.qcQualityBillDetailList[index].materialBatchNo;
let mc = this.formData.qcQualityBillDetailList[index].materialCode;
let mn = this.formData.qcQualityBillDetailList[index].materialName || '';
let sp = this.formData.qcQualityBillDetailList[index].specification1 || '';
let billId = this.formData.id;
let number = this.formData.qcQualityBillDetailList[index].number;
console.log(qscid + ' ' + mbn + ' ' + mc);
uni.navigateTo({
url: '/pages/qc/updateStandardList?qscid=' + qscid +
'&materialBatchNo=' + mbn +
'&materialCode=' + mc +
'&materialName=' + mn +
'&specification1=' + sp +
'&number=' + number +
'&did=' + did +
'&billId=' + billId
});
} else {
console.log(result)
this.$modal.msg("未检索到该质检标准编码相关信息!");
}
} else {
this.$modal.msg("请输入质检标准编码!");
}
},
test() {},
change(e) {
console.log('当前模式:' + e.type + ',状态:' + e.show);
},
scanBarCode(e) {
if (e) {
//查询质检单明细
getQualityBill(e).then(async response => {
response.data.typeText = this.typeOptions.find(i =>
i.value == response.data.type
).text
this.formData = {
...this.formData,
...response.data
}
this.formData.qcQualityBillDetailList =
response.data.qcQualityBillDetailList.map((item) => {
item.qualityStandardCode = this.StandardList.find(i =>
i.id == item.qualityStandardCode)
.qualityStandardCode
item.qualityStandardName = this.StandardList.find(i =>
i.id == item.qualityStandardCode)
.qualityStandardName
item.qualityTypeCode = Number(item.qualityTypeCode);
return item;
});
});
}
},
scanBarSourceCode() {
if (this.formData.sourceCode && this.formData.sourceCode != "") {
let q = {
sourceCode: this.formData.sourceCode
}
listQualityBill(q).then(async res => {
if (res.rows.length > 0) {
this.qualityCodeList = res.rows;
console.log(this.qualityCodeList)
} else {
this.$modal.msg("未检索到该来源单相关信息!");
}
});
listPwoJob({
code: this.formData.sourceCode
}).then(res => {
if (res.rows.length > 0) {
this.formData.pwoCode = res.rows[0].pwoCode
listPwo({
pwoCode: this.formData.pwoCode
}).then(resp => {
if (resp.rows.length > 0) {
this.formData.ptNoTar = resp.rows[0].ptNoTar;
this.formData.ptTitleTar = resp.rows[0].ptTitleTar;
}
})
}
})
}
},
//质检单
scanBar() {
const _this = this;
uni.scanCode({
scanType: ['barCode', 'qrCode'],
success: function(res) {
_this.formData.qualityCode = res.result;
_this.scanBarCode(_this.formData.qualityCode);
}
});
},
//来源单
scanBar1() {
const _this = this;
uni.scanCode({
scanType: ['barCode', 'qrCode'],
success: function(res) {
_this.formData.sourceCode = res.result;
_this.scanBarSourceCode(_this.formData.sourceCode);
}
});
},
//仓库编码
scanBar2() {
const _this = this;
uni.scanCode({
scanType: ['barCode', 'qrCode'],
success: function(res) {
_this.formData.warehouseCode = res.result;
// _this.scanBarCode(_this.formData.warehouseCode);
}
});
},
//质检方案编码
scanBar3() {
const _this = this;
uni.scanCode({
scanType: ['barCode', 'qrCode'],
success: function(res) {
_this.formData.qcQualityBillDetailList[0].qualityTypeCode = res.result;
_this.scanBarCode(_this.qcQualityBillDetailList[0].qualityTypeCode);
}
});
},
//质检标准编码
scanBar4(index) {
const _this = this;
uni.scanCode({
scanType: ['barCode', 'qrCode'],
success: function(res) {
_this.formData.qcQualityBillDetailList[index].qualityStandardCode = res.result;
_this.scanBarCode(_this.qcQualityBillDetailList[index].qualityStandardCode);
}
});
},
//质检员扫码
scanBarqualityBy(index) {
const _this = this;
uni.scanCode({
scanType: ['barCode', 'qrCode'],
success: function(res) {
_this.formData.qcQualityBillDetailList[index].qualityBy = res.result;
_this.formData.qualityBy = res.result;
}
});
},
submit() {
const _this = this;
_this.$refs.form.validate().then(res => {
uni.showModal({
title: '提示',
content: '您确定完成该质检吗?',
success: function(res) {
if (res.confirm) {
for (var i in _this.formData.qcQualityBillDetailList) {
if (_this.formData.qcQualityBillDetailList[i]
.qualityStandardCode && _this.formData.qcQualityBillDetailList[
i].qualityStandardCode != "") {
//查询质检标准编码的id
const res = _this.StandardList.find(item => item
.qualityStandardCode == _this.formData
.qcQualityBillDetailList[i].qualityStandardCode);
if (res !== undefined) {
_this.formData.qcQualityBillDetailList[i]
.qualityStandardCode = res.id;
} else {
_this.$modal.msg("请填写正确的质检标准编码!");
}
} else {
_this.formData.qcQualityBillDetailList[i].qualityStandardCode =
null;
}
}
_this.$modal.loading('提交中')
console.log(_this.formData)
updateQualityBill(_this.formData).then(async res => {
_this.$modal.closeLoading();
_this.$modal.msgSuccess("检验成功!");
setTimeout(() => {
_this.$tab.switchTab("/pages/work/index");
}, 500);
});
} else if (res.cancel) {
console.log('用户点击取消');
}
}
});
});
}
}
}
</script>
<style>
</style>