Browse Source

Merge remote-tracking branch 'origin/master'

master
fanzongzhe 7 months ago
parent
commit
aee98cbf57
  1. 39
      yxt-as-ui/src/router/index.js
  2. 2
      yxt-as-ui/src/views/client/filing/maintenanceEnterpriseAdd.vue
  3. 475
      yxt-as-ui/src/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseDaiBan.vue
  4. 325
      yxt-as-ui/src/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseEdit.vue
  5. 261
      yxt-as-ui/src/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseYiBan.vue

39
yxt-as-ui/src/router/index.js

@ -1045,21 +1045,21 @@ export const constantRoutes = [{
import('@/views/workFlow/suopeikaipiaoFlow/claimbillingYiBan.vue'),
name: 'ClaimBillingYiBan'
},
// 单索赔调整--编辑
// 维修单索赔调整--编辑
{
path: '/suopeitiaozhengFlow/claimadjustmentEdit',
component: () =>
import('@/views/workFlow/suopeitiaozhengFlow/claimadjustmentEdit.vue'),
name: 'ClaimAdjustmentEdit'
},
// 单索赔调整--待办
// 维修单索赔调整--待办
{
path: '/suopeitiaozhengFlow/claimadjustmentDaiBan',
component: () =>
import('@/views/workFlow/suopeitiaozhengFlow/claimadjustmentDaiBan.vue'),
name: 'ClaimAdjustmentDaiBan'
},
// 单索赔调整--已办
// 维修单索赔调整--已办
{
path: '/suopeitiaozhengFlow/claimadjustmentYiBan',
component: () =>
@ -1087,42 +1087,42 @@ export const constantRoutes = [{
import('@/views/workFlow/adjustmentFlow/adjustmentYiBan.vue'),
name: 'AdjustmentYiBan'
},
// 保外工单开票申请管理--编辑
// (保外)维修单开票申请管理--编辑
{
path: '/gongdankaipiaoFlow/workorderinvoicingEdit',
component: () =>
import('@/views/workFlow/gongdankaipiaoFlow/workorderinvoicingEdit.vue'),
name: 'WorkOrderInvoicingEdit'
},
// 保外工单开票申请管理--待办
// (保外)维修单开票申请管理--待办
{
path: '/gongdankaipiaoFlow/workorderinvoicingDaiBan',
component: () =>
import('@/views/workFlow/gongdankaipiaoFlow/workorderinvoicingDaiBan.vue'),
name: 'WorkOrderInvoicingDaiBan'
},
// 保外工单开票申请管理--已办
// (保外)维修单开票申请管理--已办
{
path: '/gongdankaipiaoFlow/workorderinvoicingYiBan',
component: () =>
import('@/views/workFlow/gongdankaipiaoFlow/workorderinvoicingYiBan.vue'),
name: 'WorkOrderInvoicingYiBan'
},
// 保外工单应收调差申请管理--编辑
// (保外)维修单应收调差申请管理--编辑
{
path: '/gongdanyingshouFlow/workorderreceivableEdit',
component: () =>
import('@/views/workFlow/gongdanyingshouFlow/workorderreceivableEdit.vue'),
name: 'WorkOrderReceivableEdit'
},
// 保外工单应收调差申请管理--待办
// (保外)维修单应收调差申请管理--待办
{
path: '/gongdanyingshouFlow/workorderreceivableDaiBan',
component: () =>
import('@/views/workFlow/gongdanyingshouFlow/workorderreceivableDaiBan.vue'),
name: 'WorkOrderReceivableDaiBan'
},
// 保外工单应收调差申请管理--已办
// (保外)维修单应收调差申请管理--已办
{
path: '/gongdanyingshouFlow/workorderreceivableYiBan',
component: () =>
@ -1277,6 +1277,27 @@ export const constantRoutes = [{
import('@/views/workFlow/didingpeijianFlow/topFittingYiBan.vue'),
name: 'TopFittingYiBan'
},
// 欠款月结客户备案 -- 编辑
{
path: '/qiankuanyuejieFlow/maintenanceEnterpriseEdit',
component: () =>
import('@/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseEdit.vue'),
name: 'MaintenanceEnterpriseEdit'
},
// 欠款月结客户备案 -- 待办
{
path: '/qiankuanyuejieFlow/maintenanceEnterpriseDaiBan',
component: () =>
import('@/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseDaiBan.vue'),
name: 'MaintenanceEnterpriseDaiBan'
},
// 欠款月结客户备案 -- 已办
{
path: '/qiankuanyuejieFlow/maintenanceEnterpriseYiBan',
component: () =>
import('@/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseYiBan.vue'),
name: 'MaintenanceEnterpriseYiBan'
},
// 404 page must be placed at the end !!!
// { path: '*', redirect: '/404', hidden: true }
]

2
yxt-as-ui/src/views/client/filing/maintenanceEnterpriseAdd.vue

@ -5,7 +5,7 @@
<div>{{ viewTitle }}</div>
<div>
<el-button type="primary" size="small" :disabled="submitdisabled" @click="saveOrUpdate()">保存</el-button>
<el-button type="primary" size="small" :disabled="submitdisabled">提交</el-button>
<el-button type="primary" size="small" :disabled="submitdisabled" @click="submit()">提交</el-button>
<el-button type="info" size="small" @click="handleReturn()">关闭</el-button>
</div>
</div>

475
yxt-as-ui/src/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseDaiBan.vue

@ -0,0 +1,475 @@
<template>
<div class="app-container">
<div v-show="viewState == 1">
<div class="tab-header webtop">
<div>{{ viewTitle }}</div>
<div>
<el-button type="primary" size="small" @click="openCountersign('加签')"> </el-button>
<el-button type="primary" size="small" @click="openAgree('同意')"> </el-button>
<el-button type="danger" size="small" @click="openReject('驳回')"> </el-button>
<el-button type="danger" size="small" @click="openStop('终止')"> </el-button>
</div>
</div>
<div class="">
<el-form ref="form_obj" :model="formobj" :rules="rules" class="formaddcopy02">
<div class="title">基础信息</div>
<el-row>
<el-col :span="12">
<div class="span-sty">客户名称</div>
<el-form-item><span class="addinputInfo">{{ formobj.customerName }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">客户类型</div>
<el-form-item><span class="addinputInfo">{{ formobj.customerType }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">联系电话</div>
<el-form-item><span class="addinputInfo">{{ formobj.mobile }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">微信号</div>
<el-form-item><span class="addinputInfo">{{ formobj.weixin }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<div class="span-sty">客户地址</div>
<el-form-item><span class="addinputInfo">{{ formobj.province }}{{ formobj.city }}{{ formobj.county }}{{ formobj.address }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">证件类型</div>
<el-form-item><span class="addinputInfo">{{ formobj.certificateType }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">证件号码</div>
<el-form-item><span class="addinputInfo">{{ formobj.idnumber }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">证件有效期</div>
<el-form-item><span class="addinputInfo">{{ formobj.endDate }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">电子邮箱</div>
<el-form-item><span class="addinputInfo">{{ formobj.e_mail }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">紧急联系人</div>
<el-form-item><span class="addinputInfo">{{ formobj.emergencyContact }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">紧急联系电话</div>
<el-form-item><span class="addinputInfo">{{ formobj.emergencyMobile }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">备案有效期</div>
<el-form-item><span class="addinputInfo">{{ formobj.filingIndate }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">备注</div>
<el-form-item><span class="addinputInfo">{{ formobj.remarks }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<div class="span-sty">附件</div>
<el-form-item><el-image class="addinputInfo" style="width: 150px;height: 150px" v-for="(item, index) in formobj.files" :key="index" :src="item" :preview-src-list="formobj.files" /></el-form-item>
</el-col>
</el-row>
<div class="title">对接人信息<span v-if="formobj.filingType == '补充'">(已备{{ formobj.readyStrength }})</span></div>
<el-table :key="abutmentKey" :data="formobj.contactPerson" :index="index" border style="width: 100%">
<el-table-column fixed width="60" label="序号" type="index" :index="index + 1" align="center"/>
<el-table-column prop="name" label="姓名" align="center" min-width="200" />
<el-table-column prop="mobile" label="电话" align="center" min-width="200" />
<el-table-column prop="remarks" label="备注" align="center" min-width="200" />
</el-table>
<div class="title">车辆信息<span v-if="formobj.filingType == '补充'">(已备{{ formobj.readyVehicle }})</span></div>
<el-table :key="carKey" :data="formobj.carList" :index="index" border style="width: 100%">
<el-table-column fixed width="60" label="序号" type="index" :index="index + 1" align="center"/>
<el-table-column prop="vehMark" label="车牌号" align="center" min-width="200" />
<el-table-column prop="vinNo" label="车架号" align="center" min-width="200" />
<el-table-column prop="buyDate" label="购买日期" align="center" min-width="200" />
</el-table>
</el-form>
</div>
</div>
<!-- 选择待办人 的弹出框-->
<el-dialog title="填写审批意见" :visible.sync="nodeDialogVisible" width="80%">
<el-form class="formadd" >
<el-row v-show="countersignLink" style="border-top: 1px solid #e0e3eb">
<el-col :span="4" class="tleftb">
<span class="icon">*</span>加签人员:
</el-col>
<el-col :span="20">
<el-form-item>
<el-select v-model="countersign.assignee" placeholder="请选择" filterable>
<el-option v-for="item in options" :key="item.userSid" :label="item.staffName" :value="item.userSid">
</el-option>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row v-show="currentLink" style="border-top: 1px solid #e0e3eb">
<el-col :span="4" class="tleftb">
<span>当前环节:</span>
</el-col>
<el-col :span="20">
<el-form-item><span>{{ current.taskName }}->{{ nextNode.name }}</span></el-form-item>
</el-col>
</el-row>
<el-row :class="{rowClass:!currentLink}">
<el-col :span="4" class="tleftb">
<span>意见:</span>
</el-col>
<el-col :span="20">
<el-form-item><el-input size="small" v-model="dialogList.comment" placeholder="审批意见" class="addinputw" type="textarea" :autosize="{ minRows: 1, maxRows: 10}" clearable ></el-input></el-form-item>
</el-col>
</el-row>
<div style="text-align:center;margin-top: 20px;">
<el-button type="primary" size="mini" @click="reject"> </el-button>
<el-button type="info " size="mini" @click="nodeDialogVisible = false"> </el-button>
</div>
</el-form>
</el-dialog>
</div>
</template>
<script>
import req from '@/api/client/maintenanceEnterprise'
import { selectStaffListss } from '@/api/Common/dictcommons'
export default {
name: 'MaintenanceEnterpriseDaiBan',
data() {
return {
viewTitle: '',
viewState: 1,
abutmentKey: 1,
carKey: 2,
index: 0,
formobj: {
customerName: '',
customerSid: '',
customerType: '',
customerTypeKey: '',
mobile: '',
weixin: '',
province: '',
city: '',
county: '',
address: '',
certificateType: '',
certificateTypeKey: '',
idnumber: '',
endDate: '',
e_mail: '',
emergencyContact: '',
emergencyMobile: '',
filingIndate: '',
filingType: '', //
remarks: '',
createByName: '',
createBySid: '',
createOrgName: '',
createOrgSid: '',
createTime: '',
deptName: '',
deptSid: '',
instanceId: '',
sid: '',
taskId: '',
useOrgName: '',
useOrgSid: '',
readyStrength: '',
readyVehicle: '',
files: [],
contactPerson: [],
carList: []
},
rules: {},
options: [],
operation: '', //
dialogList: {
comment: ''
},
startTask: true,
current: {
taskDefKey: '',
taskName: '' //
},
nextNode: {}, //
nodeDialogVisible: false,
currentLink: true,
countersignLink: false,
//
linkByParameter: {
businessSid: '',
comment: '',
instanceId: '',
taskId: '',
orgSidPath: '',
taskDefKey: '',
userSid: ''
},
//
countersign: {
taskId: '',
assignee: '',
userSid: '',
instanceId: '',
views: ''
}
}
},
created() {
console.log('url:' + window.location.href)
var one = window.location.href.indexOf('&data') + 6
const data = window.location.href.substr(one) // urlunescape()web,使
const obj = JSON.parse(decodeURIComponent(data))
console.log('iframe页面获取的obj:', obj)
//
this.linkByParameter.businessSid = obj.businessSid
this.linkByParameter.instanceId = obj.instanceId
this.linkByParameter.taskId = obj.taskId
this.linkByParameter.taskDefKey = obj.taskDefKey
// this.linkByParameter.orgSidPath = window.sessionStorage.getItem('orgSidPath')
this.linkByParameter.userSid = window.sessionStorage.getItem('userSid')
this.current.taskDefKey = obj.taskDefKey
this.current.taskName = obj.taskName
//
this.countersign.taskId = obj.taskId
this.countersign.userSid = window.sessionStorage.getItem('userSid')
this.countersign.instanceId = obj.instanceId
//
this.showInfo(obj.businessSid)
},
mounted() {
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 2,
data: 500 + 'px'
}
}, '*')
},
methods: {
showInfo(sid) {
this.viewTitle = '欠款月结客户备案申请详情'
this.$nextTick(() => {
this.$refs['form_obj'].clearValidate()
})
req.fetchDetailsBySid(sid).then((res) => {
if (res.success) {
this.formobj = res.data
if (this.formobj.files.length > 0) {
const aa = []
this.formobj.files.forEach((e) => {
aa.push(e.url)
})
this.formobj.files = aa
}
}
})
selectStaffListss().then((res) => {
if (res.success) {
this.options = res.data
}
})
},
//
openCountersign(val) {
this.operation = val
this.currentLink = true
this.countersignLink = true
this.dialogList.comment = ''
req.getNextNodesForSubmit({ taskDefKey: this.current.taskDefKey, businessSid: this.linkByParameter.businessSid }).then((resp) => {
if (resp.success) {
var arr = resp.data
this.nextNode = arr[0]
this.nodeDialogVisible = true
}
this.submitdisabled = false
})
},
//
openAgree(val) {
this.operation = val
this.currentLink = true
this.countersignLink = false
this.dialogList.comment = '同意'
req.getNextNodesForSubmit({ taskDefKey: this.current.taskDefKey, businessSid: this.linkByParameter.businessSid }).then((resp) => {
if (resp.success) {
var arr = resp.data
this.nextNode = arr[0]
this.nodeDialogVisible = true
}
this.submitdisabled = false
})
},
//
openReject(val) {
this.operation = val
this.currentLink = true
this.countersignLink = false
this.dialogList.comment = ''
req.getPreviousNodesForReject({ taskDefKey: this.current.taskDefKey, businessSid: this.linkByParameter.businessSid }).then((resp) => {
if (resp.success) {
var arr = resp.data
this.nextNode = arr[0]
this.nodeDialogVisible = true
}
this.submitdisabled = false
})
},
//
openStop(val) {
this.operation = val
this.currentLink = false
this.countersignLink = false
this.dialogList.comment = ''
this.nodeDialogVisible = true
},
reject() {
if (this.operation === '同意') {
this.handleAgree()
} else if (this.operation === '驳回') {
if (this.dialogList.comment === '') {
this.$message({ showClose: true, type: 'error', message: '请填写审批意见' })
} else {
this.handleReject()
}
} else if (this.operation === '终止') {
if (this.dialogList.comment === '') {
this.$message({ showClose: true, type: 'error', message: '请填写审批意见' })
} else {
this.handleStop()
}
} else if (this.operation === '加签') {
this.handleCountersign()
}
},
/** 加签 */
handleCountersign() {
if (this.countersign.assignee === '') {
this.$message({ showClose: true, type: 'error', message: '请选择加签人员' })
return
}
if (this.dialogList.comment === '') {
this.$message({ showClose: true, type: 'error', message: '请填写审批意见' })
return
}
this.countersign.views = this.dialogList.comment
req.delegate(this.countersign).then((response) => {
if (response.success) {
this.$notify({
title: '提示',
message: '执行成功',
type: 'success',
duration: 2000
})
this.nodeDialogVisible = false
//
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 1
}
}, '*')
}
})
},
/** 同意任务 */
handleAgree() {
this.linkByParameter.comment = this.dialogList.comment
req.complete(this.linkByParameter).then((response) => {
if (response.success) {
this.$notify({
title: '提示',
message: '执行成功',
type: 'success',
duration: 2000
})
this.nodeDialogVisible = false
//
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 1
}
}, '*')
}
})
},
/** 驳回任务 */
handleReject() {
this.linkByParameter.comment = this.dialogList.comment
req.reject(this.linkByParameter).then((response) => {
if (response.success) {
this.$notify({
title: '提示',
message: '执行成功',
type: 'success',
duration: 2000
})
this.nodeDialogVisible = false
//
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 1
}
}, '*')
}
})
},
/** 终止任务 */
handleStop() {
this.linkByParameter.comment = this.dialogList.comment
req.breakProcess(this.linkByParameter).then((response) => {
if (response.success) {
this.$notify({
title: '提示',
message: '执行成功',
type: 'success',
duration: 2000
})
this.nodeDialogVisible = false
//
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 1
}
}, '*')
}
})
}
}
}
</script>
<style scoped>
.span-sty {
width: 130px !important;
}
.addinputInfo {
margin-left: 120px !important;
}
.rowClass{
border-top: 1px solid #E0E3EB;
}
</style>

325
yxt-as-ui/src/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseEdit.vue

@ -0,0 +1,325 @@
<template>
<div class="app-container">
<div v-show="viewState == 1">
<div class="tab-header webtop">
<div>{{ viewTitle }}</div>
<div>
<el-button type="primary" size="small" :disabled="submitdisabled" @click="saveOrUpdate()">保存</el-button>
<el-button type="primary" size="small" :disabled="submitdisabled" @click="submit()">提交</el-button>
</div>
</div>
<div class="">
<el-form ref="form_obj" :model="formobj" :rules="rules" class="formaddcopy02">
<div class="title">基础信息</div>
<el-row>
<el-col :span="12">
<div class="span-sty">客户名称</div>
<el-form-item><span class="addinputInfo">{{ formobj.customerName }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">客户类型</div>
<el-form-item><span class="addinputInfo">{{ formobj.customerType }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">联系电话</div>
<el-form-item><span class="addinputInfo">{{ formobj.mobile }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">微信号</div>
<el-form-item><span class="addinputInfo">{{ formobj.weixin }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<div class="span-sty">客户地址</div>
<el-form-item><span class="addinputInfo">{{ formobj.province }}{{ formobj.city }}{{ formobj.county }}{{ formobj.address }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">证件类型</div>
<el-form-item><span class="addinputInfo">{{ formobj.certificateType }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">证件号码</div>
<el-form-item><span class="addinputInfo">{{ formobj.idnumber }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">证件有效期</div>
<el-form-item><span class="addinputInfo">{{ formobj.endDate }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">电子邮箱</div>
<el-form-item><span class="addinputInfo">{{ formobj.e_mail }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">紧急联系人</div>
<el-form-item><span class="addinputInfo">{{ formobj.emergencyContact }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">紧急联系电话</div>
<el-form-item><span class="addinputInfo">{{ formobj.emergencyMobile }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">备案有效期</div>
<el-form-item><el-date-picker class="addinputInfo" v-model="formobj.filingIndate" value-format="yyyy-MM-dd" format="yyyy-MM-dd" type="date" placeholder="选择日期" /></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">备注</div>
<el-form-item><el-input class="addinputInfo addinputw" v-model="formobj.remarks" clearable placeholder="" /></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<div class="span-sty">附件</div>
<el-form-item>
<uploadImg ref="uploadImg" class="addinputInfo" v-model="formobj.files" :limit="50" bucket="map" :upload-data="{ type: '0001' }"/>
</el-form-item>
</el-col>
</el-row>
<div class="title">对接人信息<span v-if="formobj.filingType == '补充'">(已备{{ formobj.readyStrength }})</span></div>
<el-table :key="abutmentKey" :data="formobj.contactPerson" :index="index" border style="width: 100%">
<el-table-column fixed width="60" label="序号" type="index" :index="index + 1" align="center"/>
<el-table-column align="center" width="80">
<template slot="header" slot-scope="scope">
<i class="add-btn-icon el-icon-plus" style="color: red;font-size:20px" @click="abutmentAdd(scope.row)"></i>
</template>
<template slot-scope="scope">
<i class="el-icon-delete" @click="abutmentDelete(scope.$index)"></i>
</template>
</el-table-column>
<el-table-column label="姓名" align="center" min-width="200">
<template slot-scope="scope">
<el-input v-model="scope.row.name" clearable placeholder="" />
</template>
</el-table-column>
<el-table-column label="电话" align="center" min-width="200">
<template slot-scope="scope">
<el-input v-model="scope.row.mobile" clearable placeholder="" />
</template>
</el-table-column>
<el-table-column label="备注" align="center" min-width="200">
<template slot-scope="scope">
<el-input v-model="scope.row.remarks" clearable placeholder="" />
</template>
</el-table-column>
</el-table>
<div class="title">车辆信息<span v-if="formobj.filingType == '补充'">(已备{{ formobj.readyVehicle }})</span></div>
<el-table :key="carKey" :data="formobj.carList" :index="index" border style="width: 100%">
<el-table-column fixed width="60" label="序号" type="index" :index="index + 1" align="center"/>
<el-table-column align="center" width="80">
<template slot="header" slot-scope="scope">
<i class="add-btn-icon el-icon-plus" style="color: red;font-size:20px" @click="carAdd(scope.row)"></i>
</template>
<template slot-scope="scope">
<i class="el-icon-delete" @click="carDelete(scope.$index)"></i>
</template>
</el-table-column>
<el-table-column label="车牌号" align="center" min-width="200">
<template slot-scope="scope">
<el-input v-model="scope.row.vehMark" clearable placeholder="" />
</template>
</el-table-column>
<el-table-column label="车架号" align="center" min-width="200">
<template slot-scope="scope">
<el-input v-model="scope.row.vinNo" clearable placeholder="" />
</template>
</el-table-column>
<el-table-column label="购买日期" align="center" min-width="200">
<template slot-scope="scope">
<el-date-picker v-model="scope.row.buyDate" value-format="yyyy-MM-dd" format="yyyy-MM-dd" type="date" placeholder="选择日期" />
</template>
</el-table-column>
</el-table>
</el-form>
</div>
</div>
</div>
</template>
<script>
import req from '@/api/client/maintenanceEnterprise'
import uploadImg from '@/components/uploadFile/uploadImg'
import { fetchBySid, getOrgSidByPath } from '@/api/Common/dictcommons'
export default {
name: 'MaintenanceEnterpriseEdit',
components: {
uploadImg
},
data() {
return {
viewTitle: '',
viewState: 1,
submitdisabled: false,
abutmentKey: 1,
carKey: 2,
index: 0,
formobj: {
customerName: '',
customerSid: '',
customerType: '',
customerTypeKey: '',
mobile: '',
weixin: '',
province: '',
city: '',
county: '',
address: '',
certificateType: '',
certificateTypeKey: '',
idnumber: '',
endDate: '',
e_mail: '',
emergencyContact: '',
emergencyMobile: '',
filingIndate: '',
filingType: '', //
remarks: '',
createByName: '',
createBySid: '',
createOrgName: '',
createOrgSid: '',
createTime: '',
deptName: '',
deptSid: '',
instanceId: '',
sid: '',
taskId: '',
useOrgName: '',
useOrgSid: '',
readyStrength: '',
readyVehicle: '',
files: [],
contactPerson: [],
carList: []
},
rules: {}
}
},
created() {
console.log('url:' + window.location.href)
var one = window.location.href.indexOf('&data') + 6
const data = window.location.href.substr(one) // urlunescape()web,使
const obj = JSON.parse(decodeURIComponent(data))
this.showInfo(obj.businessSid)
},
mounted() {
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 2,
data: 500 + 'px'
}
}, '*')
},
methods: {
showInfo(sid) {
this.viewTitle = '【编辑】定点企业备案申请'
this.$nextTick(() => {
this.$refs['form_obj'].clearValidate()
})
req.fetchDetailsBySid(sid).then((res) => {
if (res.success) {
this.formobj = res.data
}
})
},
abutmentAdd() {
this.formobj.contactPerson.push({
sid: '',
name: '',
mobile: '',
remarks: ''
})
},
abutmentDelete(index) {
this.formobj.contactPerson.splice(index, 1)
},
carAdd() {
this.formobj.carList.push({
sid: '',
vehMark: '',
vinNo: '',
buyDate: ''
})
},
carDelete(index) {
this.formobj.carList.splice(index, 1)
},
saveOrUpdate() {
this.$refs['form_obj'].validate((valid) => {
if (valid) {
this.submitdisabled = true
req.saveOrUpdate(this.formobj).then((res) => {
if (res.success) {
this.$message({ showClose: true, type: 'success', message: '保存成功' })
// ()
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 1
}
}, '*')
} else {
this.submitdisabled = false
}
}).catch(() => {
this.submitdisabled = false
})
}
})
},
submit() {
this.$refs['form_obj'].validate((valid) => {
if (valid) {
this.submitdisabled = true
req.submit(this.formobj).then((res) => {
if (res.success) {
this.$message({ showClose: true, type: 'success', message: '提交成功' })
// ()
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 1
}
}, '*')
} else {
this.submitdisabled = false
}
}).catch(() => {
this.submitdisabled = false
})
}
})
}
}
}
</script>
<style scoped>
.span-sty {
width: 130px !important;
}
.addinputInfo {
margin-left: 120px !important;
}
/deep/ .el-form-item__error {
margin-left: 120px !important;
}
.formaddcopy02 .el-row .el-col /deep/ .el-form-item .addinputw {
margin-left: 120px !important;
width: calc(100% - 115px);
}
</style>

261
yxt-as-ui/src/views/workFlow/qiankuanyuejieFlow/maintenanceEnterpriseYiBan.vue

@ -0,0 +1,261 @@
<template>
<div class="app-container">
<div v-show="viewState == 1">
<div class="tab-header webtop">
<div>{{ viewTitle }}</div>
<div>
<el-button type="danger" size="small" @click="openRevoke()">撤回</el-button>
</div>
</div>
<div class="">
<el-form ref="form_obj" :model="formobj" :rules="rules" class="formaddcopy02">
<div class="title">基础信息</div>
<el-row>
<el-col :span="12">
<div class="span-sty">客户名称</div>
<el-form-item><span class="addinputInfo">{{ formobj.customerName }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">客户类型</div>
<el-form-item><span class="addinputInfo">{{ formobj.customerType }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">联系电话</div>
<el-form-item><span class="addinputInfo">{{ formobj.mobile }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">微信号</div>
<el-form-item><span class="addinputInfo">{{ formobj.weixin }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<div class="span-sty">客户地址</div>
<el-form-item><span class="addinputInfo">{{ formobj.province }}{{ formobj.city }}{{ formobj.county }}{{ formobj.address }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">证件类型</div>
<el-form-item><span class="addinputInfo">{{ formobj.certificateType }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">证件号码</div>
<el-form-item><span class="addinputInfo">{{ formobj.idnumber }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">证件有效期</div>
<el-form-item><span class="addinputInfo">{{ formobj.endDate }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">电子邮箱</div>
<el-form-item><span class="addinputInfo">{{ formobj.e_mail }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">紧急联系人</div>
<el-form-item><span class="addinputInfo">{{ formobj.emergencyContact }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">紧急联系电话</div>
<el-form-item><span class="addinputInfo">{{ formobj.emergencyMobile }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<div class="span-sty">备案有效期</div>
<el-form-item><span class="addinputInfo">{{ formobj.filingIndate }}</span></el-form-item>
</el-col>
<el-col :span="12">
<div class="span-sty">备注</div>
<el-form-item><span class="addinputInfo">{{ formobj.remarks }}</span></el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<div class="span-sty">附件</div>
<el-form-item><el-image class="addinputInfo" style="width: 150px;height: 150px" v-for="(item, index) in formobj.files" :key="index" :src="item" :preview-src-list="formobj.files" /></el-form-item>
</el-col>
</el-row>
<div class="title">对接人信息<span v-if="formobj.filingType == '补充'">(已备{{ formobj.readyStrength }})</span></div>
<el-table :key="abutmentKey" :data="formobj.contactPerson" :index="index" border style="width: 100%">
<el-table-column fixed width="60" label="序号" type="index" :index="index + 1" align="center"/>
<el-table-column prop="name" label="姓名" align="center" min-width="200" />
<el-table-column prop="mobile" label="电话" align="center" min-width="200" />
<el-table-column prop="remarks" label="备注" align="center" min-width="200" />
</el-table>
<div class="title">车辆信息<span v-if="formobj.filingType == '补充'">(已备{{ formobj.readyVehicle }})</span></div>
<el-table :key="carKey" :data="formobj.carList" :index="index" border style="width: 100%">
<el-table-column fixed width="60" label="序号" type="index" :index="index + 1" align="center"/>
<el-table-column prop="vehMark" label="车牌号" align="center" min-width="200" />
<el-table-column prop="vinNo" label="车架号" align="center" min-width="200" />
<el-table-column prop="buyDate" label="购买日期" align="center" min-width="200" />
</el-table>
</el-form>
</div>
</div>
</div>
</template>
<script>
import req from '@/api/client/maintenanceEnterprise'
export default {
name: 'MaintenanceEnterpriseYiBan',
data() {
return {
viewTitle: '',
viewState: 1,
abutmentKey: 1,
carKey: 2,
index: 0,
formobj: {
customerName: '',
customerSid: '',
customerType: '',
customerTypeKey: '',
mobile: '',
weixin: '',
province: '',
city: '',
county: '',
address: '',
certificateType: '',
certificateTypeKey: '',
idnumber: '',
endDate: '',
e_mail: '',
emergencyContact: '',
emergencyMobile: '',
filingIndate: '',
filingType: '', //
remarks: '',
createByName: '',
createBySid: '',
createOrgName: '',
createOrgSid: '',
createTime: '',
deptName: '',
deptSid: '',
instanceId: '',
sid: '',
taskId: '',
useOrgName: '',
useOrgSid: '',
readyStrength: '',
readyVehicle: '',
files: [],
contactPerson: [],
carList: []
},
rules: {},
//
linkByParameter: {
businessSid: '',
comment: '',
instanceId: '',
taskId: '',
orgSidPath: '',
taskDefKey: '',
userSid: ''
}
}
},
created() {
console.log('url:' + window.location.href)
var one = window.location.href.indexOf('&data') + 6
const data = window.location.href.substr(one) // urlunescape()web,使
const obj = JSON.parse(decodeURIComponent(data))
console.log('iframe页面获取的obj:', obj)
//
this.linkByParameter.businessSid = obj.businessSid
this.linkByParameter.instanceId = obj.instanceId
this.linkByParameter.taskId = obj.taskId
this.linkByParameter.taskDefKey = obj.taskDefKey
this.linkByParameter.userSid = window.sessionStorage.getItem('userSid')
//
this.showInfo(obj.businessSid)
},
mounted() {
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 2,
data: 500 + 'px'
}
}, '*')
},
methods: {
showInfo(sid) {
this.viewTitle = '欠款月结客户备案申请详情'
this.$nextTick(() => {
this.$refs['form_obj'].clearValidate()
})
req.fetchDetailsBySid(sid).then((res) => {
if (res.success) {
this.formobj = res.data
if (this.formobj.files.length > 0) {
const aa = []
this.formobj.files.forEach((e) => {
aa.push(e.url)
})
this.formobj.files = aa
}
}
})
},
/** 确认撤回任务 */
openRevoke() {
this.$confirm('是否确认执行撤回操作', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
this.handleRevoke()
}).catch(() => {
this.$message({
type: 'info',
message: '已取消撤回'
})
})
},
/** 撤回任务 */
handleRevoke() {
req.revokeProcess(this.linkByParameter).then((response) => {
if (response.success) {
this.$notify({
title: '提示',
message: '执行成功',
type: 'success',
duration: 2000
})
this.nodeDialogVisible = false
//
window.parent.postMessage({
cmd: 'returnHeight',
params: {
//
code: 1
}
}, '*')
}
})
}
}
}
</script>
<style scoped>
.span-sty {
width: 130px !important;
}
.addinputInfo {
margin-left: 120px !important;
}
</style>
Loading…
Cancel
Save