设备维修单

This commit is contained in:
JinLu.Yin 2022-08-07 18:43:25 +08:00
parent 1c22b6a114
commit 05add0259e

View File

@ -1,6 +1,6 @@
<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="100px">
<el-form-item label="维修单编号" prop="repairCode"> <el-form-item label="维修单编号" prop="repairCode">
<el-input <el-input
v-model="queryParams.repairCode" v-model="queryParams.repairCode"
@ -17,14 +17,7 @@
@keyup.enter.native="handleQuery" @keyup.enter.native="handleQuery"
/> />
</el-form-item> </el-form-item>
<el-form-item label="设备ID" prop="machineryId">
<el-input
v-model="queryParams.machineryId"
placeholder="请输入设备ID"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="设备编码" prop="machineryCode"> <el-form-item label="设备编码" prop="machineryCode">
<el-input <el-input
v-model="queryParams.machineryCode" v-model="queryParams.machineryCode"
@ -41,54 +34,6 @@
@keyup.enter.native="handleQuery" @keyup.enter.native="handleQuery"
/> />
</el-form-item> </el-form-item>
<el-form-item label="品牌" prop="machineryBrand">
<el-input
v-model="queryParams.machineryBrand"
placeholder="请输入品牌"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="规格型号" prop="machinerySpec">
<el-input
v-model="queryParams.machinerySpec"
placeholder="请输入规格型号"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="设备类型ID" prop="machineryTypeId">
<el-input
v-model="queryParams.machineryTypeId"
placeholder="请输入设备类型ID"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="报修日期" prop="requireDate">
<el-date-picker clearable
v-model="queryParams.requireDate"
type="date"
value-format="yyyy-MM-dd"
placeholder="请选择报修日期">
</el-date-picker>
</el-form-item>
<el-form-item label="维修完成日期" prop="finishDate">
<el-date-picker clearable
v-model="queryParams.finishDate"
type="date"
value-format="yyyy-MM-dd"
placeholder="请选择维修完成日期">
</el-date-picker>
</el-form-item>
<el-form-item label="验收日期" prop="confirmDate">
<el-date-picker clearable
v-model="queryParams.confirmDate"
type="date"
value-format="yyyy-MM-dd"
placeholder="请选择验收日期">
</el-date-picker>
</el-form-item>
<el-form-item label="维修结果" prop="repairResult"> <el-form-item label="维修结果" prop="repairResult">
<el-select v-model="queryParams.repairResult" placeholder="请选择维修结果" clearable> <el-select v-model="queryParams.repairResult" placeholder="请选择维修结果" clearable>
<el-option <el-option
@ -99,22 +44,6 @@
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="维修人员" prop="acceptedBy">
<el-input
v-model="queryParams.acceptedBy"
placeholder="请输入维修人员"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="验收人员" prop="confirmBy">
<el-input
v-model="queryParams.confirmBy"
placeholder="请输入验收人员"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="单据状态" prop="status"> <el-form-item label="单据状态" prop="status">
<el-select v-model="queryParams.status" placeholder="请选择单据状态" clearable> <el-select v-model="queryParams.status" placeholder="请选择单据状态" clearable>
<el-option <el-option
@ -139,7 +68,7 @@
icon="el-icon-plus" icon="el-icon-plus"
size="mini" size="mini"
@click="handleAdd" @click="handleAdd"
v-hasPermi="['dv:repair:add']" v-hasPermi="['mes:dv:repair:add']"
>新增</el-button> >新增</el-button>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
@ -150,7 +79,7 @@
size="mini" size="mini"
:disabled="single" :disabled="single"
@click="handleUpdate" @click="handleUpdate"
v-hasPermi="['dv:repair:edit']" v-hasPermi="['mes:dv:repair:edit']"
>修改</el-button> >修改</el-button>
</el-col> </el-col>
<el-col :span="1.5"> <el-col :span="1.5">
@ -161,44 +90,29 @@
size="mini" size="mini"
:disabled="multiple" :disabled="multiple"
@click="handleDelete" @click="handleDelete"
v-hasPermi="['dv:repair:remove']" v-hasPermi="['mes:dv:repair:remove']"
>删除</el-button> >删除</el-button>
</el-col> </el-col>
<el-col :span="1.5">
<el-button
type="warning"
plain
icon="el-icon-download"
size="mini"
@click="handleExport"
v-hasPermi="['dv:repair:export']"
>导出</el-button>
</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="repairList" @selection-change="handleSelectionChange"> <el-table v-loading="loading" :data="repairList" @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="维修单ID" align="center" prop="repairId" /> <el-table-column label="维修单编号" width="100px" align="center" prop="repairCode" />
<el-table-column label="维修单编号" align="center" prop="repairCode" /> <el-table-column label="维修单名称" width="150px" align="center" prop="repairName" :show-overflow-tooltip="true"/>
<el-table-column label="维修单名称" align="center" prop="repairName" />
<el-table-column label="设备ID" align="center" prop="machineryId" />
<el-table-column label="设备编码" align="center" prop="machineryCode" /> <el-table-column label="设备编码" align="center" prop="machineryCode" />
<el-table-column label="设备名称" align="center" prop="machineryName" /> <el-table-column label="设备名称" align="center" prop="machineryName" />
<el-table-column label="品牌" align="center" prop="machineryBrand" /> <el-table-column label="报修日期" align="center" prop="requireDate" width="120">
<el-table-column label="规格型号" align="center" prop="machinerySpec" />
<el-table-column label="设备类型ID" align="center" prop="machineryTypeId" />
<el-table-column label="报修日期" align="center" prop="requireDate" width="180">
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.requireDate, '{y}-{m}-{d}') }}</span> <span>{{ parseTime(scope.row.requireDate, '{y}-{m}-{d}') }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="维修完成日期" align="center" prop="finishDate" width="180"> <el-table-column label="维修完成日期" align="center" prop="finishDate" width="120">
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.finishDate, '{y}-{m}-{d}') }}</span> <span>{{ parseTime(scope.row.finishDate, '{y}-{m}-{d}') }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="验收日期" align="center" prop="confirmDate" width="180"> <el-table-column label="验收日期" align="center" prop="confirmDate" width="120">
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.confirmDate, '{y}-{m}-{d}') }}</span> <span>{{ parseTime(scope.row.confirmDate, '{y}-{m}-{d}') }}</span>
</template> </template>
@ -215,7 +129,6 @@
<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="备注" 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
@ -223,14 +136,14 @@
type="text" type="text"
icon="el-icon-edit" icon="el-icon-edit"
@click="handleUpdate(scope.row)" @click="handleUpdate(scope.row)"
v-hasPermi="['dv:repair:edit']" v-hasPermi="['mes:dv:repair: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="['dv:repair:remove']" v-hasPermi="['mes:dv:repair:remove']"
>删除</el-button> >删除</el-button>
</template> </template>
</el-table-column> </el-table-column>
@ -245,57 +158,84 @@
/> />
<!-- 添加或修改设备维修单对话框 --> <!-- 添加或修改设备维修单对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body> <el-dialog :title="title" :visible.sync="open" width="960px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="80px"> <el-form ref="form" :model="form" :rules="rules" label-width="120px">
<el-row>
<el-col :span="8">
<el-form-item label="维修单编号" prop="repairCode"> <el-form-item label="维修单编号" prop="repairCode">
<el-input v-model="form.repairCode" placeholder="请输入维修单编号" /> <el-input v-model="form.repairCode" placeholder="请输入维修单编号" />
</el-form-item> </el-form-item>
</el-col>
<el-col :span="4">
<el-form-item label-width="80">
<el-switch v-model="autoGenFlag"
active-color="#13ce66"
active-text="自动生成"
@change="handleAutoGenChange(autoGenFlag)" v-if="optType != 'view'">
</el-switch>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="维修单名称" prop="repairName"> <el-form-item label="维修单名称" prop="repairName">
<el-input v-model="form.repairName" placeholder="请输入维修单名称" /> <el-input v-model="form.repairName" placeholder="请输入维修单名称" />
</el-form-item> </el-form-item>
<el-form-item label="设备ID" prop="machineryId"> </el-col>
<el-input v-model="form.machineryId" placeholder="请输入设备ID" /> </el-row>
</el-form-item> <el-row>
<el-form-item label="设备编码" prop="machineryCode"> <el-col :span="8">
<el-input v-model="form.machineryCode" placeholder="请输入设备编码" /> <el-form-item label="设备编号" prop="machineryCode">
<el-input v-model="form.machineryCode" placeholder="请输入设备编号" />
</el-form-item> </el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="设备名称" prop="machineryName"> <el-form-item label="设备名称" prop="machineryName">
<el-input v-model="form.machineryName" placeholder="请输入设备名称" /> <el-input v-model="form.machineryName" placeholder="请输入设备名称" />
</el-form-item> </el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="品牌" prop="machineryBrand"> <el-form-item label="品牌" prop="machineryBrand">
<el-input v-model="form.machineryBrand" placeholder="请输入品牌" /> <el-input v-model="form.machineryBrand" placeholder="请输入品牌" />
</el-form-item> </el-form-item>
<el-form-item label="规格型号" prop="machinerySpec"> </el-col>
<el-input v-model="form.machinerySpec" placeholder="请输入规格型号" /> </el-row>
</el-form-item> <el-row>
<el-form-item label="设备类型ID" prop="machineryTypeId"> <el-col :span="8">
<el-input v-model="form.machineryTypeId" placeholder="请输入设备类型ID" />
</el-form-item>
<el-form-item label="报修日期" prop="requireDate"> <el-form-item label="报修日期" prop="requireDate">
<el-date-picker clearable <el-date-picker clearable
v-model="form.requireDate" v-model="form.requireDate"
style="width: 187px"
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 label="维修完成日期" prop="finishDate"> </el-col>
<el-col :span="8">
<el-form-item label="维修完成日期" v-if="form.status =='APPROVING' || form.status=='FINISHED' || form.status=='CONFIRMED' " prop="finishDate">
<el-date-picker clearable <el-date-picker clearable
v-model="form.finishDate" v-model="form.finishDate"
style="width: 187px"
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 label="验收日期" prop="confirmDate"> </el-col>
<el-col :span="8">
<el-form-item label="验收日期" v-if="form.status=='FINISHED' || form.status=='CONFIRMED' " prop="confirmDate">
<el-date-picker clearable <el-date-picker clearable
v-model="form.confirmDate" v-model="form.confirmDate"
style="width: 187px"
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 label="维修结果"> </el-col>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="维修结果" v-if="form.status =='APPROVING' || form.status=='FINISHED' || form.status=='CONFIRMED' ">
<el-radio-group v-model="form.repairResult"> <el-radio-group v-model="form.repairResult">
<el-radio <el-radio
v-for="dict in dict.type.mes_repair_result" v-for="dict in dict.type.mes_repair_result"
@ -304,28 +244,31 @@
>{{dict.label}}</el-radio> >{{dict.label}}</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="维修人员" prop="acceptedBy"> </el-col>
<el-input v-model="form.acceptedBy" placeholder="请输入维修人员" /> <el-col :span="8">
<el-form-item label="维修人员" prop="acceptedName" v-if="form.status =='APPROVING' || form.status=='FINISHED' || form.status=='CONFIRMED' ">
<el-input v-model="form.acceptedName" readonly="readonly"/>
</el-form-item> </el-form-item>
<el-form-item label="验收人员" prop="confirmBy"> </el-col>
<el-input v-model="form.confirmBy" placeholder="请输入验收人员" /> <el-col :span="8">
</el-form-item> <el-form-item label="验收人员" prop="confirmName" v-if="form.status=='FINISHED' || form.status=='CONFIRMED' ">
<el-form-item label="单据状态" prop="status"> <el-input v-model="form.confirmName" readonly="readonly"/>
<el-select v-model="form.status" placeholder="请选择单据状态">
<el-option
v-for="dict in dict.type.mes_order_status"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select>
</el-form-item> </el-form-item>
</el-col>
</el-row>
<el-row>
<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-row>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button> <el-button type="primary" v-if="form.status =='PREPARE' && optType !='view'" @click="submitForm"> </el-button>
<el-button type="primary" v-if="form.status == 'APPROVING' && optType !='view'" @click="finish">完成维修</el-button>
<el-button type="success" v-if="form.status == 'FINISHED' && optType !='view'" @click="confirm">验收通过</el-button>
<el-button type="danger" v-if="form.status == 'FINISHED' && optType !='view'" @click="unconfirm">不通过</el-button>
<el-button @click="cancel"> </el-button> <el-button @click="cancel"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
@ -340,6 +283,8 @@ export default {
dicts: ['mes_repair_result', 'mes_order_status'], dicts: ['mes_repair_result', 'mes_order_status'],
data() { data() {
return { return {
autoGenFlag:false,
optType: undefined,
// //
loading: true, loading: true,
// //
@ -433,10 +378,10 @@ export default {
requireDate: null, requireDate: null,
finishDate: null, finishDate: null,
confirmDate: null, confirmDate: null,
repairResult: "0", repairResult: "",
acceptedBy: null, acceptedBy: null,
confirmBy: null, confirmBy: null,
status: null, status: 'PREPARE',
remark: null, remark: null,
attr1: null, attr1: null,
attr2: null, attr2: null,
@ -516,6 +461,16 @@ export default {
this.download('dv/repair/export', { this.download('dv/repair/export', {
...this.queryParams ...this.queryParams
}, `repair_${new Date().getTime()}.xlsx`) }, `repair_${new Date().getTime()}.xlsx`)
},
//
handleAutoGenChange(autoGenFlag){
if(autoGenFlag){
genCode('REPAIR_CODE').then(response =>{
this.form.repairCode = response;
});
}else{
this.form.repairCode = null;
}
} }
} }
}; };