!20 工艺流程

工艺流程
This commit is contained in:
打豆豆 2024-03-11 05:22:34 +00:00 committed by Gitee
commit 417df95800
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
14 changed files with 1349 additions and 437 deletions

View File

@ -0,0 +1,44 @@
import request from '@/utils/request'
// 查询工序类型列表
export function listMachinerytype(query) {
return request({
url: '/process/type/list',
method: 'get',
params: query
})
}
// 查询工序类型详细
export function getMachinerytype(processTypeld) {
return request({
url: '/process/type/' + processTypeld,
method: 'get'
})
}
// 新增工序类型
export function addMachinerytype(data) {
return request({
url: '/process/type/add',
method: 'post',
data: data
})
}
// 修改工序类型
export function updateMachinerytype(data) {
return request({
url: '/process/type/edit',
method: 'put',
data: data
})
}
// 删除工序类型
export function delMachinerytype(processTypeld) {
return request({
url: '/process/type/' + processTypeld,
method: 'delete'
})
}

View File

@ -34,7 +34,7 @@
<div class="right-menu"> <div class="right-menu">
<template v-if="device !== 'mobile'"> <template v-if="device !== 'mobile'">
<search id="header-search" class="right-menu-item" /> <!-- <search id="header-search" class="right-menu-item" /> -->
<!-- <el-tooltip content="源码地址" effect="dark" placement="bottom"> <!-- <el-tooltip content="源码地址" effect="dark" placement="bottom">
<ruo-yi-git id="ruoyi-git" class="right-menu-item hover-effect" /> <ruo-yi-git id="ruoyi-git" class="right-menu-item hover-effect" />
@ -46,9 +46,9 @@
<screenfull id="screenfull" class="right-menu-item hover-effect" /> <screenfull id="screenfull" class="right-menu-item hover-effect" />
<el-tooltip content="布局大小" effect="dark" placement="bottom"> <!-- <el-tooltip content="布局大小" effect="dark" placement="bottom">
<size-select id="size-select" class="right-menu-item hover-effect" /> <size-select id="size-select" class="right-menu-item hover-effect" />
</el-tooltip> </el-tooltip> -->
</template> </template>
<el-dropdown <el-dropdown

View File

@ -232,7 +232,6 @@
:options="machineryTypeOptions" :options="machineryTypeOptions"
:normalizer="normalizer" :normalizer="normalizer"
placeholder="请选择所属分类" placeholder="请选择所属分类"
:disable-branch-nodes="true"
@select="handleNodeClick" @select="handleNodeClick"
/> />
</el-form-item> </el-form-item>

View File

@ -324,7 +324,6 @@
:normalizer="normalizer" :normalizer="normalizer"
placeholder="请选择所属分类" placeholder="请选择所属分类"
v-else v-else
:disable-branch-nodes="true"
/> />
</el-form-item> </el-form-item>
</el-col> </el-col>

View File

@ -242,7 +242,7 @@
<el-col :span="12"> <el-col :span="12">
<el-form-item label="物料/产品分类" prop="itemTypeId"> <el-form-item label="物料/产品分类" prop="itemTypeId">
<treeselect v-model="form.itemTypeId" :options="itemTypeOptions" :show-count="true" disabled v-if="optType=='view'" /> <treeselect v-model="form.itemTypeId" :options="itemTypeOptions" :show-count="true" disabled v-if="optType=='view'" />
<treeselect v-model="form.itemTypeId" :options="itemTypeOptions" :show-count="true" placeholder="请选择所属分类" v-else :disable-branch-nodes="true"/> <treeselect v-model="form.itemTypeId" :options="itemTypeOptions" :show-count="true" placeholder="请选择所属分类" v-else/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>

View File

@ -249,7 +249,7 @@
<WorkStationMachine ref="machineryList" :optType="optType" :workstationId="form.workstationId" style="align:center"></WorkStationMachine> <WorkStationMachine ref="machineryList" :optType="optType" :workstationId="form.workstationId" style="align:center"></WorkStationMachine>
</el-card> </el-card>
</el-carousel-item> </el-carousel-item>
<el-carousel-item> <!-- <el-carousel-item>
<el-card shadow="always" style="width:400px"> <el-card shadow="always" style="width:400px">
<div slot="header"> <div slot="header">
<span>人力资源</span> <span>人力资源</span>
@ -257,8 +257,8 @@
</div> </div>
<Workstationworker ref="postList" :optType="optType" :workstationId="form.workstationId"></Workstationworker> <Workstationworker ref="postList" :optType="optType" :workstationId="form.workstationId"></Workstationworker>
</el-card> </el-card>
</el-carousel-item> </el-carousel-item> -->
<el-carousel-item> <!-- <el-carousel-item>
<el-card shadow="always" style="width:400px"> <el-card shadow="always" style="width:400px">
<div slot="header"> <div slot="header">
<span>工装夹具</span> <span>工装夹具</span>
@ -266,7 +266,7 @@
</div> </div>
<WorkStationTool ref="toolList" :optType="optType" :workstationId="form.workstationId"></WorkStationTool> <WorkStationTool ref="toolList" :optType="optType" :workstationId="form.workstationId"></WorkStationTool>
</el-card> </el-card>
</el-carousel-item> </el-carousel-item> -->
</el-carousel> </el-carousel>
</el-col> </el-col>
</el-row> </el-row>

View File

