维修工单及项目生命周期记录完善

This commit is contained in:
xiaofajia 2024-10-22 23:43:26 +08:00
parent 742f1bde16
commit dc3153b1af
3 changed files with 101 additions and 50 deletions

View File

@ -288,7 +288,6 @@ export default {
remark: item.remark
}
})]
console.log(this.formData)
await auditTicketWares(this.formData)
this.dialogVisible = false
this.$modal.msgSuccess("审核成功")

View File

@ -1,12 +1,30 @@
<template>
<div class="app-container">
<el-dialog title="流程记录" :visible.sync="dialogVisible" width="60%" v-dialogDrag append-to-body>
<el-form :model="formData" ref="formRef" :rules="formRules" :loading="formLoading" :inline="true" label-width="15rem">
<el-row :gutter="1">
<el-col :span="24">
<span class="notice">{{
projectList.length === 0
? (this.formData.recordType === 'kssg'
? "没有项目可以施工"
: (this.formData.recordType === 'sgz')
? "没有项目在施工中"
: (this.formData.recordType === 'sgwczj'
? "没有项目可以完成"
: ''
)
)
: ''
}}</span>
</el-col>
</el-row>
<el-form :model="formData" ref="formRef" :rules="formRules" :loading="formLoading" :inline="true"
label-width="15rem">
<el-row :gutter="1">
<el-col :span="24">
<el-form-item v-if="formData.recordType !== 'zj'" label="维修项目" prop="item.id">
<el-select style="width: 20rem" v-model="formData.item.id" >
<el-option v-for="item in projectList" :key="item.id" :label="item.itemName" :value="item.id" />
<el-select style="width: 20rem" v-model="formData.item.id">
<el-option v-for="item in projectList" :key="item.id" :label="item.itemName" :value="item.id"/>
</el-select>
</el-form-item>
</el-col>
@ -14,30 +32,41 @@
<el-row :gutter="1">
<el-col :span="24">
<el-form-item label="描述" prop="remark">
<el-input style="width: 30rem" type="textarea" v-model="formData.remark" :autosize="{ minRows: 4, maxRows: 8}"/>
<el-input style="width: 30rem" type="textarea" v-model="formData.remark"
:autosize="{ minRows: 4, maxRows: 8}"/>
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="1">
<el-col :span="24">
<el-form-item label="附件" prop="image">
<!-- <FileUpload v-model="formData.image" />-->
<ImageUpload v-model="formData.image" />
<!-- <FileUpload v-model="formData.image" />-->
<ImageUpload v-model="formData.image"/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button v-if="formData.recordType !== 'sgwczj'" type="primary" @click="doUpdate"> </el-button>
<el-button v-if="formData.recordType === 'sgwczj'" type="primary" @click="doUpdate">部分完成</el-button>
<el-button v-if="formData.recordType === 'sgwczj'" type="success" @click="doFinish">
{{isNext ? "整体完成并指派下一项目" : (isEndCheck ? "整体完成并移交总检" : "整体完成")}}
<el-button v-if="formData.recordType !== 'sgwczj' && projectList.length > 0" type="primary" @click="doUpdate(null)">
</el-button>
<el-button @click="dialogVisible = false"> </el-button>
<el-button v-if="formData.recordType === 'sgwczj' && projectList.length !== 0" type="primary" @click="doUpdate(null)">
部分完成
</el-button>
<el-button v-if="formData.recordType === 'sgwczj' && projectList.length !== 0" type="primary" @click="doFinish">
完成并移交下一班组
</el-button>
<el-button v-if="formData.recordType === 'sgwczj' && !isNext && projectList.length !== 0" type="primary"
@click="doFinish">
{{ isEndCheck ? "完成并移交总检" : "完成工单" }}
</el-button>
<!-- <el-button v-if="formData.recordType === 'sgwczj'" type="success" @click="doFinish">-->
<!-- {{isNext ? "整体完成并指派下一项目" : (isEndCheck ? "整体完成并移交总检" : "整体完成")}}-->
<!-- </el-button>-->
</div>
</el-dialog>
<UpdateRepair ref="updateRepair" @success="doUpdate" />
<UpdateRepair ref="updateRepair" @success="doUpdate"/>
</div>
</template>
@ -49,16 +78,16 @@ import UpdateRepair from "@/views/repair/tickets/form/UpdateRepair.vue";
export default {
name: "UpdateRecord",
components: {UpdateRepair},
data(){
data() {
return {
dialogVisible: false,
formData:{
formData: {
//
id: null,
ticketsWorkStatus: null,
remark: null,
//
item:{
item: {
id: null,
itemStatus: null,
},
@ -66,8 +95,8 @@ export default {
image: null,
recordType: null,
},
formRules:{
'item.id':[{required: true, message: "维修项目不能为空", trigger: 'blur'}]
formRules: {
'item.id': [{required: true, message: "维修项目不能为空", trigger: 'blur'}]
},
formLoading: false,
projectList: [],
@ -78,104 +107,127 @@ export default {
clickRow: null
}
},
methods:{
init(){
methods: {
init() {
this.formData = {
//
id: null,
ticketsWorkStatus: null,
remark: null,
//
item:{
ticketsWorkStatus: null,
remark: null,
//
item: {
id: null,
itemStatus: null,
itemStatus: null,
},
//
image: null,
recordType: null,
recordType: null,
}
this.projectList = []
this.clickRow = null
},
async open(row){
async open(row) {
this.init()
this.clickRow = row
//
this.isEndCheck = row.endCheck === '1'
this.formData.id = row.id
this.formData.recordType = row.clickType
await this.listProject(row.id)
this.dialogVisible = true
},
async listProject(ticketId){
async listProject(ticketId) {
try {
this.formLoading = true
const res = await getProjectList(ticketId)
this.projectList = res.data
this.formData.ticketsWorkStatus = "02"
this.formData.item.itemStatus = "02"
if (this.formData.recordType === 'kssg') {
this.projectList = this.projectList.filter(item => item.itemStatus === '01')
}else if (this.formData.recordType === 'sgz'){
this.projectList = this.projectList.filter(item => item.itemStatus === '02')
}else {
// >1
this.isNext = this.projectList.filter(item => item.itemStatus !== '03').length > 1
// 010203
// 便
//
//
if (this.formData.recordType !== 'kssg') {
this.projectList = this.projectList.filter(item => item.itemStatus === '02')
// 西
//
if (this.formData.recordType !== 'sgz') {
// >1
this.isNext = this.projectList.filter(item => item.itemStatus !== '03').length > 1
}
}
}finally {
} finally {
this.formLoading = false
}
},
async doUpdate(){
async doUpdate(nextName = null) {
try {
if (this.formData.recordType === 'zj'){
if (nextName){
this.formData['nextName'] = nextName
}
if (this.formData.recordType === 'zj') {
this.formData.ticketsWorkStatus = '03'
this.formData['isFinish'] = '1'
}
if (this.formData.recordType !== 'zj'){
if (this.formData.recordType !== 'zj') {
await this.$refs.formRef.validate()
this.formLoading = true
await updateStatus(this.formData)
this.$modal.msgSuccess("操作成功")
if (!nextName) {
this.$modal.msgSuccess("操作成功")
}
this.dialogVisible = false
this.$emit("success")
}else {
} else {
this.formLoading = true
await updateStatus(this.formData)
this.$modal.msgSuccess("操作成功")
if (nextName) {
this.$modal.msgSuccess("操作成功")
}
this.dialogVisible = false
this.$emit("success")
}
}catch {
} catch {
}
},
async doFinish(){
try{
async doFinish() {
try {
await this.$refs.formRef.validate()
this.formLoading = true
//
this.formData.item.itemStatus = "03"
//
if (this.isNext){
if (this.isNext) {
this.formData['finishType'] = "01"
await this.$refs.updateRepair.open(this.clickRow)
return
}
//
if (this.isEndCheck){
if (this.isEndCheck) {
this.formData['finishType'] = "02"
this.formData.ticketsWorkStatus = "05"
await this.doUpdate();
return
}
// ,
this.formData.ticketsWorkStatus = "03"
this.formData['finishType'] = "03"
this.formData['isFinish'] = '1'
await this.doUpdate()
}catch{}
} catch {
}
}
}
}
</script>
<style scoped lang="scss">
.notice {
display: inline-block;
width: 100%;
text-align: center;
margin: 1rem 0;
font-size: 18px;
color: red;
}
</style>

View File

@ -208,7 +208,7 @@ export default {
await updateRepair(this.formData)
this.$modal.msgSuccess("指派成功")
this.dialogVisible = false
this.$emit("success")
this.$emit("success", this.formData.nowRepairName)
} catch {
}