429 lines
9.4 KiB
Vue
429 lines
9.4 KiB
Vue
<template>
|
|
<el-dialog
|
|
:title="titleMap[mode]"
|
|
v-model="visible"
|
|
width="1000px"
|
|
:size="1000"
|
|
destroy-on-close
|
|
@closed="$emit('closed')"
|
|
>
|
|
<el-form
|
|
ref="dialogForm"
|
|
:model="form"
|
|
:rules="rules"
|
|
label-width="80px"
|
|
>
|
|
<el-row>
|
|
<el-col :md="12" :sm="24">
|
|
<el-form-item label="交接物料" prop="wm">
|
|
<el-select
|
|
v-model="form.wm"
|
|
placeholder="交接物料"
|
|
filterable
|
|
clearable
|
|
style="width: 100%"
|
|
@change="materialChange"
|
|
>
|
|
<el-option
|
|
v-for="item in materialOptions"
|
|
:key="item.id"
|
|
:label="item.batch"
|
|
:value="item.id"
|
|
>
|
|
<span>{{ item.batch }}</span>
|
|
<div style="float: right">
|
|
<span>{{ item.count }}</span>
|
|
<span
|
|
v-if="item.notok_sign_name !== null"
|
|
style="color: #aaaaaa"
|
|
>({{ item.notok_sign_name }})</span
|
|
>
|
|
</div>
|
|
</el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :md="12" :sm="24">
|
|
<el-form-item label="交送日期" prop="send_date">
|
|
<el-date-picker
|
|
v-model="form.send_date"
|
|
type="date"
|
|
placeholder="选择时间"
|
|
format="YYYY-MM-DD"
|
|
value-format="YYYY-MM-DD"
|
|
style="width: 100%"
|
|
/>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :md="12" :sm="24">
|
|
<el-form-item label="交接数量" width="100">
|
|
<el-input-number
|
|
v-model="form.count"
|
|
controls-position="right"
|
|
:min="0"
|
|
step="1"
|
|
:step-strictly="true"
|
|
style="width: 100%"
|
|
placeholder="交接数量"
|
|
>
|
|
</el-input-number>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :md="12" :sm="24">
|
|
<el-form-item label="交送人" prop="send_user">
|
|
<el-select
|
|
v-model="form.send_user"
|
|
placeholder="交送人"
|
|
clearable
|
|
filterable
|
|
style="width: 100%"
|
|
>
|
|
<el-option
|
|
v-for="item in userList"
|
|
:key="item.id"
|
|
:label="item.name"
|
|
:value="item.id"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :md="12" :sm="24" v-if="type==30">
|
|
<el-form-item label="接收部门" prop="recive_dept">
|
|
<el-select
|
|
v-model="form.recive_dept"
|
|
placeholder="接收工段"
|
|
clearable
|
|
style="width: 100%"
|
|
@change="getUserList3"
|
|
>
|
|
<el-option
|
|
v-for="item in deptOptions"
|
|
:key="item.id"
|
|
:label="item.name"
|
|
:value="item.id"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :md="12" :sm="24" v-else>
|
|
<el-form-item label="接收工段" prop="recive_mgroup">
|
|
<el-select
|
|
v-model="form.recive_mgroup"
|
|
placeholder="接收工段"
|
|
clearable
|
|
style="width: 100%"
|
|
@change="getUserList2"
|
|
>
|
|
<el-option
|
|
v-for="item in mgroupOptions"
|
|
:key="item.id"
|
|
:label="item.name"
|
|
:value="item.id"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :md="12" :sm="24">
|
|
<el-form-item label="接收人" prop="recive_user">
|
|
<el-select
|
|
v-model="form.recive_user"
|
|
placeholder="接收人"
|
|
clearable
|
|
filterable
|
|
style="width: 100%"
|
|
>
|
|
<el-option
|
|
v-for="item in userList2"
|
|
:key="item.id"
|
|
:label="item.name"
|
|
:value="item.id"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
</el-row>
|
|
</el-form>
|
|
<el-footer>
|
|
<el-button type="primary" v-loading="isSaveing" @click="submit"
|
|
>确定</el-button
|
|
>
|
|
<el-button @click="visible = false">取消</el-button>
|
|
</el-footer>
|
|
</el-dialog>
|
|
</template>
|
|
<script>
|
|
export default {
|
|
emits: ["success", "closed"],
|
|
props: {
|
|
type: {
|
|
type: Number,
|
|
default: 10,
|
|
},
|
|
mgroupId: {
|
|
type: String,
|
|
default: "",
|
|
},
|
|
mgroupName: {
|
|
type: String,
|
|
default: "",
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
yseorno: ["是", "否"],
|
|
loading: false,
|
|
mode: "add",
|
|
titleMap: {
|
|
add: "新增交接记录",
|
|
edit: "编辑交接记录",
|
|
show: "查看交接记录",
|
|
},
|
|
handle_user: [],
|
|
form: {
|
|
batch: "",
|
|
count: 0, //送料数
|
|
wm: "",
|
|
send_date: "",
|
|
send_user: "",
|
|
send_mgroup: "",
|
|
recive_user: "",
|
|
recive_mgroup: "",
|
|
},
|
|
rules: {
|
|
batch: [
|
|
{
|
|
required: true,
|
|
message: "请输入批次号",
|
|
trigger: "blur",
|
|
},
|
|
],
|
|
wm: {
|
|
required: true,
|
|
message: "请选择物料",
|
|
trigger: "blur",
|
|
},
|
|
send_date: [
|
|
{
|
|
required: true,
|
|
message: "请选择送料日期",
|
|
trigger: "blur",
|
|
},
|
|
],
|
|
send_user: [
|
|
{
|
|
required: true,
|
|
message: "请选择交送人",
|
|
trigger: "blur",
|
|
},
|
|
],
|
|
send_mgroup: [
|
|
{
|
|
required: true,
|
|
message: "请选择交送工段",
|
|
trigger: "blur",
|
|
},
|
|
],
|
|
recive_user: [
|
|
{
|
|
required: true,
|
|
message: "请选择接收人",
|
|
trigger: "blur",
|
|
},
|
|
],
|
|
recive_mgroup: [
|
|
{
|
|
required: true,
|
|
message: "请选择接收工段",
|
|
trigger: "blur",
|
|
},
|
|
],
|
|
},
|
|
deptID:'',
|
|
userList: [],
|
|
userList2: [],
|
|
deptOptions:[],
|
|
mgroupOptions: [],
|
|
materialOptions: [],
|
|
visible: false,
|
|
isSaveing: false,
|
|
setFiltersVisible: false,
|
|
};
|
|
},
|
|
mounted() {
|
|
let that = this;
|
|
that.form.type = that.type;
|
|
let materialObj = that.$TOOL.data.get("MATERIAL_OBJECT");
|
|
that.materialObj = materialObj;
|
|
let date = new Date();
|
|
let year = date.getFullYear();
|
|
let month = date.getMonth() + 1;
|
|
let day = date.getDate();
|
|
that.form.handle_date = year + "-" + month + "-" + day;
|
|
that.form.send_mgroup = that.mgroupId;
|
|
console.log('mgroupName',that.mgroupName)
|
|
if(that.mgroupName=="size"||that.mgroupName=="facade"){//检验部交接
|
|
that.$API.system.user.list
|
|
.req({ page: 0, posts__code__contains: "check" })
|
|
.then((res) => {
|
|
that.userList = res;
|
|
});
|
|
}else{
|
|
that.deptID = that.$TOOL.data.get('gx_deptID');
|
|
that.getUserList();
|
|
}
|
|
that.getMaterial();
|
|
that.getDeptOptions();
|
|
that.getMgroupOptions();
|
|
},
|
|
methods: {
|
|
//获取部门列表
|
|
getDeptOptions() {
|
|
this.$API.system.dept.list
|
|
.req({ page: 0, type: "dept" })
|
|
.then((res) => {
|
|
this.deptOptions = res;
|
|
});
|
|
},
|
|
//获取工段列表
|
|
getMgroupOptions() {
|
|
this.$API.mtm.mgroup.list
|
|
.req({ page: 0})
|
|
.then((res) => {
|
|
this.mgroupOptions = res;
|
|
});
|
|
},
|
|
//获取车间物料
|
|
getMaterial() {
|
|
let that = this;
|
|
var req = {
|
|
mgroupx: that.mgroupId,
|
|
page: 0,
|
|
notok_sign__isnull : 1,
|
|
count_xtest__isnull:1
|
|
};
|
|
if(that.mgroupName=="size"){
|
|
req.material__process__name="一次超洗";
|
|
}else if(that.mgroupName=="facade"){
|
|
req.material__process__name="二次超洗";
|
|
}
|
|
// else{
|
|
// if (this.type == 10) {
|
|
// req.notok_sign__isnull = 1;
|
|
// } else if (this.type == 20) {
|
|
// req.notok_sign__isnull = 0;
|
|
// }else if (this.type == 30) {
|
|
// req.notok_sign__isnull = 1;
|
|
// }
|
|
// }
|
|
|
|
this.$API.wpm.wmaterial.list
|
|
.req(req)
|
|
.then((res) => {
|
|
that.materialOptions = res;
|
|
});
|
|
},
|
|
//获取交送工段人员
|
|
getUserList() {
|
|
let that = this;
|
|
this.$API.system.user.list
|
|
.req({ depts: that.deptID, page: 0 })
|
|
.then((res) => {
|
|
that.userList = res;
|
|
});
|
|
},
|
|
//获取接收工段人员
|
|
getUserList2() {
|
|
let that = this;
|
|
let deptID = '';
|
|
this.mgroupOptions.forEach(item => {
|
|
if(item.id==that.form.recive_mgroup){
|
|
deptID = item.belong_dept;
|
|
this.$API.system.user.list
|
|
.req({ depts: deptID, page: 0 })
|
|
.then((res) => {
|
|
that.userList2 = res;
|
|
});
|
|
}
|
|
});
|
|
},
|
|
//获取接收部门人员
|
|
getUserList3() {
|
|
let that = this;
|
|
this.$API.system.user.list
|
|
.req({ depts: that.form.recive_dept, page: 0 })
|
|
.then((res) => {
|
|
that.userList2 = res;
|
|
});
|
|
},
|
|
//显示
|
|
open(mode = "add") {
|
|
this.mode = mode;
|
|
this.visible = true;
|
|
return this;
|
|
},
|
|
materialChange(val) {
|
|
let data = this.materialOptions.filter((item) => {
|
|
return item.id == val;
|
|
});
|
|
this.form.batch = data[0].batch;
|
|
},
|
|
//提交
|
|
submit() {
|
|
this.$refs.dialogForm.validate(async (valid) => {
|
|
if (valid) {
|
|
if (this.mode == "add") {
|
|
this.$API.wpm.handover.create
|
|
.req(this.form)
|
|
.then((res) => {
|
|
this.isSaveing = false;
|
|
this.$emit("success", this.form, this.mode);
|
|
this.visible = false;
|
|
this.$message.success("操作成功");
|
|
})
|
|
.catch((err) => {
|
|
//可以处理校验错误
|
|
this.isSaveing = false;
|
|
return err;
|
|
});
|
|
} else if (this.mode == "edit") {
|
|
this.$API.wpm.handover.update
|
|
.req(this.form.id, this.form)
|
|
.then((res) => {
|
|
this.isSaveing = false;
|
|
this.$emit("success", this.form, this.mode);
|
|
this.visible = false;
|
|
this.$message.success("操作成功");
|
|
})
|
|
.catch((err) => {
|
|
//可以处理校验错误
|
|
this.isSaveing = false;
|
|
return err;
|
|
});
|
|
}
|
|
}
|
|
});
|
|
},
|
|
//表单注入数据
|
|
setData(data) {
|
|
Object.assign(this.form, data);
|
|
if(data.type==30){
|
|
this.getUserList3();
|
|
}else{
|
|
this.getUserList2();
|
|
}
|
|
},
|
|
//设置过滤项
|
|
setFilters(filters) {
|
|
this.selectionFilters = filters;
|
|
this.setFiltersVisible = true;
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
<style scoped>
|
|
.formTitle {
|
|
margin-bottom: 10px;
|
|
font-weight: 600;
|
|
}
|
|
</style>
|