@ -1,6 +1,39 @@
<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="100px"> <el-row :gutter="20">
<!--分类数据-->
<el-col :span="4" :xs="24">
<div class="head-container">
<el-input
v-model="processTypeName"
placeholder="请输入类型名称"
clearable
size="small"
prefix-icon="el-icon-search"
style="margin-bottom: 20px"
/>
</div>
<div class="head-container">
<el-tree
:data="machineryTypeOptions"
:props="defaultPropss"
:expand-on-click-node="false"
:filter-node-method="filterNode"
ref="tree"
default-expand-all
@node-click="handleNodeClick"
/>
</div>
</el-col>
<el-col :span="20" :xs="24">
<el-form
:model="queryParams"
ref="queryForm"
size="small"
:inline="true"
v-show="showSearch"
label-width="100px"
>
<el-form-item label="工序编码" prop="processCode"> <el-form-item label="工序编码" prop="processCode">
<el-input <el-input
v-model="queryParams.processCode" v-model="queryParams.processCode"
@ -26,8 +59,16 @@
/> />
</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
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> type="primary"
icon="el-icon-search"
size="mini"
@click="handleQuery"
>搜索</el-button
>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
>重置</el-button
>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -40,7 +81,8 @@
size="mini" size="mini"
@click="handleAdd" @click="handleAdd"
v-hasPermi="['mes:pro:process:add']" v-hasPermi="['mes:pro:process:add']"
>新增</el-button> >新增</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
@ -51,7 +93,8 @@
:disabled="single" :disabled="single"
@click="handleUpdate" @click="handleUpdate"
v-hasPermi="['mes:pro:process:edit']" v-hasPermi="['mes:pro:process:edit']"
>修改</el-button> >修改</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
@ -62,7 +105,8 @@
:disabled="multiple" :disabled="multiple"
@click="handleDelete" @click="handleDelete"
v-hasPermi="['mes:pro:process:remove']" v-hasPermi="['mes:pro:process:remove']"
>删除</el-button> >删除</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
@ -72,30 +116,56 @@
size="mini" size="mini"
@click="handleExport" @click="handleExport"
v-hasPermi="['mes:pro:process:export']" v-hasPermi="['mes:pro:process:export']"
>导出</el-button> >导出</el-button
>
</el-col> </el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> <right-toolbar
:showSearch.sync="showSearch"
@queryTable="getList"
></right-toolbar>
</el-row> </el-row>
<el-table v-loading="loading" :data="processList" @selection-change="handleSelectionChange"> <el-table
v-loading="loading"
:data="processList"
@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="processCode" > <el-table-column label="工序编码" align="center" prop="processCode">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
type="text" type="text"
@click="handleView(scope.row)" @click="handleView(scope.row)"
v-hasPermi="['mes:pro:process:query']" v-hasPermi="['mes:pro:process:query']"
>{{scope.row.processCode}}</el-button> >{{ scope.row.processCode }}</el-button
>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="工序名称" align="center" prop="processName" :show-overflow-tooltip="true"/> <el-table-column
label="工序名称"
align="center"
prop="processName"
:show-overflow-tooltip="true"
/>
<el-table-column label="是否启用" align="center" prop="enableFlag"> <el-table-column label="是否启用" align="center" prop="enableFlag">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag :options="dict.type.sys_yes_no" :value="scope.row.enableFlag"/> <dict-tag
:options="dict.type.sys_yes_no"
:value="scope.row.enableFlag"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true"/> <el-table-column
<el-table-column label="操作" align="center" class-name="small-padding fixed-width"> label="备注"
align="center"
prop="remark"
:show-overflow-tooltip="true"
/>
<el-table-column
label="操作"
align="center"
class-name="small-padding fixed-width"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
size="mini" size="mini"
@ -103,20 +173,24 @@
icon="el-icon-edit" icon="el-icon-edit"
@click="handleUpdate(scope.row)" @click="handleUpdate(scope.row)"
v-hasPermi="['mes:pro:process:edit']" v-hasPermi="['mes:pro:process:edit']"
>修改</el-button> >修改</el-button
>
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
icon="el-icon-delete" icon="el-icon-delete"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
v-hasPermi="['mes:pro:process:remove']" v-hasPermi="['mes:pro:process:remove']"
>删除</el-button> >删除</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
</el-col>
</el-row>
<pagination <pagination
v-show="total>0" v-show="total > 0"
:total="total" :total="total"
:page.sync="queryParams.pageNum" :page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize" :limit.sync="queryParams.pageSize"
@ -129,38 +203,70 @@
<el-row> <el-row>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="工序编码" prop="processCode"> <el-form-item label="工序编码" prop="processCode">
<el-input v-model="form.processCode" placeholder="请输入工序编码" /> <el-input
v-model="form.processCode"
placeholder="请输入工序编码"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="3"> <el-col :span="3">
<el-form-item label-width="80"> <el-form-item label-width="80">
<el-switch v-model="autoGenFlag" <el-switch
v-model="autoGenFlag"
active-color="#13ce66" active-color="#13ce66"
active-text="自动生成" active-text="自动生成"
@change="handleAutoGenChange(autoGenFlag)" v-if="optType != 'view'"> @change="handleAutoGenChange(autoGenFlag)"
v-if="optType != 'view'"
>
</el-switch> </el-switch>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="7"> <el-col :span="7">
<el-form-item label="工序名称" prop="processName"> <el-form-item label="工序名称" prop="processName">
<el-input v-model="form.processName" placeholder="请输入工序名称" /> <el-input
v-model="form.processName"
placeholder="请输入工序名称"
/>
</el-form-item>
</el-col>
<el-col :span="11">
<el-form-item label="工序类型" prop="processTypeId">
<treeselect
v-model="form.processTypeId"
:options="machineryTypeOptions"
:normalizer="normalizer"
v-if="optType == 'view'"
/>
<treeselect
v-model="form.processTypeId"
:options="machineryTypeOptions"
:normalizer="normalizer"
placeholder="请选择所属分类"
v-else
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="6"> <el-col :span="6">
<el-form-item label="是否启用" prop="enableFlag"> <el-form-item label="是否启用" prop="enableFlag">
<el-radio-group v-model="form.enableFlag" disabled v-if="optType=='view'"> <el-radio-group
v-model="form.enableFlag"
disabled
v-if="optType == 'view'"
>
<el-radio <el-radio
v-for="dict in dict.type.sys_yes_no" v-for="dict in dict.type.sys_yes_no"
:key="dict.value" :key="dict.value"
:label="dict.value" :label="dict.value"
>{{dict.label}}</el-radio> >{{ dict.label }}</el-radio
>
</el-radio-group> </el-radio-group>
<el-radio-group v-model="form.enableFlag" v-else> <el-radio-group v-model="form.enableFlag" v-else>
<el-radio <el-radio
v-for="dict in dict.type.sys_yes_no" v-for="dict in dict.type.sys_yes_no"
:key="dict.value" :key="dict.value"
:label="dict.value" :label="dict.value"
>{{dict.label}}</el-radio> >{{ dict.label }}</el-radio
>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -168,22 +274,38 @@
<el-row> <el-row>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="工序说明" prop="attention"> <el-form-item label="工序说明" prop="attention">
<el-input v-model="form.attention" type="textarea" placeholder="请输入内容" /> <el-input
v-model="form.attention"
type="textarea"
placeholder="请输入内容"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="备注" prop="remark"> <el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" /> <el-input
v-model="form.remark"
type="textarea"
placeholder="请输入内容"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
</el-form> </el-form>
<el-divider content-position="center" v-if="form.processId !=null">操作步骤</el-divider> <el-divider content-position="center" v-if="form.processId != null"
<Processcontent v-if="form.processId !=null" :optType="optType" :processId="form.processId"></Processcontent> >操作步骤</el-divider
>
<Processcontent
v-if="form.processId != null"
:optType="optType"
:processId="form.processId"
></Processcontent>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
<el-button type="primary" @click="cancel" v-if="optType =='view'">返回</el-button> <el-button type="primary" @click="cancel" v-if="optType == 'view'"
>返回</el-button
>
<el-button type="primary" @click="submitForm" v-else> </el-button> <el-button type="primary" @click="submitForm" v-else> </el-button>
<el-button @click="cancel"> </el-button> <el-button @click="cancel"> </el-button>
</div> </div>
@ -192,17 +314,27 @@
</template> </template>
<script> <script>
import { listProcess, getProcess, delProcess, addProcess, updateProcess } from "@/api/mes/pro/process"; import {
listProcess,
getProcess,
delProcess,
addProcess,
updateProcess,
} from "@/api/mes/pro/process";
import Processcontent from "./content.vue"; import Processcontent from "./content.vue";
import {genCode} from "@/api/system/autocode/rule" import { genCode } from "@/api/system/autocode/rule";
import { listMachinerytype } from "@/api/mes/pro/processType";
import Treeselect from "@riophae/vue-treeselect";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
export default { export default {
name: "Process", name: "Process",
dicts: ['sys_yes_no'], dicts: ["sys_yes_no"],
components: {Processcontent}, components: { Treeselect,Processcontent },
data() { data() {
return { return {
// //
autoGenFlag:true, autoGenFlag: true,
optType: undefined, optType: undefined,
// //
loading: true, loading: true,
@ -229,36 +361,87 @@ export default {
processCode: null, processCode: null,
processName: null, processName: null,
enableFlag: null, enableFlag: null,
processTypeName: null,
processTypeId: null,
}, },
// //
form: {}, form: {},
// //
//
//
machineryTypeOptions: [],
processTypeName: undefined,
defaultPropss: {
children: "children",
label: "processTypeName",
},
rules: { rules: {
processCode: [ processCode: [
{ required: true, message: "工序编码不能为空", trigger: "blur" } { required: true, message: "工序编码不能为空", trigger: "blur" },
], ],
processName: [ processName: [
{ required: true, message: "工序名称不能为空", trigger: "blur" } { required: true, message: "工序名称不能为空", trigger: "blur" },
], ],
enableFlag: [ enableFlag: [
{ required: true, message: "是否启用不能为空", trigger: "blur" } { required: true, message: "是否启用不能为空", trigger: "blur" },
], ],
} },
}; };
}, },
watch: {
//
processTypeName(val) {
this.$refs.tree.filter(val);
},
},
created() { created() {
this.getList(); this.getList();
this.getTreeselect();
}, },
methods: { methods: {
/** 查询生产工序列表 */ /** 查询生产工序列表 */
getList() { getList() {
this.loading = true; this.loading = true;
listProcess(this.queryParams).then(response => { listProcess(this.queryParams).then((response) => {
this.processList = response.rows; this.processList = response.rows;
this.total = response.total; this.total = response.total;
this.loading = false; this.loading = false;
}); });
}, },
/** 转换设备类型数据结构 */
normalizer(node) {
if (node.children && !node.children.length) {
delete node.children;
}
return {
id: node.processTypeId,
label: node.processTypeName,
children: node.children,
};
},
/** 查询设备类型下拉树结构 */
getTreeselect() {
listMachinerytype().then((response) => {
this.machineryTypeOptions = [];
const data = this.handleTree(
response.data,
"processTypeId",
"parentTypeId"
)[0];
this.machineryTypeOptions.push(data);
});
},
//
filterNode(value, data) {
if (!value) return true;
return data.processTypeName.indexOf(value) !== -1;
},
//
handleNodeClick(data) {
this.queryParams.processTypeId = data.processTypeId;
// this.queryParamsdata = data;
this.handleQuery();
},
// //
cancel() { cancel() {
this.open = false; this.open = false;
@ -271,12 +454,14 @@ export default {
processCode: null, processCode: null,
processName: null, processName: null,
attention: null, attention: null,
enableFlag: 'Y', enableFlag: "Y",
remark: null, remark: null,
createBy: null, createBy: null,
createTime: null, createTime: null,
updateBy: null, updateBy: null,
updateTime: null updateTime: null,
processTypeName: null,
processTypeId: null,
}; };
this.autoGenFlag = true; this.autoGenFlag = true;
this.resetForm("form"); this.resetForm("form");
@ -293,9 +478,9 @@ export default {
}, },
// //
handleSelectionChange(selection) { handleSelectionChange(selection) {
this.ids = selection.map(item => item.processId) this.ids = selection.map((item) => item.processId);
this.single = selection.length!==1 this.single = selection.length !== 1;
this.multiple = !selection.length this.multiple = !selection.length;
}, },
/** 新增按钮操作 */ /** 新增按钮操作 */
handleAdd() { handleAdd() {
@ -303,15 +488,15 @@ export default {
this.open = true; this.open = true;
this.title = "添加生产工序"; this.title = "添加生产工序";
this.optType = "add"; this.optType = "add";
genCode('PROCESS_CODE').then(response =>{ genCode("PROCESS_CODE").then((response) => {
this.form.processCode = response; this.form.processCode = response;
}); });
}, },
// //
handleView(row){ handleView(row) {
this.reset(); this.reset();
const processId = row.processId || this.ids; const processId = row.processId || this.ids;
getProcess(processId).then(response => { getProcess(processId).then((response) => {
this.form = response.data; this.form = response.data;
this.open = true; this.open = true;
this.title = "查看工序信息"; this.title = "查看工序信息";
@ -321,8 +506,8 @@ export default {
/** 修改按钮操作 */ /** 修改按钮操作 */
handleUpdate(row) { handleUpdate(row) {
this.reset(); this.reset();
const processId = row.processId || this.ids const processId = row.processId || this.ids;
getProcess(processId).then(response => { getProcess(processId).then((response) => {
this.form = response.data; this.form = response.data;
this.open = true; this.open = true;
this.title = "修改生产工序"; this.title = "修改生产工序";
@ -331,16 +516,16 @@ export default {
}, },
/** 提交按钮 */ /** 提交按钮 */
submitForm() { submitForm() {
this.$refs["form"].validate(valid => { this.$refs["form"].validate((valid) => {
if (valid) { if (valid) {
if (this.form.processId != null) { if (this.form.processId != null) {
updateProcess(this.form).then(response => { updateProcess(this.form).then((response) => {
this.$modal.msgSuccess("修改成功"); this.$modal.msgSuccess("修改成功");
this.open = false; this.open = false;
this.getList(); this.getList();
}); });
} else { } else {
addProcess(this.form).then(response => { addProcess(this.form).then((response) => {
this.$modal.msgSuccess("新增成功"); this.$modal.msgSuccess("新增成功");
this.open = false; this.open = false;
this.getList(); this.getList();
@ -352,29 +537,37 @@ export default {
/** 删除按钮操作 */ /** 删除按钮操作 */
handleDelete(row) { handleDelete(row) {
const processIds = row.processId || this.ids; const processIds = row.processId || this.ids;
this.$modal.confirm('是否确认删除生产工序?').then(function() { this.$modal
.confirm("是否确认删除生产工序?")
.then(function () {
return delProcess(processIds); return delProcess(processIds);
}).then(() => { })
.then(() => {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}).catch(() => {}); })
.catch(() => {});
}, },
/** 导出按钮操作 */ /** 导出按钮操作 */
handleExport() { handleExport() {
this.download('mes/pro/process/export', { this.download(
...this.queryParams "mes/pro/process/export",
}, `process_${new Date().getTime()}.xlsx`) {
...this.queryParams,
},
`process_${new Date().getTime()}.xlsx`
);
}, },
// //
handleAutoGenChange(autoGenFlag){ handleAutoGenChange(autoGenFlag) {
if(autoGenFlag){ if (autoGenFlag) {
genCode('PROCESS_CODE').then(response =>{ genCode("PROCESS_CODE").then((response) => {
this.form.processCode = response; this.form.processCode = response;
}); });
}else{ } else {
this.form.processCode = null; this.form.processCode = null;
} }
} },
} },
}; };
</script> </script>

View File

@ -0,0 +1,288 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="类型名称" prop="processTypeName">
<el-input
v-model="queryParams.processTypeName"
placeholder="请输入工序类型名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="是否启用" prop="enableFlag">
<el-select v-model="queryParams.enableFlag" placeholder="选择是或否" clearable>
<el-option
v-for="dict in dict.type.sys_yes_no"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<el-table
v-loading="loading"
:data="machinerytypeList"
row-key="processTypeId"
default-expand-all
:tree-props="{children: 'children', hasChildren: 'hasChildren'}"
>
<el-table-column label="工序类型编码" prop="processTypeCode" />
<el-table-column label="工序类型名称" align="center" prop="processTypeName" />
<el-table-column label="是否启用" align="center" prop="enableFlag" >
<template slot-scope="scope">
<dict-tag :options="dict.type.sys_yes_no" :value="scope.row.enableFlag"/>
</template>
</el-table-column>
<el-table-column label="备注" align="center" prop="remark" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
>修改</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-plus"
@click="handleAdd(scope.row)"
>新增</el-button>
<el-button
v-if="scope.row.parentTypeId != 0"
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
>删除</el-button>
</template>
</el-table-column>
</el-table>
<!-- 添加或修改工序类型对话框 -->
<el-dialog :title="title" :visible.sync="open" width="700px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="120px">
<el-row>
<el-col :span="24" v-if="form.parentTypeId !== 0">
<el-form-item label="父类型" prop="parentTypeId">
<treeselect v-model="form.parentTypeId" :options="machinerytypeOptions" :normalizer="normalizer" placeholder="请选择父类型" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="工序类型名称" prop="processTypeName">
<el-input v-model="form.processTypeName" placeholder="请输入工序类型名称" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="是否启用" prop="enableFlag">
<el-radio-group v-model="form.enableFlag" disabled v-if="optType=='view'">
<el-radio
v-for="dict in dict.type.sys_yes_no"
:key="dict.value"
:label="dict.value"
>{{dict.label}}</el-radio>
</el-radio-group>
<el-radio-group v-model="form.enableFlag" v-else>
<el-radio
v-for="dict in dict.type.sys_yes_no"
:key="dict.value"
:label="dict.value"
>{{dict.label}}</el-radio>
</el-radio-group>
</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>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import { listMachinerytype, getMachinerytype, delMachinerytype, addMachinerytype, updateMachinerytype } from "@/api/mes/pro/processType";
import Treeselect from "@riophae/vue-treeselect";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
export default {
name: "Machinerytype",
dicts: ['sys_yes_no'],
components: {
Treeselect
},
data() {
return {
optType:undefined,
//
loading: true,
//
showSearch: true,
//
machinerytypeList: [],
//
machinerytypeOptions: [],
//
title: "",
//
open: false,
//
queryParams: {
machineryTypeCode: null,
processTypeName: null,
parentTypeId: null,
ancestors: null,
enableFlag: null,
},
//
form: {},
//
rules: {
parentTypeId: [
{ required: true, message: "父类型不能为空", trigger: "blur" }
],
processTypeName: [
{ required: true, message: "工序类型名称不能为空", trigger: "blur" }
],
enableFlag: [
{ required: true, message: "是否启用不能为空", trigger: "blur" }
],
}
};
},
created() {
this.getList();
},
methods: {
/** 查询工序类型列表 */
getList() {
this.loading = true;
listMachinerytype(this.queryParams).then(response => {
this.machinerytypeList = this.handleTree(response.data, "processTypeId", "parentTypeId");
this.loading = false;
});
},
/** 转换工序类型数据结构 */
normalizer(node) {
if (node.children && !node.children.length) {
delete node.children;
}
return {
id: node.processTypeId,
label: node.processTypeName,
children: node.children
};
},
/** 查询工序类型下拉树结构 */
getTreeselect() {
listMachinerytype().then(response => {
this.machinerytypeOptions = [];
const data = this.handleTree(response.data, "processTypeId", "parentTypeId")[0];
this.machinerytypeOptions.push(data);
});
},
//
cancel() {
this.open = false;
this.reset();
},
//
reset() {
this.form = {
processTypeId: null,
processTypeName: null,
parentTypeId: 1,
ancestors: null,
enableFlag: 'Y',
remark: null,
createBy: null,
createTime: null,
updateBy: null,
updateTime: null
};
this.resetForm("form");
},
/** 搜索按钮操作 */
handleQuery() {
this.getList();
},
/** 重置按钮操作 */
resetQuery() {
this.resetForm("queryForm");
this.handleQuery();
},
/** 新增按钮操作 */
handleAdd(row) {
this.reset();
this.getTreeselect();
if (row != null && row.processTypeId) {
this.form.parentTypeId = row.processTypeId;
} else {
this.form.parentTypeId = 0;
}
this.open = true;
this.title = "添加工序类型";
},
/** 修改按钮操作 */
handleUpdate(row) {
console.log(row);
this.reset();
this.getTreeselect();
if (row != null) {
this.form.parentTypeId = row.processTypeId;
}
getMachinerytype(row.processTypeId).then(response => {
this.form = response.data;
this.open = true;
this.title = "修改工序类型";
});
},
/** 提交按钮 */
submitForm() {
this.$refs["form"].validate(valid => {
if (valid) {
if (this.form.processTypeId != null) {
updateMachinerytype(this.form).then(response => {
this.$modal.msgSuccess("修改成功");
this.open = false;
this.getList();
});
} else {
addMachinerytype(this.form).then(response => {
this.$modal.msgSuccess("新增成功");
this.open = false;
this.getList();
});
}
}
});
},
/** 删除按钮操作 */
handleDelete(row) {
console.log(row);
this.$modal.confirm('是否确认删除工序类型编号为"' + row.processTypeId + '"的数据项?').then(function() {
return delMachinerytype(row.processTypeId);
}).then(() => {
this.getList();
this.$modal.msgSuccess("删除成功");
}).catch(() => {});
}
}
};
</script>

View File

@ -291,6 +291,16 @@
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<!-- <el-row>
<el-col :span="12">
<el-form-item label="是否工艺节点" prop="idid">
<el-radio-group v-model="form.idid">
<el-radio :label="0"></el-radio>
<el-radio :label="1"></el-radio>
</el-radio-group>
</el-form-item>
</el-col>
</el-row> -->
<el-row> <el-row>
<el-col :span="12"> <el-col :span="12">
<el-form-item label="选择设备类型" prop="machineryTypeId"> <el-form-item label="选择设备类型" prop="machineryTypeId">
@ -299,14 +309,14 @@
:options="machineryTypeOptions" :options="machineryTypeOptions"
:normalizer="normalizer" :normalizer="normalizer"
placeholder="请选择设备类型" placeholder="请选择设备类型"
:disable-branch-nodes="true"
@select="handleNodeClick" @select="handleNodeClick"
/> />
<!-- :disable-branch-nodes="true" -->
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12"> <!-- <el-col :span="12"> -->
<!-- <el-col :span="12" v-if="Typefile">--> <el-col :span="12" v-if="Typefile">
<el-form-item label="代码上传" prop=""> <!-- <el-form-item label="代码上传" prop="">
<el-upload <el-upload
ref="codeName" ref="codeName"
class="upload-demo" class="upload-demo"
@ -329,11 +339,26 @@
>&nbsp;预览文件</el-button >&nbsp;预览文件</el-button
> >
</el-upload> </el-upload>
</el-form-item> -->
<el-form-item label="代码上传" prop="url">
<el-select
v-model="form.originalName"
value-key="codeId"
placeholder="请选择工序"
@change="selectSource($event)"
>
<el-option
v-for="item in machineryList"
:key="item.codeId"
:label="item.codeName"
:value="{ url: item.codeId, originalName: item.codeName }"
></el-option>
</el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="12"> <el-col :span="12" v-if="warehousing">
<el-form-item label="选择出入库类型" prop="exitType"> <el-form-item label="选择出入库类型" prop="exitType">
<el-radio-group v-model="form.exitType"> <el-radio-group v-model="form.exitType">
<el-radio label="0">出库</el-radio> <el-radio label="0">出库</el-radio>
@ -402,6 +427,7 @@
</template> </template>
<script> <script>
import { list } from "@/api/management/codeprogram";
import { findProAgvline } from "@/api/mes/dv/route"; import { findProAgvline } from "@/api/mes/dv/route";
import { findProAgvsite } from "@/api/mes/dv/siteConfiguration"; import { findProAgvsite } from "@/api/mes/dv/siteConfiguration";
import { import {
@ -471,7 +497,8 @@ export default {
lineName: "", lineName: "",
pointName: "", pointName: "",
TypeId: false, TypeId: false,
// Typefile: false, Typefile: false,
warehousing: false,
// //
form: { form: {
originalName: "", originalName: "",
@ -479,6 +506,7 @@ export default {
lineId: "", lineId: "",
pointId: "", pointId: "",
}, },
machineryList: [],
// //
rules: { rules: {
routeId: [ routeId: [
@ -504,6 +532,9 @@ export default {
trigger: "blur", trigger: "blur",
}, },
], ],
idid: [
{ required: true, message: "请选择是否工艺节点", trigger: "blur" },
],
}, },
}; };
}, },
@ -568,16 +599,40 @@ export default {
handleNodeClick(data) { handleNodeClick(data) {
if (data.machineryTypeId == 229) { if (data.machineryTypeId == 229) {
this.TypeId = true; this.TypeId = true;
// this.Typefile = false; this.Typefile = false;
this.warehousing = false;
this.form.originalName = "";
this.form.url = "";
this.form.exitType = "";
} else if (data.machineryTypeId == 230) {
this.TypeId = false;
this.Typefile = false;
this.warehousing = true;
this.form.lineId = "";
this.form.pointId = "";
this.form.exitType = "0";
this.form.originalName = ""; this.form.originalName = "";
this.form.url = ""; this.form.url = "";
} else { } else {
this.TypeId = false; this.TypeId = false;
// this.Typefile = true; this.Typefile = true;
this.warehousing = false;
this.form.lineId = ""; this.form.lineId = "";
this.form.pointId = ""; this.form.pointId = "";
this.form.exitType = "";
this.form.originalName = "";
this.form.url = "";
} }
this.form.machineryTypeName = data.machineryTypeName; this.form.machineryTypeName = data.machineryTypeName;
var queryParams = { machineryTypeId: data.machineryTypeId };
list(queryParams).then((response) => {
this.machineryList = response.data;
});
},
selectSource(e) {
console.log(e);
this.form.url = e.url;
this.form.originalName = e.originalName;
}, },
// //
cancel() { cancel() {
@ -646,11 +701,12 @@ export default {
processCode: null, processCode: null,
processName: null, processName: null,
isCheck: "N", isCheck: "N",
keyFlag: "N",
orderNum: 1, orderNum: 1,
nextProcessId: null, nextProcessId: null,
nextProcessCode: null, nextProcessCode: null,
nextProcessName: null, nextProcessName: null,
linkType: null, linkType: "FS",
defaultPreTime: 0, defaultPreTime: 0,
defaultSufTime: 0, defaultSufTime: 0,
colorCode: "#00AEF3", colorCode: "#00AEF3",
@ -693,7 +749,13 @@ export default {
this.reset(); this.reset();
if (this.form.machineryTypeId == null) { if (this.form.machineryTypeId == null) {
this.TypeId = false; this.TypeId = false;
// this.Typefile = false; this.Typefile = false;
this.warehousing = false;
this.form.originalName = "";
this.form.url = "";
this.form.exitType = "";
this.form.lineId = "";
this.form.pointId = "";
} }
this.open = true; this.open = true;
this.title = "添加工艺组成"; this.title = "添加工艺组成";
@ -713,16 +775,35 @@ export default {
}); });
if (row.machineryTypeId == null) { if (row.machineryTypeId == null) {
this.TypeId = false; this.TypeId = false;
// this.Typefile = false; this.Typefile = false;
this.warehousing = false;
} else { } else {
if (row.machineryTypeId == 229) { if (row.machineryTypeId == 229) {
this.TypeId = true; this.TypeId = true;
// this.Typefile = false; this.Typefile = false;
this.warehousing = false;
// this.form.originalName = "";
// this.form.url = "";
// this.form.exitType = "";
} else if (row.machineryTypeId == 230) {
this.TypeId = false;
this.Typefile = false;
this.warehousing = true;
// this.form.lineId = "";
// this.form.pointId = "";
} else { } else {
this.TypeId = false; this.TypeId = false;
// this.Typefile = true; this.Typefile = true;
this.warehousing = false;
// this.form.lineId = "";
// this.form.pointId = "";
// this.form.exitType = "";
} }
} }
var queryParams = { machineryTypeId: row.machineryTypeId };
list(queryParams).then((response) => {
this.machineryList = response.data;
});
var name = {}; var name = {};
if (row.originalName != undefined && row.originalName != "") { if (row.originalName != undefined && row.originalName != "") {
this.$set(name, "name", row.originalName); this.$set(name, "name", row.originalName);
@ -734,13 +815,13 @@ export default {
this.$refs["form"].validate((valid) => { this.$refs["form"].validate((valid) => {
if (valid) { if (valid) {
if (this.form.recordId != null) { if (this.form.recordId != null) {
if (this.form.machineryTypeId == 229) { // if (this.form.machineryTypeId == 229) {
this.form.originalName = ""; // this.form.originalName = "";
this.form.url = ""; // this.form.url = "";
} else { // } else {
this.form.lineId = ""; // this.form.lineId = "";
this.form.pointId = ""; // this.form.pointId = "";
} // }
updateRouteprocess(this.form).then((response) => { updateRouteprocess(this.form).then((response) => {
this.$modal.msgSuccess("修改成功"); this.$modal.msgSuccess("修改成功");
this.open = false; this.open = false;

View File

@ -1,6 +1,13 @@
<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="68px"
>
<el-form-item label="工单编码" prop="workorderCode"> <el-form-item label="工单编码" prop="workorderCode">
<el-input <el-input
v-model="queryParams.workorderCode" v-model="queryParams.workorderCode"
@ -60,86 +67,191 @@
/> />
</el-form-item> </el-form-item>
<el-form-item label="需求日期" prop="requestDate"> <el-form-item label="需求日期" prop="requestDate">
<el-date-picker clearable <el-date-picker
clearable
v-model="queryParams.requestDate" v-model="queryParams.requestDate"
type="date" type="date"
value-format="yyyy-MM-dd" value-format="yyyy-MM-dd"
placeholder="请选择需求日期"> placeholder="请选择需求日期"
>
</el-date-picker> </el-date-picker>
</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
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> type="primary"
icon="el-icon-search"
size="mini"
@click="handleQuery"
>搜索</el-button
>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
>重置</el-button
>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-refresh" v-hasPermi="['mes:pro:protask:list']" circle="" @click="getList"></el-button> <el-button
<el-button type="primary" icon="el-icon-edit" v-hasPermi="['mes:pro:protask:edit']" circle="" @click="handleOpenGantt"></el-button> type="primary"
icon="el-icon-refresh"
v-hasPermi="['mes:pro:protask:list']"
circle=""
@click="getList"
></el-button>
<el-button
type="primary"
icon="el-icon-edit"
v-hasPermi="['mes:pro:protask:edit']"
circle=""
@click="handleOpenGantt"
></el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<div class="wrapper"> <div class="wrapper">
<div class="container"> <div class="container">
<GanttChar class="left-container" ref="ganttChar" :tasks="tasks"></GanttChar> <GanttChar
class="left-container"
ref="ganttChar"
:tasks="tasks"
></GanttChar>
</div> </div>
</div> </div>
<el-row :gutter="10" class="mb8" style="margin-top: 10px">
<el-col :span="1.5">
<el-button type="primary" plain size="mini" @click="production"
>批量执行生产</el-button
>
</el-col>
</el-row>
<el-table <el-table
v-loading="loading" v-loading="loading"
:data="workorderList" :data="workorderList"
row-key="workorderId" row-key="workorderId"
default-expand-all default-expand-all
:tree-props="{children: 'children', hasChildren: 'hasChildren'}" :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
@selection-change="handleSelectionChange"
> >
<el-table-column label="工单编码" width="180" prop="workorderCode" > <el-table-column
type="selection"
width="55"
align="center"
:selectable="selectable"
/>
<el-table-column label="工单编码" width="180" prop="workorderCode">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
@click="handleView(scope.row)" @click="handleView(scope.row)"
v-hasPermi="['mes:pro:protask:query']" v-hasPermi="['mes:pro:protask:query']"
>{{scope.row.workorderCode}}</el-button> >{{ scope.row.workorderCode }}</el-button
>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="工单名称" width="200" align="center" prop="workorderName" :show-overflow-tooltip="true"/> <el-table-column
<el-table-column label="工单来源" align="center" prop="orderSource" > label="工单名称"
width="200"
align="center"
prop="workorderName"
:show-overflow-tooltip="true"
/>
<el-table-column label="工单来源" align="center" prop="orderSource">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag :options="dict.type.mes_workorder_sourcetype" :value="scope.row.orderSource"/> <dict-tag
:options="dict.type.mes_workorder_sourcetype"
:value="scope.row.orderSource"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="订单编号" width="140" align="center" prop="sourceCode" /> <el-table-column
<el-table-column label="产品编号" width="120" align="center" prop="productCode" /> label="订单编号"
<el-table-column label="产品名称" width="200" align="center" prop="productName" :show-overflow-tooltip="true"/> width="140"
<el-table-column label="规格型号" align="center" prop="productSpc" :show-overflow-tooltip="true"/> align="center"
prop="sourceCode"
/>
<el-table-column
label="产品编号"
width="120"
align="center"
prop="productCode"
/>
<el-table-column
label="产品名称"
width="200"
align="center"
prop="productName"
:show-overflow-tooltip="true"
/>
<el-table-column
label="规格型号"
align="center"
prop="productSpc"
: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="quantity" /> <el-table-column label="计划数量" align="center" prop="quantity" />
<el-table-column label="调整数量" align="center" prop="quantityChanged" /> <el-table-column label="调整数量" align="center" prop="quantityChanged" />
<el-table-column label="已生产数量" align="center" width="100px" prop="quantityProduced" /> <el-table-column
label="已生产数量"
align="center"
width="100px"
prop="quantityProduced"
/>
<el-table-column label="客户编码" align="center" prop="clientCode" /> <el-table-column label="客户编码" align="center" prop="clientCode" />
<el-table-column label="客户名称" align="center" prop="clientName" :show-overflow-tooltip="true"/> <el-table-column
<el-table-column label="需求日期" align="center" prop="requestDate" width="180"> label="客户名称"
align="center"
prop="clientName"
:show-overflow-tooltip="true"
/>
<el-table-column
label="需求日期"
align="center"
prop="requestDate"
width="180"
>
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.requestDate, '{y}-{m}-{d}') }}</span> <span>{{ parseTime(scope.row.requestDate, "{y}-{m}-{d}") }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="排产状态" align="center" prop="status"> <el-table-column label="排产状态" align="center" prop="status">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag :options="dict.type.mes_order_status" :value="scope.row.status"/> <dict-tag
:options="dict.type.mes_order_status"
:value="scope.row.status"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" width="150px" align="center" class-name="small-padding fixed-width"> <el-table-column
label="操作"
width="150px"
align="center"
class-name="small-padding fixed-width"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
icon="el-icon-edit" icon="el-icon-edit"
v-if="scope.row.status =='CONFIRMED'" v-if="scope.row.status == 'CONFIRMED'"
@click="handleUpdate(scope.row)" @click="handleUpdate(scope.row)"
v-hasPermi="['mes:pro:protask:edit']" v-hasPermi="['mes:pro:protask:edit']"
>排产</el-button> >排产</el-button
>
<el-button
size="mini"
type="text"
v-if="scope.row.status == 'CONFIRMED'"
@click="handleproductione(scope.row)"
>执行生产</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination <pagination
v-show="total>0" v-show="total > 0"
:total="total" :total="total"
:page.sync="queryParams.pageNum" :page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize" :limit.sync="queryParams.pageSize"
@ -169,7 +281,8 @@
v-for="dict in dict.type.mes_workorder_sourcetype" v-for="dict in dict.type.mes_workorder_sourcetype"
:key="dict.value" :key="dict.value"
:label="dict.value" :label="dict.value"
>{{dict.label}}</el-radio> >{{ dict.label }}</el-radio
>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -194,7 +307,7 @@
<el-row> <el-row>
<el-col :span="12"> <el-col :span="12">
<el-form-item label="产品编号" prop="productCode"> <el-form-item label="产品编号" prop="productCode">
<el-input v-model="form.productCode" readonly="readonly" > <el-input v-model="form.productCode" readonly="readonly">
</el-input> </el-input>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -224,11 +337,13 @@
</el-col> </el-col>
<el-col :span="12"> <el-col :span="12">
<el-form-item label="需求日期" prop="requestDate"> <el-form-item label="需求日期" prop="requestDate">
<el-date-picker disabled <el-date-picker
disabled
v-model="form.requestDate" v-model="form.requestDate"
type="date" type="date"
value-format="yyyy-MM-dd" value-format="yyyy-MM-dd"
placeholder="请选择需求日期"> placeholder="请选择需求日期"
>
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -236,7 +351,7 @@
<el-row v-if="form.orderSource == 'ORDER'"> <el-row v-if="form.orderSource == 'ORDER'">
<el-col :span="12"> <el-col :span="12">
<el-form-item label="客户编号" prop="clientCode"> <el-form-item label="客户编号" prop="clientCode">
<el-input v-model="form.clientCode" readonly="readonly" > <el-input v-model="form.clientCode" readonly="readonly">
</el-input> </el-input>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -250,23 +365,65 @@
<el-row> <el-row>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="备注" prop="remark"> <el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" readonly="readonly" /> <el-input
v-model="form.remark"
type="textarea"
readonly="readonly"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
</el-form> </el-form>
<el-steps :active="activeProcess" v-if="form.workorderId !=null" align-center simple> <el-steps
<el-step v-for="(item,index) in processOptions" :active="activeProcess"
:title="item.processName" @click.native="handleStepClick(index)"> v-if="form.workorderId != null"
align-center
simple
>
<el-step
v-for="(item, index) in processOptions"
:title="item.processName"
@click.native="handleStepClick(index)"
>
</el-step> </el-step>
</el-steps> </el-steps>
<el-card v-for=" (item,index) in processOptions " :key="index" v-if="activeProcess == index && form.workorderId !=null"> <el-card
<ProTask :workorderId="form.workorderId" :routeId="item.routeId" :processId="item.processId" :colorCode="item.colorCode" :optType="optType" :recordId="item.recordId"></ProTask> v-for="(item, index) in processOptions"
:key="index"
v-if="activeProcess == index && form.workorderId != null"
>
<ProTask
:workorderId="form.workorderId"
:routeId="item.routeId"
:processId="item.processId"
:colorCode="item.colorCode"
:optType="optType"
:recordId="item.recordId"
></ProTask>
</el-card> </el-card>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
<el-button type="primary" @click="cancel" v-if="optType =='view' || form.status !='PREPARE' ">返回</el-button> <el-button
<el-button type="primary" @click="submitForm" v-if="form.status =='PREPARE' && optType !='view' "> </el-button> type="primary"
<el-button type="success" @click="handleFinish" v-if="form.status =='PREPARE' && optType !='view' && form.workorderId !=null">完成</el-button> @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
type="success"
@click="handleFinish"
v-if="
form.status == 'PREPARE' &&
optType != 'view' &&
form.workorderId != null
"
>完成</el-button
>
<el-button @click="cancel"> </el-button> <el-button @click="cancel"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
@ -274,8 +431,14 @@
</template> </template>
<script> <script>
import { listWorkorder, getWorkorder, delWorkorder, addWorkorder, updateWorkorder } from "@/api/mes/pro/workorder"; import {
import {listGanttTaskList} from "@/api/mes/pro/protask"; listWorkorder,
getWorkorder,
delWorkorder,
addWorkorder,
updateWorkorder,
} from "@/api/mes/pro/workorder";
import { listGanttTaskList } from "@/api/mes/pro/protask";
import { listProductprocess } from "@/api/mes/pro/routeprocess"; import { listProductprocess } from "@/api/mes/pro/routeprocess";
import ProTask from "./proTask.vue"; import ProTask from "./proTask.vue";
import GanttChar from "./ganttx.vue"; import GanttChar from "./ganttx.vue";
@ -284,16 +447,16 @@ import "@riophae/vue-treeselect/dist/vue-treeselect.css";
export default { export default {
name: "Workorder", name: "Workorder",
dicts: ['mes_order_status','mes_workorder_sourcetype'], dicts: ["mes_order_status", "mes_workorder_sourcetype"],
components: { components: {
Treeselect, Treeselect,
ProTask, ProTask,
GanttChar GanttChar,
}, },
data() { data() {
return { return {
// //
autoGenFlag:true, autoGenFlag: true,
optType: undefined, optType: undefined,
activeProcess: 0, activeProcess: 0,
// //
@ -322,7 +485,7 @@ export default {
pageSize: 10, pageSize: 10,
workorderCode: null, workorderCode: null,
workorderName: null, workorderName: null,
workorderType: 'SELF', // workorderType: "SELF", //
orderSource: null, orderSource: null,
sourceCode: null, sourceCode: null,
productId: null, productId: null,
@ -342,9 +505,9 @@ export default {
ancestors: null, ancestors: null,
status: null, status: null,
}, },
tasks:{ tasks: {
data: [], data: [],
links: [] links: [],
}, },
// //
form: {}, form: {},
@ -358,17 +521,21 @@ export default {
/** 查询生产工单列表 */ /** 查询生产工单列表 */
getList() { getList() {
this.loading = true; this.loading = true;
listWorkorder(this.queryParams).then(response => { listWorkorder(this.queryParams).then((response) => {
this.workorderList = this.handleTree(response.rows, "workorderId", "parentId"); this.workorderList = this.handleTree(
response.rows,
"workorderId",
"parentId"
);
this.total = response.total; this.total = response.total;
this.loading = false; this.loading = false;
}); });
}, },
handleOpenGantt(){ handleOpenGantt() {
this.$router.push({ path: '/mes/pro/schedule/ganttedit'}) this.$router.push({ path: "/mes/pro/schedule/ganttedit" });
}, },
getGanttTasks(){ getGanttTasks() {
listGanttTaskList(this.queryParams).then(response =>{ listGanttTaskList(this.queryParams).then((response) => {
this.tasks.data = response.data.data; this.tasks.data = response.data.data;
this.tasks.links = response.data.links; this.tasks.links = response.data.links;
this.$refs.ganttChar.reload(); this.$refs.ganttChar.reload();
@ -376,8 +543,8 @@ export default {
}, },
// //
getProcess(){ getProcess() {
listProductprocess(this.form.productId).then(response =>{ listProductprocess(this.form.productId).then((response) => {
this.processOptions = response.data; this.processOptions = response.data;
}); });
}, },
@ -390,15 +557,23 @@ export default {
return { return {
id: node.workorderId, id: node.workorderId,
label: node.workorderName, label: node.workorderName,
children: node.children children: node.children,
}; };
}, },
/** 查询生产工单下拉树结构 */ /** 查询生产工单下拉树结构 */
getTreeselect() { getTreeselect() {
listWorkorder().then(response => { listWorkorder().then((response) => {
this.workorderOptions = []; this.workorderOptions = [];
const data = { workorderId: 0, workorderName: '顶级节点', children: [] }; const data = {
data.children = this.handleTree(response.data, "workorderId", "parentId"); workorderId: 0,
workorderName: "顶级节点",
children: [],
};
data.children = this.handleTree(
response.data,
"workorderId",
"parentId"
);
this.workorderOptions.push(data); this.workorderOptions.push(data);
}); });
}, },
@ -434,19 +609,19 @@ export default {
createBy: null, createBy: null,
createTime: null, createTime: null,
updateBy: null, updateBy: null,
updateTime: null updateTime: null,
}; };
this.activeProcess =0; this.activeProcess = 0;
this.autoGenFlag = true; this.autoGenFlag = true;
this.resetForm("form"); this.resetForm("form");
}, },
// //
openGanttChart(){ openGanttChart() {
this.$refs.ganttChar.showFlag =true; this.$refs.ganttChar.showFlag = true;
}, },
//Step //Step
handleStepClick(index){ handleStepClick(index) {
this.activeProcess =index; this.activeProcess = index;
}, },
/** 搜索按钮操作 */ /** 搜索按钮操作 */
handleQuery() { handleQuery() {
@ -457,8 +632,24 @@ export default {
this.resetForm("queryForm"); this.resetForm("queryForm");
this.handleQuery(); this.handleQuery();
}, },
//
handleSelectionChange(selection) {
var ids = [];
ids = selection.map((item) => item.routeId);
},
production() {},
handleproductione() {},
selectable(row, index) {
if (row.status == "WORKING") {
return false;
} else {
return true;
}
},
//BOM //BOM
handleSubAdd(row){ handleSubAdd(row) {
this.open = false; this.open = false;
this.reset(); this.reset();
this.getTreeselect(); this.getTreeselect();
@ -472,7 +663,7 @@ export default {
} }
this.open = true; this.open = true;
this.title = "添加生产工单"; this.title = "添加生产工单";
this.optType="add"; this.optType = "add";
}, },
/** 新增按钮操作 */ /** 新增按钮操作 */
handleAdd(row) { handleAdd(row) {
@ -490,17 +681,17 @@ export default {
} }
this.open = true; this.open = true;
this.title = "添加生产工单"; this.title = "添加生产工单";
this.optType="add"; this.optType = "add";
genCode('WORKORDER_CODE').then(response =>{ genCode("WORKORDER_CODE").then((response) => {
this.form.workorderCode = response; this.form.workorderCode = response;
}); });
}, },
// //
handleView(row){ handleView(row) {
this.reset(); this.reset();
this.getTreeselect(); this.getTreeselect();
const workorderId = row.workorderId || this.ids; const workorderId = row.workorderId || this.ids;
getWorkorder(workorderId).then(response => { getWorkorder(workorderId).then((response) => {
this.form = response.data; this.form = response.data;
this.getProcess(); this.getProcess();
this.open = true; this.open = true;
@ -515,27 +706,27 @@ export default {
if (row != null) { if (row != null) {
this.form.parentId = row.workorderId; this.form.parentId = row.workorderId;
} }
getWorkorder(row.workorderId).then(response => { getWorkorder(row.workorderId).then((response) => {
this.form = response.data; this.form = response.data;
this.getProcess(); this.getProcess();
this.open = true; this.open = true;
this.title = "生产排产"; this.title = "生产排产";
this.optType="edit"; this.optType = "edit";
}); });
}, },
/** 提交按钮 */ /** 提交按钮 */
submitForm() { submitForm() {
this.$refs["form"].validate(valid => { this.$refs["form"].validate((valid) => {
if (valid) { if (valid) {
if (this.form.workorderId != null) { if (this.form.workorderId != null) {
updateWorkorder(this.form).then(response => { updateWorkorder(this.form).then((response) => {
this.$modal.msgSuccess("修改成功"); this.$modal.msgSuccess("修改成功");
//this.open = false; //this.open = false;
this.$refs["bomlist"].getList(); this.$refs["bomlist"].getList();
this.getList(); this.getList();
}); });
} else { } else {
addWorkorder(this.form).then(response => { addWorkorder(this.form).then((response) => {
this.$modal.msgSuccess("新增成功"); this.$modal.msgSuccess("新增成功");
//this.open = false; //this.open = false;
this.form.workorderId = response.data; this.form.workorderId = response.data;
@ -547,35 +738,47 @@ export default {
}, },
/** 删除按钮操作 */ /** 删除按钮操作 */
handleDelete(row) { handleDelete(row) {
this.$modal.confirm('是否确认删除生产工单编号为"' + row.workorderId + '"的数据项?').then(function() { this.$modal
.confirm(
'是否确认删除生产工单编号为"' + row.workorderId + '"的数据项?'
)
.then(function () {
return delWorkorder(row.workorderId); return delWorkorder(row.workorderId);
}).then(() => { })
.then(() => {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}).catch(() => {}); })
.catch(() => {});
}, },
handleSelectProduct(){ handleSelectProduct() {
this.$refs.itemSelect.showFlag = true; this.$refs.itemSelect.showFlag = true;
}, },
handleSelectClient(){ handleSelectClient() {
this.$refs.clientSelect.showFlag = true; this.$refs.clientSelect.showFlag = true;
}, },
/** 导出按钮操作 */ /** 导出按钮操作 */
handleExport() { handleExport() {
this.download('mes/pro/workorder/export', { this.download(
...this.queryParams "mes/pro/workorder/export",
}, `workorder_${new Date().getTime()}.xlsx`) {
...this.queryParams,
}, },
handleFinish(){ `workorder_${new Date().getTime()}.xlsx`
);
},
handleFinish() {
let that = this; let that = this;
this.$modal.confirm('是否完成工单编制?【完成后将不能更改】').then(function(){ this.$modal
that.form.status = 'CONFIRMED'; .confirm("是否完成工单编制?【完成后将不能更改】")
.then(function () {
that.form.status = "CONFIRMED";
that.submitForm(); that.submitForm();
}); });
}, },
// //
onItemSelected(obj){ onItemSelected(obj) {
if(obj != undefined && obj != null){ if (obj != undefined && obj != null) {
this.form.productId = obj.itemId; this.form.productId = obj.itemId;
this.form.productCode = obj.itemCode; this.form.productCode = obj.itemCode;
this.form.productName = obj.itemName; this.form.productName = obj.itemName;
@ -584,28 +787,28 @@ export default {
} }
}, },
// //
onClientSelected(obj){ onClientSelected(obj) {
if(obj != undefined && obj != null){ if (obj != undefined && obj != null) {
this.form.clientId = obj.clientId; this.form.clientId = obj.clientId;
this.form.clientCode = obj.clientCode; this.form.clientCode = obj.clientCode;
this.form.clientName = obj.clientName; this.form.clientName = obj.clientName;
} }
}, },
// //
handleAutoGenChange(autoGenFlag){ handleAutoGenChange(autoGenFlag) {
if(autoGenFlag){ if (autoGenFlag) {
genCode('WORKORDER_CODE').then(response =>{ genCode("WORKORDER_CODE").then((response) => {
this.form.workorderCode = response; this.form.workorderCode = response;
}); });
}else{ } else {
this.form.workorderCode = null; this.form.workorderCode = null;
} }
} },
} },
}; };
</script> </script>
<style scoped> <style scoped>
.wrapper{ .wrapper {
height: 400px; height: 400px;
} }
.container { .container {

View File

@ -126,7 +126,7 @@
</el-col> </el-col>
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="8"> <!-- <el-col :span="8">
<el-form-item label="开始时间" prop="startTime"> <el-form-item label="开始时间" prop="startTime">
<el-date-picker clearable <el-date-picker clearable
v-model="form.startTime" v-model="form.startTime"
@ -136,7 +136,7 @@
placeholder="请选择开始生产时间"> placeholder="请选择开始生产时间">
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
</el-col> </el-col> -->
<el-col :span="8"> <el-col :span="8">
<el-form-item label="生产时长" prop="duration"> <el-form-item label="生产时长" prop="duration">
<el-input-number :min="1" :precision="0" :step="1" v-model="form.duration" @change="calculateEndTime" placeholder="请输入生产时长" /> <el-input-number :min="1" :precision="0" :step="1" v-model="form.duration" @change="calculateEndTime" placeholder="请输入生产时长" />

View File

@ -310,7 +310,7 @@
<VendorSelect ref="vendorSelect" @onSelected="onVendorSelected" /> <VendorSelect ref="vendorSelect" @onSelected="onVendorSelected" />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <!-- <el-col :span="8">
<el-form-item label="入库仓库"> <el-form-item label="入库仓库">
<el-cascader <el-cascader
v-model="warehouseInfo" v-model="warehouseInfo"
@ -320,7 +320,7 @@
> >
</el-cascader> </el-cascader>
</el-form-item> </el-form-item>
</el-col> </el-col> -->
<el-col :span="8"> </el-col> <el-col :span="8"> </el-col>
</el-row> </el-row>
<el-row> <el-row>

View File

@ -121,7 +121,7 @@
</el-col> </el-col>
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="8"> <!-- <el-col :span="8">
<el-form-item label="入库仓库" prop="warehouseId"> <el-form-item label="入库仓库" prop="warehouseId">
<el-cascader v-model="warehouseInfo" <el-cascader v-model="warehouseInfo"
:options="warehouseOptions" :options="warehouseOptions"
@ -130,7 +130,7 @@
> >
</el-cascader> </el-cascader>
</el-form-item> </el-form-item>
</el-col> </el-col> -->
<el-col :span="8"> <el-col :span="8">
<el-form-item label="是否检验"> <el-form-item label="是否检验">
<el-radio-group v-model="form.iqcCheck" disabled v-if="optType=='view'"> <el-radio-group v-model="form.iqcCheck" disabled v-if="optType=='view'">

View File

@ -9,7 +9,8 @@
size="mini" size="mini"
@click="handleAdd" @click="handleAdd"
v-hasPermi="['mes:wm:productsalse:add']" v-hasPermi="['mes:wm:productsalse:add']"
>新增</el-button> >新增</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
@ -20,7 +21,8 @@
:disabled="single" :disabled="single"
@click="handleUpdate" @click="handleUpdate"
v-hasPermi="['mes:wm:productsalse:edit']" v-hasPermi="['mes:wm:productsalse:edit']"
>修改</el-button> >修改</el-button
>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
@ -31,30 +33,71 @@
:disabled="multiple" :disabled="multiple"
@click="handleDelete" @click="handleDelete"
v-hasPermi="['mes:wm:productsalse:remove']" v-hasPermi="['mes:wm:productsalse:remove']"
>删除</el-button> >删除</el-button
>
</el-col> </el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> <right-toolbar
:showSearch.sync="showSearch"
@queryTable="getList"
></right-toolbar>
</el-row> </el-row>
<el-table v-loading="loading" :data="productsalselineList" @selection-change="handleSelectionChange"> <el-table
v-loading="loading"
:data="productsalselineList"
@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="产品编码" width="120px" align="center" prop="itemCode" /> <el-table-column
<el-table-column label="产品名称" width="150px" align="center" prop="itemName" :show-overflow-tooltip="true"/> label="产品编码"
<el-table-column label="规格型号" align="center" prop="specification" :show-overflow-tooltip="true"/> width="120px"
align="center"
prop="itemCode"
/>
<el-table-column
label="产品名称"
width="150px"
align="center"
prop="itemName"
:show-overflow-tooltip="true"
/>
<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="quantitySalse" /> <el-table-column label="出库数量" align="center" prop="quantitySalse" />
<el-table-column label="批次号" width="120px" align="center" prop="batchCode" /> <el-table-column
label="批次号"
width="120px"
align="center"
prop="batchCode"
/>
<el-table-column label="仓库名称" align="center" prop="warehouseName" /> <el-table-column label="仓库名称" align="center" prop="warehouseName" />
<el-table-column label="库区名称" align="center" prop="locationName" /> <el-table-column label="库区名称" align="center" prop="locationName" />
<el-table-column label="库位名称" align="center" prop="areaName" /> <el-table-column label="库位名称" align="center" prop="areaName" />
<el-table-column label="是否检验" align="center" prop="iqcCheck"> <el-table-column label="是否检验" align="center" prop="iqcCheck">
<template slot-scope="scope"> <template slot-scope="scope">
<dict-tag :options="dict.type.sys_yes_no" :value="scope.row.oqcCheck"/> <dict-tag
:options="dict.type.sys_yes_no"
:value="scope.row.oqcCheck"
/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="检验单编号" width="120" align="center" prop="oqcCode" /> <el-table-column
label="检验单编号"
width="120"
align="center"
prop="oqcCode"
/>
<el-table-column label="备注" align="center" prop="remark" /> <el-table-column label="备注" align="center" prop="remark" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width"> <el-table-column
label="操作"
align="center"
class-name="small-padding fixed-width"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
size="mini" size="mini"
@ -63,13 +106,14 @@
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
v-if="optType != 'view'" v-if="optType != 'view'"
v-hasPermi="['mes:wm:productsalse:remove']" v-hasPermi="['mes:wm:productsalse:remove']"
>删除</el-button> >删除</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination <pagination
v-show="total>0" v-show="total > 0"
:total="total" :total="total"
:page.sync="queryParams.pageNum" :page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize" :limit.sync="queryParams.pageSize"
@ -82,15 +126,25 @@
<el-row> <el-row>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="产品编码" prop="itemCode"> <el-form-item label="产品编码" prop="itemCode">
<el-input v-model="form.itemCode" placeholder="请选择库存物资" > <el-input v-model="form.itemCode" placeholder="请选择库存物资">
<el-button slot="append" @click="handleSelectStock" icon="el-icon-search"></el-button> <el-button
slot="append"
@click="handleSelectStock"
icon="el-icon-search"
></el-button>
</el-input> </el-input>
</el-form-item> </el-form-item>
<StockSelect ref="stockSelect" @onSelected="onStockSelected"></StockSelect> <StockSelect
ref="stockSelect"
@onSelected="onStockSelected"
></StockSelect>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="产品名称" prop="itemName"> <el-form-item label="产品名称" prop="itemName">
<el-input v-model="form.itemName" placeholder="请输入产品物料名称" /> <el-input
v-model="form.itemName"
placeholder="请输入产品物料名称"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
@ -102,7 +156,11 @@
<el-row> <el-row>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="规格型号" prop="specification"> <el-form-item label="规格型号" prop="specification">
<el-input v-model="form.specification" type="textarea" placeholder="请输入内容" /> <el-input
v-model="form.specification"
type="textarea"
placeholder="请输入内容"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
@ -126,29 +184,39 @@
<el-row> <el-row>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="批次号" prop="batchCode"> <el-form-item label="批次号" prop="batchCode">
<el-input v-model="form.batchCode"/> <el-input v-model="form.batchCode" />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="生产工单" prop="workorderCode"> <el-form-item label="生产工单" prop="workorderCode">
<el-input v-model="form.workorderCode"/> <el-input v-model="form.workorderCode" />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="出库数量" prop="quantitySalse"> <el-form-item label="出库数量" prop="quantitySalse">
<el-input :max="form.quantityMax" :min="0" v-model="form.quantitySalse" placeholder="请输入出库数量" /> <el-input
:max="form.quantityMax"
:min="0"
v-model="form.quantitySalse"
placeholder="请输入出库数量"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="8"> <el-col :span="8">
<el-form-item label="是否检验"> <el-form-item label="是否检验">
<el-radio-group v-model="form.oqcCheck" disabled v-if="optType=='view'"> <el-radio-group
v-model="form.oqcCheck"
disabled
v-if="optType == 'view'"
>
<el-radio <el-radio
v-for="dict in dict.type.sys_yes_no" v-for="dict in dict.type.sys_yes_no"
:key="dict.value" :key="dict.value"
:label="dict.value" :label="dict.value"
>{{dict.label}}</el-radio> >{{ dict.label }}</el-radio
>
</el-radio-group> </el-radio-group>
<el-radio-group v-model="form.oqcCheck" v-else> <el-radio-group v-model="form.oqcCheck" v-else>
@ -156,23 +224,39 @@
v-for="dict in dict.type.sys_yes_no" v-for="dict in dict.type.sys_yes_no"
:key="dict.value" :key="dict.value"
:label="dict.value" :label="dict.value"
>{{dict.label}}</el-radio> >{{ dict.label }}</el-radio
>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="8"> <el-col :span="8">
<el-form-item v-if="form.oqcCheck == 'Y'" label="出货检验单" prop="oqcCode"> <el-form-item
<el-input v-model="form.oqcCode" placeholder="请输入出货检验单" > v-if="form.oqcCheck == 'Y'"
<el-button slot="append" @click="handleSelectOqc" icon="el-icon-search"></el-button> label="出货检验单"
prop="oqcCode"
>
<el-input v-model="form.oqcCode" placeholder="请输入出货检验单">
<el-button
slot="append"
@click="handleSelectOqc"
icon="el-icon-search"
></el-button>
</el-input> </el-input>
</el-form-item> </el-form-item>
<OqcSelectSingle ref="oqcSelect" @onSelected="onOqcSelected"></OqcSelectSingle> <OqcSelectSingle
ref="oqcSelect"
@onSelected="onOqcSelected"
></OqcSelectSingle>
</el-col> </el-col>
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="备注" prop="remark"> <el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" /> <el-input
v-model="form.remark"
type="textarea"
placeholder="请输入内容"
/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
@ -186,30 +270,36 @@
</template> </template>
<script> <script>
import { listProductsalseline, getProductsalseline, delProductsalseline, addProductsalseline, updateProductsalseline } from "@/api/mes/wm/productsalseline"; import {
import StockSelect from "@/components/stockSelect/single.vue" listProductsalseline,
import OqcSelectSingle from "@/components/oqcSelect/single.vue" getProductsalseline,
delProductsalseline,
addProductsalseline,
updateProductsalseline,
} from "@/api/mes/wm/productsalseline";
import StockSelect from "@/components/stockSelect/single.vue";
import OqcSelectSingle from "@/components/oqcSelect/single.vue";
export default { export default {
name: "Productsalseline", name: "Productsalseline",
dicts: ['sys_yes_no'], dicts: ["sys_yes_no"],
components: {StockSelect,OqcSelectSingle}, components: { StockSelect, OqcSelectSingle },
props: { props: {
salseId: null, salseId: null,
optType: null, optType: null,
warehouseId: null, warehouseId: null,
locationId: null, locationId: null,
areaId: null areaId: null,
}, },
data() { data() {
return { return {
// //
loading: true, loading: true,
warehouseInfo:[], warehouseInfo: [],
warehouseOptions:[], warehouseOptions: [],
warehouseProps:{ warehouseProps: {
multiple: false, multiple: false,
value: 'pId', value: "pId",
label: 'pName', label: "pName",
}, },
// //
ids: [], ids: [],
@ -250,20 +340,21 @@ export default {
areaCode: null, areaCode: null,
areaName: null, areaName: null,
}, },
quantitySalse: "",
// //
form: {}, form: {},
// //
rules: { rules: {
itemCode: [ itemCode: [
{ required: true, message: "出库物资不能为空", trigger: "blur" } { required: true, message: "出库物资不能为空", trigger: "blur" },
], ],
warehouseInfo: [ warehouseInfo: [
{ required: true, message: "仓库不能为空", trigger: "blur" } { required: true, message: "仓库不能为空", trigger: "blur" },
], ],
quantitySalse: [ quantitySalse: [
{ required: true, message: "出库数量不能为空", trigger: "blur" } { required: true, message: "出库数量不能为空", trigger: "blur" },
], ],
} },
}; };
}, },
created() { created() {
@ -273,7 +364,7 @@ export default {
/** 查询产品销售出库行列表 */ /** 查询产品销售出库行列表 */
getList() { getList() {
this.loading = true; this.loading = true;
listProductsalseline(this.queryParams).then(response => { listProductsalseline(this.queryParams).then((response) => {
this.productsalselineList = response.rows; this.productsalselineList = response.rows;
this.total = response.total; this.total = response.total;
this.loading = false; this.loading = false;
@ -308,7 +399,7 @@ export default {
areaId: this.areaId, areaId: this.areaId,
areaCode: null, areaCode: null,
areaName: null, areaName: null,
oqcCheck: 'N', oqcCheck: "N",
oqcId: null, oqcId: null,
oqcCode: null, oqcCode: null,
remark: null, remark: null,
@ -319,7 +410,7 @@ export default {
createBy: null, createBy: null,
createTime: null, createTime: null,
updateBy: null, updateBy: null,
updateTime: null updateTime: null,
}; };
this.resetForm("form"); this.resetForm("form");
}, },
@ -335,9 +426,9 @@ export default {
}, },
// //
handleSelectionChange(selection) { handleSelectionChange(selection) {
this.ids = selection.map(item => item.lineId) this.ids = selection.map((item) => item.lineId);
this.single = selection.length!==1 this.single = selection.length !== 1;
this.multiple = !selection.length this.multiple = !selection.length;
}, },
/** 新增按钮操作 */ /** 新增按钮操作 */
handleAdd() { handleAdd() {
@ -348,8 +439,8 @@ export default {
/** 修改按钮操作 */ /** 修改按钮操作 */
handleUpdate(row) { handleUpdate(row) {
this.reset(); this.reset();
const lineId = row.lineId || this.ids const lineId = row.lineId || this.ids;
getProductsalseline(lineId).then(response => { getProductsalseline(lineId).then((response) => {
this.form = response.data; this.form = response.data;
this.open = true; this.open = true;
this.title = "修改产品销售出库行"; this.title = "修改产品销售出库行";
@ -357,16 +448,22 @@ export default {
}, },
/** 提交按钮 */ /** 提交按钮 */
submitForm() { submitForm() {
this.$refs["form"].validate(valid => { this.$refs["form"].validate((valid) => {
if (valid) { if (valid) {
if (this.form.lineId != null) { if (this.form.lineId != null) {
updateProductsalseline(this.form).then(response => { updateProductsalseline(this.form).then((response) => {
this.$modal.msgSuccess("修改成功"); this.$modal.msgSuccess("修改成功");
this.open = false; this.open = false;
this.getList(); this.getList();
}); });
} else { } else {
addProductsalseline(this.form).then(response => { if (this.form.quantitySalse > this.quantitySalse) {
this.$message({
message: "数量不足",
type: "warning",
});
}
addProductsalseline(this.form).then((response) => {
this.$modal.msgSuccess("新增成功"); this.$modal.msgSuccess("新增成功");
this.open = false; this.open = false;
this.getList(); this.getList();
@ -378,27 +475,34 @@ export default {
/** 删除按钮操作 */ /** 删除按钮操作 */
handleDelete(row) { handleDelete(row) {
const lineIds = row.lineId || this.ids; const lineIds = row.lineId || this.ids;
this.$modal.confirm('是否确认删除产品销售出库行编号为"' + lineIds + '"的数据项?').then(function() { this.$modal
.confirm('是否确认删除产品销售出库行编号为"' + lineIds + '"的数据项?')
.then(function () {
return delProductsalseline(lineIds); return delProductsalseline(lineIds);
}).then(() => { })
.then(() => {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}).catch(() => {}); })
.catch(() => {});
}, },
/** 导出按钮操作 */ /** 导出按钮操作 */
handleExport() { handleExport() {
this.download('wm/productsalseline/export', { this.download(
...this.queryParams "wm/productsalseline/export",
}, `productsalseline_${new Date().getTime()}.xlsx`) {
...this.queryParams,
}, },
handleSelectStock(){ `productsalseline_${new Date().getTime()}.xlsx`
);
},
handleSelectStock() {
this.$refs.stockSelect.showFlag = true; this.$refs.stockSelect.showFlag = true;
this.$refs.stockSelect.getList(); this.$refs.stockSelect.getList();
}, },
// //
onStockSelected(obj){ onStockSelected(obj) {
if(obj != undefined && obj != null){ if (obj != undefined && obj != null) {
debugger;
this.form.materialStockId = obj.materialStockId; this.form.materialStockId = obj.materialStockId;
this.form.itemId = obj.itemId; this.form.itemId = obj.itemId;
this.form.itemCode = obj.itemCode; this.form.itemCode = obj.itemCode;
@ -419,19 +523,20 @@ export default {
this.form.areaName = obj.areaName; this.form.areaName = obj.areaName;
this.form.quantitySalse = obj.quantityOnhand; this.form.quantitySalse = obj.quantityOnhand;
this.form.quantityMax = obj.quantityOnhand; this.form.quantityMax = obj.quantityOnhand;
this.quantitySalse = obj.quantityOnhand;
} }
}, },
//OQC //OQC
handleSelectOqc(){ handleSelectOqc() {
this.$refs.oqcSelect.showFlag = true; this.$refs.oqcSelect.showFlag = true;
}, },
//OQC //OQC
onOqcSelected(obj){ onOqcSelected(obj) {
if(obj != undefined && obj != null){ if (obj != undefined && obj != null) {
this.form.oqcId = obj.oqcId; this.form.oqcId = obj.oqcId;
this.form.oqcCode = obj.oqcCode; this.form.oqcCode = obj.oqcCode;
} }
}, },
} },
}; };
</script> </script>