factory_web/src/views/wpm_bx/mlogb_form.vue

520 lines
13 KiB
Vue

<!-- 新增mlogbIn -->
<template>
<el-dialog
title="添加日志详情"
v-model="visible"
:size="1000"
destroy-on-close
@closed="$emit('closed')"
>
<el-container v-loading="loading">
<el-main style="padding: 0">
<el-form
ref="dialogForm"
:model="form"
:rules="rules"
label-position="right"
label-width="80px"
style="padding: 0"
>
<el-row>
<el-col :md="12" :sm="12" :xs="24" v-if="!isfix&&!hasRoute">
<el-form-item label="工艺步骤" prop="route">
<el-select
v-model="form.route"
placeholder="工艺步骤"
clearable
filterable
style="width: 100%"
:disabled="mode == 'edit'"
@change="routeChange"
>
<el-option
v-for="item in routeOptions"
:key="item.id"
:label="item.name"
:value="item.id"
>
<span>[{{ item.routepack_name }}]{{ item.name }}</span>
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :md="12" :sm="12" :xs="24" v-if="!isfix">
<el-form-item label="关联任务">
<el-select
v-model="form.mtask"
placeholder="关联任务"
clearable
class="width-100"
@change="getMaterial"
>
<el-option
v-for="item in options"
:key="item.id"
:label="item.number"
:value="item.id"
>
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :md="12" :sm="12" :xs="24">
<el-form-item label="批次选择">
<el-select
v-model="batchs"
placeholder="批次选择"
clearable
class="width-100"
@change="changeMaterial"
>
<el-option
v-for="item in materialOptions"
:key="item.id"
:label="item.batch"
:value="item.id"
>
<span>{{ item.batch }}</span>
<span v-if="item.defect_name&&item.defect_name!==null">({{ item.defect_name }})</span>
<span style="float: right;">{{ item.count_cando }}</span>
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :md="12" :sm="12" :xs="24">
<el-form-item label="物料扫码" style="display: flex;">
<el-input ref="codeInput" v-model="wm_in" clearable @change="formWminChange(wm_in)" style="width: 200px;margin-left: 4px;"></el-input>
</el-form-item>
</el-col>
<el-col :md="12" :sm="12" :xs="24">
<el-form-item label="使用数量" prop="count_use">
<el-input-number ref="codeInput" v-model="form.count_use" :min="0" clearable class="width-100"></el-input-number>
</el-form-item>
</el-col>
<el-col :md="12" :sm="12" :xs="24">
<el-form-item label="主要批次" v-if="!isfix">
<el-select
v-model="form.parent"
placeholder="主要批次"
clearable
class="width-100"
>
<el-option
v-for="item in mlogbInOptions"
:key="item.id"
:label="item.batch"
:value="item.id"
>
</el-option>
</el-select>
</el-form-item>
</el-col>
</el-row>
</el-form>
<el-footer>
<el-button type="primary" :loading="isSaveing" @click="submit">提交</el-button>
<el-button @click="visible = false">取消</el-button>
</el-footer>
</el-main>
</el-container>
</el-dialog>
</template>
<script>
const defaultForm = {
mlog: "",
mtask: "",
batch: "",
wm_in: "",
count_use: 0,
note:'',
parent: "",
};
export default {
props: {
mlog: {
type: String,
default: "",
},
mgroup: {
type: String,
default: "",
},
tracking:{
type: Number,
default: null,
},
routeId:{
type: String,
default: "",
},
material_in: {
type: String,
default: "",
},
hasRoute:{
type: Boolean,
default: false,
},
isfix:{
type: Boolean,
default: false,
},
process:{
type: String,
default: "",
},
},
emits: ["success", "closed"],
data() {
return {
batchs:"",
loading: false,
mode: "add",
titleMap: {
add: "新增",
edit: "编辑",
},
//表单数据
form: defaultForm,
//验证规则
rules: {
wm_in: [
{
required: true,
message: "请填写批次号",
trigger: "blur",
},
]
},
wm_in:'',
mlogbId:'',
route_code:"",
mlogbIns:[],
options: [],
optionsEq: [],
routeOptions: [],
mlogbInOptions:[],
materialOptions: [],
mgroup_code:'',
mlogbInId:'',
mlogbInCount:0,
hasMlogbIn:false,
visible: false,
isSaveing: false,
setFiltersVisible: false,
params: {
page: 0,
mlog: "",
material_in__isnull: 0,
},
bwItemForms:[],
bwItemForm:{
wpr:"",
mlogb:"",
number:"",
},
};
},
mounted() {
this.materialIn = this.material_in;
this.route_code = this.$route.path.split("/")[2];
this.form.mlog = this.mlog;
this.params.mlog = this.mlog;
let arr = this.$route.path.split("/");
this.mgroup_code = arr[2];
this.$nextTick(()=>{
this.getMlogbIn();
this.getMtask();
this.getMaterial();
this.getParentList();
this.getEquipment();
if(!this.hasRoute&&!this.isfix){
this.getRoute();
}
})
},
methods: {
open() {
this.visible = true;
this.form.mtask = "";
this.wm_in = "";
this.form.count_use = 0;
this.form.parent = "";
},
getMlogbIn(){
let that = this;
let params = {};
params.page= 0;
params.mlog= that.mlog;
params.material_in__isnull=0;
this.$API.wpm.mlogb.list.req(params).then((res) => {
that.mlogbIns = res;
})
},
getEquipment() {
let that = this;
this.$API.em.equipment.list.req({ page: 0, type: 10,mgroup:that.mgroup}).then((res) => {
res.forEach((item) => {
let obj = {};
Object.assign(obj, item);
obj.label = item.name+'-'+item.number;
that.optionsEq.push(obj);
});
});
},
getRoute() {
let that = this;
that.$API.mtm.route.list
.req({ process: that.process, page: 0, routepack__state: 30 })
.then((res) => {
that.routeOptions = res;
if(res.length==1){
that.form.route = res[0].id;
}
});
},
getParentList(){
let that = this;
that.$API.wpm.mlogb.list.req(that.params).then((res) => {
if(res.length>0){
that.mlogbInOptions = res.filter((item)=>{
return item.parent==null;
})
// that.form.parent = that.mlogbInOptions[0].id;
}else{
that.form.parent = '';
}
})
},
//获取任务列表
getMtask() {
console.log(this.materialIn);
let that = this;
let obj = {};
obj.page = 0;
obj.state = 20;
obj.mgroup = that.mgroup;
obj.route__material_in = that.materialIn;
this.$API.pm.mtask.list.req(obj).then((res) => {
that.options = res;
});
},
//获取车间物料
getMaterial() {
let that = this;
let obj = {};
console.log('that.mgroup',that.mgroup);
obj.mtaskx =that.form.mtask;
obj.mgroupx =that.mgroup;
if(that.routeId!==null&&that.routeId!==''){
obj.route =that.routeId;
}
obj.page =0;
if(that.isfix ){//来料未完成的返修品&&出料已完成的返修品和不合格品
obj.tag = 'canfix';
}else{
if(that.materialIn!==null&&that.materialIn!==''){
obj.material =that.materialIn;
}
obj.state =10;
obj.tag = 'todo';
}
this.$API.wpm.wmaterial.list.req(obj).then((res) => {
let arr = [];
if(res.length>0){
arr = res.filter((item)=>{
return Number(item.count_cando)>0;
})
}
that.materialOptions = arr;
});
},
routeChange(){
let that = this;
that.routeOptions.forEach(item=>{
if(item.id == that.form.route){
that.materialIn = item.material_in;
that.getMaterial();
}
})
},
changeMaterial(){
let that = this;
that.materialOptions.forEach(item=>{
if(item.id == that.batchs){
that.form.batch = item.batch;
that.form.wm_in = item.id;
that.form.count_use = item.count_cando;
}
})
},
//扫描后处理方法
formWminChange(code){
console.log('code',code);
let that = this,codeId='',arr=[];
code = code.replace(/(^\s*)|(\s*$)/g, "");
if(code.indexOf("#")>-1){
let arrs = code.split("#");
codeId = arrs[1];
that.scanKyes = arrs[0];
this.$API.cm.labelmat.item.req(codeId).then((res) => {
if(res){
arr = that.materialOptions.filter((item) => {
return item.batch == res.batch&&item.state==res.state;
})
if (arr.length > 0) {
that.form.batch = arr[0].batch;
that.form.wm_in = arr[0].id;
that.form.count_use = arr[0].count;
that.wm_in = arr[0].batch;
}else{
that.wm_in = '';
that.$message.error("批次号不存在");
}
}else{
that.wm_in = '';
}
}).catch((err) => {
that.wm_in = '';
that.$message.error("批次号不存在");
});
}else{
that.scanKyes = "";
that.$API.wpm.wpr.list.req({number:code,page:0}).then((res) => {
if(res.length>0){
let index = res.length-1;//最后一条记录
let bwitem = {};
bwitem.mlogb="";
bwitem.number=res[index].number;
bwitem.wpr=res[index].id;
let arr = that.materialOptions.filter((item) => {
return item.id == res[index].wm;
})
if(arr.length>0){ //车间存在该批次
let batch = arr[0].batch;
that.wm_in = arr[0].batch;
that.mlogbInCount = arr[0].count;//该批次数量
//判断日志中是否存在该批次
let arr0= that.mlogbIns.filter((item)=>{
return item.batch == batch;
})
let arr1 = that.bwItemForms.filter((item)=>{
return item.number == bwitem.number;
})
if (arr0.length > 0) {
that.hasMlogbIn = true;
that.form.count_use = 1;
that.mlogbId = arr0[0].id;
bwitem.mlogb = arr0[0].id;
}else{
if(arr1.length>0){
that.wm_in = '';
that.$message.error("已存在");
}else{
that.form.batch = arr[0].batch;
that.form.wm_in = arr[0].id;
that.form.count_use += 1;
that.wm_in = '';
that.batchs = arr[0].id;
}
}
that.bwItemForms.push(bwitem);
// that.bwItemForm = bwitem;
}else{
that.wm_in = '';
that.$message.error("批次号不存在");
}
}
})
// if(that.tracking==10||that.tracking==null){//批次
// arr = that.materialOptions.filter((item) => {
// return item.batch == code;
// })
// if (arr.length > 0) {
// that.form.batch = arr[0].batch;
// that.form.wm_in = arr[0].id;
// that.form.count_use = arr[0].count;
// that.wm_in = arr[0].batch;
// }else{
// that.wm_in = '';
// that.$message.error("批次号不存在");
// }
// }else{//单件
// console.log('code',code);
// }
}
},
//表单提交方法
submit() {
let that = this;
if(that.hasMlogbIn){
that.$API.wpm.mlogbw.create.req(that.bwItemForms).then((res1) => {
that.wm_in = '';
that.form.mtask = '';
that.form.batch = '';
that.form.parent = '';
that.form.count_use = 0;
that.$emit("closed");
that.visible = false;
})
}else{
that.form.mlog = that.mlog;
that.$API.wpm.mlogb.in.req(that.form).then((res) => {
that.$message.success("添加成功");
that.wm_in = '';
that.form.mtask = '';
that.form.batch = '';
that.form.parent = '';
that.form.count_use = 0;
if(that.scanKyes!=='mat'&&that.bwItemForms.length>0){
//2
// async function callApis() {
// for (const item of that.bwItemForms) {
// item.mlogb = res.id;
// try {
// await that.$API.wpm.mlogbw.create.req(item).then((res) => {});
// } catch (error) {
// console.error('Error calling API:', error);
// }
// }
// }
// callApis();
//1
// const promises = that.bwItemForms.map(item => {
// item.mlogb = res.id;
// return that.$API.wpm.mlogbw.create.req(item).then((res) => {});
// });
// console.log('promises.length',promises.length);
// Promise.all(promises).then(results => {
// console.log('results',results);
// that.$emit("closed");
// }).catch(error => {
// console.error(error);
// });
//0
that.bwItemForms.forEach(item=>{
item.mlogb = res.id;
})
that.$API.wpm.mlogbw.create.req(that.bwItemForms).then((res1) => {
that.$emit("closed");
})
}else{
that.$emit("closed");
}
that.visible = false;
}).catch((err) => {});
}
},
//设置过滤项
setFilters(filters) {
this.selectionFilters = filters;
this.setFiltersVisible = true;
},
},
};
</script>
<style></style>