工艺模板列表修改

dev-scheduling
zhangdi 3 months ago
parent de1430b109
commit 4a10d1bcbb
  1. 357
      src/views/processManagement/components/addTemplateDialog.vue
  2. 3
      src/views/processManagement/processTemplate.vue

@ -15,17 +15,17 @@
class="demo-ruleForm" class="demo-ruleForm"
> >
<el-row :gutter="24"> <el-row :gutter="24">
<el-col :span="8"> <el-col :span="6">
<el-form-item label="模板编码:" prop="code"> <el-form-item label="模板编码:" prop="code">
<el-input v-model="ruleForm.code"></el-input> <el-input v-model="ruleForm.code"></el-input>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="6">
<el-form-item label="模板名称:" prop="name"> <el-form-item label="模板名称:" prop="name">
<el-input v-model="ruleForm.name"></el-input> <el-input v-model="ruleForm.name"></el-input>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="6">
<el-form-item label="模板类型:" prop="templateType"> <el-form-item label="模板类型:" prop="templateType">
<el-select v-model="ruleForm.templateType" placeholder="请选择" clearable filterable> <el-select v-model="ruleForm.templateType" placeholder="请选择" clearable filterable>
<el-option <el-option
@ -37,7 +37,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="6">
<el-form-item label="作业中心:" prop="workCenterId"> <el-form-item label="作业中心:" prop="workCenterId">
<el-select v-model="ruleForm.workCenterId" placeholder="请选择" clearable filterable> <el-select v-model="ruleForm.workCenterId" placeholder="请选择" clearable filterable>
<el-option v-for="item in workCenterList" :label="item.wcName" :value="item.id"> <el-option v-for="item in workCenterList" :label="item.wcName" :value="item.id">
@ -45,7 +45,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="6">
<el-form-item label="镀种分类:" prop="platingType"> <el-form-item label="镀种分类:" prop="platingType">
<el-select v-model="ruleForm.platingType" placeholder="请选择" clearable filterable> <el-select v-model="ruleForm.platingType" placeholder="请选择" clearable filterable>
<el-option <el-option
@ -57,34 +57,47 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="6">
<el-form-item label="优先级:" prop="priority"> <el-form-item label="优先级:" prop="priority">
<el-input-number <el-input-number
v-model="ruleForm.priority" v-model="ruleForm.priority"
controls-position="right" controls-position="right"
@change="handleChange"
:min="1" :min="1"
:max="10" :max="10"
></el-input-number> ></el-input-number>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="16"> <el-col :span="8">
<el-form-item label="备注:" prop="remarks"> <el-form-item label="备注:" prop="remarks">
<el-input v-model="ruleForm.remarks" type="textarea" :rows="3"></el-input> <el-input v-model="ruleForm.remarks" type="textarea" :rows="2"></el-input>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<div class="process-box">
<div class="process-left">
<el-tree
:data="treeData"
:props="defaultProps"
@node-click="handleNodeClick"
:default-expand-all="true"
:expand-on-click-node="false"
/>
</div>
<div class="process-right">
<el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick">
<el-tab-pane label="工序" name="1" v-if="treeLeave == 1"></el-tab-pane>
<el-tab-pane label="项目" name="2" v-if="treeLeave == 2"></el-tab-pane>
</el-tabs>
<div style="margin-bottom: 12px" v-if="moldAddMore"> <div style="margin-bottom: 12px" v-if="moldAddMore">
<el-button type="primary" @click="addTable">插入一行</el-button> <el-button type="primary" @click="addTable">插入一行</el-button>
<el-button type="danger" @click="delTable">删除行</el-button> <el-button type="danger" @click="delTable">删除选择</el-button>
</div> </div>
<!-- 全局错误提示 --> <!-- 全局错误提示 -->
<div v-if="formError" class="error-message" style="color: #f56c6c; margin-bottom: 10px"> <div v-if="formError" class="error-message" style="color: #f56c6c; margin-bottom: 10px">
{{ formError }} {{ formError }}
</div> </div>
<el-table :data="ruleForm.tableData" style="width: 100%"> <el-table v-if="activeName == '1'" :data="ruleForm.tableData" style="width: 100%">
<el-table-column type="selection" width="55"> </el-table-column> <el-table-column type="selection" width="55"> </el-table-column>
<el-table-column prop="processNo" label="工序号" align="left"> <el-table-column prop="processNo" label="工序号" align="left">
<template #header> <template #header>
@ -93,7 +106,7 @@
<template #default="scope"> <template #default="scope">
<el-form-item <el-form-item
:prop="`tableData[${scope.$index}].processNo`" :prop="`tableData[${scope.$index}].processNo`"
:rules="rules.processNo" :rules="rules.tableData.processNo"
label-width="0" label-width="0"
> >
<el-input v-model="scope.row.processNo" placeholder="请输入内容"></el-input> <el-input v-model="scope.row.processNo" placeholder="请输入内容"></el-input>
@ -107,7 +120,7 @@
<template #default="scope"> <template #default="scope">
<el-form-item <el-form-item
:prop="`tableData[${scope.$index}].processCode`" :prop="`tableData[${scope.$index}].processCode`"
:rules="rules.processCode" :rules="rules.tableData.processCode"
label-width="0" label-width="0"
> >
<el-select <el-select
@ -117,17 +130,16 @@
clearable clearable
filterable filterable
> >
<el-option v-for="(item, index) in processList" :label="item.name" :value="item.id"> <el-option
v-for="(item, index) in processList"
:label="item.name"
:value="item.id"
>
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
</template> </template>
</el-table-column> </el-table-column>
<!-- <el-table-column prop="processName" label="工序名称" align="left">
<template #default="scope">
<span>{{ scope.row.processName }}</span>
</template>
</el-table-column> -->
<el-table-column prop="craftCode" label="工艺能力" align="left"> <el-table-column prop="craftCode" label="工艺能力" align="left">
<template #header> <template #header>
<span><i style="color: red">*</i>工艺能力</span> <span><i style="color: red">*</i>工艺能力</span>
@ -135,10 +147,15 @@
<template #default="scope"> <template #default="scope">
<el-form-item <el-form-item
:prop="`tableData[${scope.$index}].craftCode`" :prop="`tableData[${scope.$index}].craftCode`"
:rules="rules.craftCode" :rules="rules.tableData.craftCode"
label-width="0" label-width="0"
> >
<el-select v-model="scope.row.craftCode" placeholder="请选择" clearable filterable> <el-select
v-model="scope.row.craftCode"
placeholder="请选择"
clearable
filterable
>
<el-option v-for="item in craftCodeList" :label="item.name" :value="item.id"> <el-option v-for="item in craftCodeList" :label="item.name" :value="item.id">
</el-option> </el-option>
</el-select> </el-select>
@ -152,7 +169,7 @@
<template #default="scope"> <template #default="scope">
<el-form-item <el-form-item
:prop="`tableData[${scope.$index}].workHours`" :prop="`tableData[${scope.$index}].workHours`"
:rules="rules.workHours" :rules="rules.tableData.workHours"
label-width="0" label-width="0"
> >
<el-input-number <el-input-number
@ -171,7 +188,7 @@
<template #default="scope"> <template #default="scope">
<el-form-item <el-form-item
:prop="`tableData[${scope.$index}].proDes`" :prop="`tableData[${scope.$index}].proDes`"
:rules="rules.proDes" :rules="rules.tableData.proDes"
label-width="0" label-width="0"
> >
<el-input v-model="scope.row.proDes" placeholder="请输入内容"></el-input> <el-input v-model="scope.row.proDes" placeholder="请输入内容"></el-input>
@ -185,7 +202,7 @@
<template #default="scope"> <template #default="scope">
<el-form-item <el-form-item
:prop="`tableData[${scope.$index}].isMain`" :prop="`tableData[${scope.$index}].isMain`"
:rules="rules.isMain" :rules="rules.tableData.isMain"
label-width="0" label-width="0"
> >
<el-select v-model="scope.row.isMain" placeholder="请选择" clearable filterable> <el-select v-model="scope.row.isMain" placeholder="请选择" clearable filterable>
@ -196,6 +213,108 @@
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<el-table v-if="activeName == '2'" :data="ruleForm.tableData2" style="width: 100%">
<el-table-column type="selection" width="55"> </el-table-column>
<el-table-column prop="trialNo" label="工序号">
<template #header>
<span><i style="color: red">*</i>工序号</span>
</template>
<template #default="scope">
<el-form-item
:prop="`tableData2[${scope.$index}].trialNo`"
:rules="rules.tableData2.trialNo"
label-width="0"
>
<el-input
v-model="scope.row.trialNo"
placeholder="请输入"
style="width: 100%"
></el-input>
</el-form-item>
</template>
</el-table-column>
<el-table-column prop="projectCode" label="检验项目">
<template #header>
<span><i style="color: red">*</i>检验项目</span>
</template>
<template #default="scope">
<el-form-item
:prop="`tableData2[${scope.$index}].projectCode`"
:rules="rules.tableData2.projectCode"
label-width="0"
>
<el-select
v-model="scope.row.projectCode"
placeholder="请选择"
clearable
filterable
@change="projectChange(scope.row, scope.$index)"
>
<el-option
v-for="(item, index) in projectOptions"
:label="item.name"
:value="item.id"
></el-option>
</el-select>
</el-form-item>
</template>
</el-table-column>
<el-table-column prop="projectStandard" label="检验标准">
<template #header>
<span><i style="color: red">*</i>检验标准</span>
</template>
<template #default="scope">
<el-form-item
:prop="`tableData2[${scope.$index}].projectStandard`"
:rules="rules.tableData2.projectStandard"
label-width="0"
>
<el-select
v-model="scope.row.projectStandard"
placeholder="请选择"
clearable
filterable
@change="standardChange(scope.row, scope.$index)"
>
<el-option
v-for="(item, index) in standardList"
:label="item.name"
:value="item.id"
></el-option>
</el-select>
</el-form-item>
</template>
</el-table-column>
<el-table-column prop="proHours" label="定额工时(分钟)">
<template #header>
<span><i style="color: red">*</i>定额工时(分钟)</span>
</template>
<template #default="scope">
<el-form-item
:prop="`tableData2[${scope.$index}].proHours`"
:rules="rules.tableData2.proHours"
label-width="0"
>
<el-input
v-model="scope.row.proHours"
placeholder="请输入"
style="width: 100%"
></el-input>
</el-form-item>
</template>
</el-table-column>
<el-table-column prop="prepareHours" label="准备工时(分钟)">
<template #default="scope">
<el-input
v-model="scope.row.prepareHours"
placeholder="请输入"
style="width: 100%"
></el-input>
</template>
</el-table-column>
</el-table>
</div>
</div>
</el-form> </el-form>
<template #footer> <template #footer>
@ -215,6 +334,7 @@ import {
getDetail, getDetail,
getProcessAbilityList, getProcessAbilityList,
} from '@/api/processManagement/processTemplate'; } from '@/api/processManagement/processTemplate';
import { getProject, getStandardList } from '@/api/processManagement/taskProcessing';
import { getList } from '@/api/processManagement/basicProcesses'; import { getList } from '@/api/processManagement/basicProcesses';
import { getWorkCenterList } from '@/api/processManagement/addQuantity'; import { getWorkCenterList } from '@/api/processManagement/addQuantity';
import pinyin from 'pinyin'; import pinyin from 'pinyin';
@ -239,7 +359,75 @@ export default {
}, },
data() { data() {
return { return {
formLoading:false, treeData: [
{
label: '工序列表',
processList: [
{
processInfo: {
processName: '工序1',
},
projectInfo: [
{
jobName: '作业1',
},
{
jobName: '作业2',
},
],
},
{
processInfo: {
processName: '工序2',
},
projectInfo: [
{
jobName: '作业2',
},
{
jobName: '作业3',
},
],
},
],
},
], //
defaultProps: {
label: data => {
// Level 1: ""
if (data.label && data.processList) {
return data.label;
}
// Level 2:
if (data.processInfo) {
return data.processInfo.processName || '未命名工序';
}
// Level 3: /
if (data.jobName !== undefined) {
return data.jobName;
}
return '未知节点';
},
children: data => {
// Level 1 Level 2
if (data.processList) {
return data.processList;
}
// Level 2 Level 3
if (data.processInfo && data.projectInfo) {
return data.projectInfo;
}
// Level 3
return [];
},
isLeaf: data => {
// jobName
return data.jobName !== undefined;
},
},
activeName: '1',
treeLeave: 1, //
formLoading: false,
craftCodeList: [], // craftCodeList: [], //
formError: '', // formError: '', //
processTemplateList: [], processTemplateList: [],
@ -255,6 +443,7 @@ export default {
platingType: '', platingType: '',
priority: '', priority: '',
tableData: [], tableData: [],
tableData2: [],
}, },
rules: { rules: {
code: [{ required: true, message: '请输入', trigger: 'blur' }], code: [{ required: true, message: '请输入', trigger: 'blur' }],
@ -281,6 +470,24 @@ export default {
trigger: 'submit', trigger: 'submit',
}, },
], ],
tableData2: [
{
required: true,
message: '请至少添加一行数据',
trigger: 'submit',
type: 'array', //
},
{
validator: (rule, value, callback) => {
if (value.length === 0) {
callback(new Error('请至少添加一行数据'));
} else {
callback();
}
},
trigger: 'submit',
},
],
processNo: [{ required: true, message: '请输入工序号', trigger: 'blur' }], processNo: [{ required: true, message: '请输入工序号', trigger: 'blur' }],
processCode: [{ required: true, message: '请选择工序代码', trigger: 'blur' }], processCode: [{ required: true, message: '请选择工序代码', trigger: 'blur' }],
craftCode: [{ required: true, message: '请选择工艺能力', trigger: 'blur' }], craftCode: [{ required: true, message: '请选择工艺能力', trigger: 'blur' }],
@ -288,7 +495,10 @@ export default {
proDes: [{ required: true, message: '请输入工序描述', trigger: 'blur' }], proDes: [{ required: true, message: '请输入工序描述', trigger: 'blur' }],
isMain: [{ required: true, message: '请选择主工序', trigger: 'blur' }], isMain: [{ required: true, message: '请选择主工序', trigger: 'blur' }],
}, },
workCenterList: [], // workCenterList: [], //
projectOptions: [], //
standardList: [], //
}; };
}, },
mounted() { mounted() {
@ -299,12 +509,57 @@ export default {
this.getProcessList(); this.getProcessList();
this.getWorkCenterList(); this.getWorkCenterList();
this.getProcessAbilityList(); this.getProcessAbilityList();
this.getProject();
this.getStandardList();
if (this.title == '修改') { if (this.title == '修改') {
this.getDetail(); this.getDetail();
} }
}, },
methods: { methods: {
//
projectChange(row, index) {
let selectName = this.projectOptions.find(item => item.id == row.projectCode);
this.form2.tableData2[index].projectName = selectName.name;
},
//
standardChange(row, index) {
let selectName = this.standardList.find(item => item.id == row.projectStandard);
this.form2.tableData2[index].projectStandardName = selectName.name;
},
getStandardList() {
getStandardList().then(res => {
this.standardList = res.data.data;
});
},
getProject() {
getProject({ size: 999999, current: 1 }).then(res => {
this.projectOptions = res.data.data.records;
});
},
//
handleNodeClick(nodes, node, self) {
const data = nodes;
if (data.label && data.processList) {
this.activeName = '1';
this.treeLeave = 1;
this.ruleForm.tableData = data.processList;
} else if (data.processInfo) {
this.activeName = '2';
this.treeLeave = 2;
this.ruleForm.tableData2 = [data.projectInfo];
}
},
// tab
handleClick(value) {
console.log(999999, value);
// this.form1.deleteIds = [];
// this.form2.deleteIds = [];
// this.form3.deleteIds = [];
// this.form4.deleteIds = [];
},
nameChange() {}, nameChange() {},
// //
getProcessNo(table) { getProcessNo(table) {
const len = table; const len = table;
@ -384,7 +639,7 @@ export default {
submit() { submit() {
this.$refs.ruleForm.validate(valid => { this.$refs.ruleForm.validate(valid => {
if (valid) { if (valid) {
this.formLoading = true this.formLoading = true;
const pinyinArr = pinyin(this.ruleForm.name, { const pinyinArr = pinyin(this.ruleForm.name, {
style: pinyin.STYLE_NORMAL, // STYLE_TONE style: pinyin.STYLE_NORMAL, // STYLE_TONE
heteronym: false, // heteronym: false, //
@ -399,27 +654,31 @@ export default {
// //
if (!this.moldAddMore) { if (!this.moldAddMore) {
update(query).then(res => { update(query)
this.formLoading = false .then(res => {
this.formLoading = false;
this.$message({ this.$message({
type: 'success', type: 'success',
message: '操作成功!', message: '操作成功!',
}); });
this.$emit('closeDialog'); this.$emit('closeDialog');
}).catch(err=>{ })
this.formLoading = false .catch(err => {
this.formLoading = false;
}); });
} else { } else {
// //
add(query).then(res => { add(query)
this.formLoading = false .then(res => {
this.formLoading = false;
this.$message({ this.$message({
type: 'success', type: 'success',
message: '操作成功!', message: '操作成功!',
}); });
this.$emit('closeDialog'); this.$emit('closeDialog');
}).catch(err=>{ })
this.formLoading = false .catch(err => {
this.formLoading = false;
}); });
} }
} else { } else {
@ -475,4 +734,32 @@ export default {
padding: 0 !important; padding: 0 !important;
line-height: 50px !important; line-height: 50px !important;
} }
.process-box {
display: flex;
flex-direction: row;
height: calc(100vh - 280px);
.process-left {
// padding: 20px;
width: 240px;
border: 1px solid #ccc;
}
.process-right {
padding: 12px;
flex: 1;
border: 1px solid #ccc;
border-left: 0;
.table-btn {
width: 100%;
height: 50px;
.table-btn-left {
float: left;
}
.table-btn-right {
float: right;
}
}
}
}
</style> </style>

@ -10,7 +10,6 @@
@row-del="rowDel" @row-del="rowDel"
@search-change="searchChange" @search-change="searchChange"
@search-reset="searchReset" @search-reset="searchReset"
@selection-change="selectionChange"
@current-change="currentChange" @current-change="currentChange"
@size-change="sizeChange" @size-change="sizeChange"
@refresh-change="refreshChange" @refresh-change="refreshChange"
@ -74,7 +73,6 @@ export default {
height: 'auto', height: 'auto',
calcHeight: 32, calcHeight: 32,
tip: false, tip: false,
size: 'medium',
simplePage: true, simplePage: true,
searchShow: true, searchShow: true,
searchMenuSpan: 6, searchMenuSpan: 6,
@ -323,7 +321,6 @@ export default {
this.data = res.data.data.records; this.data = res.data.data.records;
this.loading = false; this.loading = false;
this.page.total = this.data.length; this.page.total = this.data.length;
this.selectionClear();
}); });
}, },
}, },

Loading…
Cancel
Save