Compare commits
3 Commits
prod-26-04
...
c4f078db0d
| Author | SHA1 | Date | |
|---|---|---|---|
| c4f078db0d | |||
| 066cb05797 | |||
| 72817e22e3 |
@@ -177,23 +177,3 @@ export function getNewVersion(key){
|
|||||||
params: key
|
params: key
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getLog(data){
|
|
||||||
// 添加log
|
|
||||||
return request({
|
|
||||||
url: '/ureport/pageView/save',
|
|
||||||
method:'POST',
|
|
||||||
contentType:'application/json',
|
|
||||||
data
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//获取最新版本
|
|
||||||
export function getUserBO(){
|
|
||||||
return request({
|
|
||||||
url: '/base/user/getUserBO',
|
|
||||||
method:'POST',
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ service.interceptors.request.use(
|
|||||||
// let token='eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJBTkNIQU5HIiwidXNlcklkIjo0NTY3MSwibmFtZSI6IuWuieeVhSIsInVzZXJOYW1lIjoiQU5DSEFORyIsInN1cHBsaWVySWQiOjExMjgsImlzWmQiOjAsImV4cCI6MTc1NTQyMjUyNX0.xzDZhaANJFnbeViIHJA0SEtOyTv7Ja3rKmXqRKRuFkc'
|
// let token='eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJBTkNIQU5HIiwidXNlcklkIjo0NTY3MSwibmFtZSI6IuWuieeVhSIsInVzZXJOYW1lIjoiQU5DSEFORyIsInN1cHBsaWVySWQiOjExMjgsImlzWmQiOjAsImV4cCI6MTc1NTQyMjUyNX0.xzDZhaANJFnbeViIHJA0SEtOyTv7Ja3rKmXqRKRuFkc'
|
||||||
// let token='eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJTSEhQWEIiLCJ1c2VySWQiOjU0NzI2LCJuYW1lIjoiI-a1i-ivleWwj-eZveeZvSIsInVzZXJOYW1lIjoiU0hIUFhCIiwic3VwcGxpZXJJZCI6MTAwMDE2NSwiZXhwIjoxNzQ0NTEwNzkwfQ.JPk0OA7slYJN3FIi_uhW4Y0CiWRvl6R1dK8MRTbyhD8'
|
// let token='eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJTSEhQWEIiLCJ1c2VySWQiOjU0NzI2LCJuYW1lIjoiI-a1i-ivleWwj-eZveeZvSIsInVzZXJOYW1lIjoiU0hIUFhCIiwic3VwcGxpZXJJZCI6MTAwMDE2NSwiZXhwIjoxNzQ0NTEwNzkwfQ.JPk0OA7slYJN3FIi_uhW4Y0CiWRvl6R1dK8MRTbyhD8'
|
||||||
// if(!(reqUrl=='/supplier/supplierTraining/trainingTask' || reqUrl=='/supplier/supplierTraining/normalList' || reqUrl=='/supplier/supplierTraining/trainingList')){
|
// if(!(reqUrl=='/supplier/supplierTraining/trainingTask' || reqUrl=='/supplier/supplierTraining/normalList' || reqUrl=='/supplier/supplierTraining/trainingList')){
|
||||||
if ((reqUrl=='/supplier/supplierTraining/trainingList' || reqUrl=='/supplier/supplierTraining/normalList') && config?.params?.type==1){
|
if (reqUrl=='/supplier/supplierTraining/trainingList' && config?.params?.type==1){
|
||||||
console.log('司机app使用该请求不挂token')
|
console.log('司机app使用该请求不挂token')
|
||||||
} else {
|
} else {
|
||||||
if(token) {
|
if(token) {
|
||||||
|
|||||||
@@ -1,6 +1,3 @@
|
|||||||
import { getLog } from "@/api/order"
|
|
||||||
|
|
||||||
let _setLogTimer = null
|
|
||||||
|
|
||||||
export const myMixins = {
|
export const myMixins = {
|
||||||
data() {
|
data() {
|
||||||
@@ -8,11 +5,6 @@ export const myMixins = {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
setLogHandler(data) {
|
|
||||||
if (_setLogTimer) return
|
|
||||||
_setLogTimer = setTimeout(() => { _setLogTimer = null }, 1000)
|
|
||||||
getLog(data)
|
|
||||||
},
|
|
||||||
showFun() {
|
showFun() {
|
||||||
if( localStorage.getItem('infoVerify') == 8 || localStorage.getItem('infoVerify') == 12 ) {
|
if( localStorage.getItem('infoVerify') == 8 || localStorage.getItem('infoVerify') == 12 ) {
|
||||||
return false
|
return false
|
||||||
|
|||||||
@@ -154,7 +154,7 @@ export default {
|
|||||||
this.isLoading = false
|
this.isLoading = false
|
||||||
},
|
},
|
||||||
initShow(){
|
initShow(){
|
||||||
this.keyword= ''
|
this.keyword= '',
|
||||||
this.getNormalList()
|
this.getNormalList()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="wrap">
|
<div class="wrap">
|
||||||
<div class="error_bar" v-if="errorMsg">{{ errorMsg }}</div>
|
|
||||||
<div class="top_banner">
|
<div class="top_banner">
|
||||||
<img src="@/assets/supplier/topBg.png" alt="">
|
<img src="@/assets/supplier/topBg.png" alt="">
|
||||||
</div>
|
</div>
|
||||||
@@ -135,7 +134,6 @@
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
clickFlag: true,
|
clickFlag: true,
|
||||||
errorMsg: '',
|
|
||||||
phoneVerify: [{ required: true, message: '请输入联系电话' }, { validator: value => { return /^1[3456789]\d{9}$/.test(value) }, message: '联系电话格式不正确' }],
|
phoneVerify: [{ required: true, message: '请输入联系电话' }, { validator: value => { return /^1[3456789]\d{9}$/.test(value) }, message: '联系电话格式不正确' }],
|
||||||
emailVerify: [{ required: true, message: '请输入邮箱' }, { validator: value => { return /[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?/.test(value) }, message: '邮箱格式不正确' }],
|
emailVerify: [{ required: true, message: '请输入邮箱' }, { validator: value => { return /[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?/.test(value) }, message: '邮箱格式不正确' }],
|
||||||
id:'', //车辆Id
|
id:'', //车辆Id
|
||||||
@@ -233,11 +231,7 @@
|
|||||||
this.idBackPhoto = _data?.idCardBackUrl;
|
this.idBackPhoto = _data?.idCardBackUrl;
|
||||||
this.companyPhoto = _data?.businessLicense;
|
this.companyPhoto = _data?.businessLicense;
|
||||||
this.licensePhoto = _data?.accountUrl;
|
this.licensePhoto = _data?.accountUrl;
|
||||||
this.wechatId = _data?.wechatId;
|
this.wechatId = _data?.wechatId
|
||||||
this.form.person = _data.legalName;
|
|
||||||
if( _data.failReason ) {
|
|
||||||
this.showError(_data.failReason)
|
|
||||||
}
|
|
||||||
if(this.idFrontPhoto) {
|
if(this.idFrontPhoto) {
|
||||||
this.idFrontPhotoList = [{ url : this.idFrontPhoto }];
|
this.idFrontPhotoList = [{ url : this.idFrontPhoto }];
|
||||||
}
|
}
|
||||||
@@ -258,54 +252,44 @@
|
|||||||
// this.form.serviceAreaCode = _data?.serviceAreaCode.split(',').map(item => Number(item));
|
// this.form.serviceAreaCode = _data?.serviceAreaCode.split(',').map(item => Number(item));
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
showError(msg) {
|
|
||||||
this.errorMsg = msg;
|
|
||||||
},
|
|
||||||
async applyAdd() {
|
async applyAdd() {
|
||||||
this.errorMsg = '';
|
|
||||||
if( !this.idFrontPhoto ) {
|
if( !this.idFrontPhoto ) {
|
||||||
this.showError('法人身份证人像页未上传')
|
this.$toast('法人身份证人像页未上传')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if( !this.idBackPhoto ) {
|
if( !this.idBackPhoto ) {
|
||||||
this.showError('法人身份证国徽页未上传')
|
this.$toast('法人身份证国徽页未上传')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if( !this.companyPhoto ) {
|
if( !this.companyPhoto ) {
|
||||||
this.showError('营业执照未上传')
|
this.$toast('营业执照未上传')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if(this.form.person != this.form.legalName){
|
if(this.form.person != this.form.legalName){
|
||||||
this.showError('身份证法人姓名和营业执照法人不一致')
|
this.$toast('身份证法人姓名和营业执照法人不一致')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if( !this.licensePhoto ) {
|
if( !this.licensePhoto ) {
|
||||||
this.showError('开户许可证未上传')
|
this.$toast('开户许可证未上传')
|
||||||
return
|
|
||||||
}
|
|
||||||
if( !(this.$refs.tree.getCheckedKeys().length > 0) ) {
|
|
||||||
this.showError('服务能力不能为空')
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if( !(this.form.serviceAreaCode.length > 0) ) {
|
if( !(this.form.serviceAreaCode.length > 0) ) {
|
||||||
this.showError('服务区域不能为空')
|
this.$toast('服务区域不能为空')
|
||||||
return
|
|
||||||
}
|
|
||||||
if( !this.qrCode && !this.id) {
|
|
||||||
await this.QrCodeHandler();
|
|
||||||
this.showError('请先添加下方企微再申请')
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
// this.wechatId='wmOTNXBwAABrvKkE_Fh8ZN8Xm2S9v2wQ'
|
// this.wechatId='wmOTNXBwAABrvKkE_Fh8ZN8Xm2S9v2wQ'
|
||||||
if(!this.wechatId) {
|
if(!this.wechatId) {
|
||||||
await this.QrCodeResult();
|
await this.QrCodeResult();
|
||||||
if( !this.wechatId ) {
|
if( !this.wechatId ) {
|
||||||
this.showError('请先添加企微再申请')
|
this.$toast('请先添加企微再申请')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if( this.$refs.tree.getCheckedKeys().length > 0 ) {
|
if( this.$refs.tree.getCheckedKeys().length > 0 ) {
|
||||||
await this.saveHandler()
|
await this.saveHandler()
|
||||||
|
} else {
|
||||||
|
this.$toast('服务能力不能为空')
|
||||||
|
return
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async QrCodeResult() { //获取添加企微结果
|
async QrCodeResult() { //获取添加企微结果
|
||||||
@@ -346,8 +330,6 @@
|
|||||||
this.clickFlag = true
|
this.clickFlag = true
|
||||||
}, 1000)
|
}, 1000)
|
||||||
});
|
});
|
||||||
} catch (e) {
|
|
||||||
this.showError(e)
|
|
||||||
} finally {
|
} finally {
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
this.clickFlag = true
|
this.clickFlag = true
|
||||||
@@ -446,7 +428,7 @@
|
|||||||
this.form.accountInfoDTO.companyType=res?.data?.type
|
this.form.accountInfoDTO.companyType=res?.data?.type
|
||||||
// 营业执照法人名称
|
// 营业执照法人名称
|
||||||
this.form.person = res?.data?.person
|
this.form.person = res?.data?.person
|
||||||
// await this.QrCodeHandler();
|
await this.QrCodeHandler();
|
||||||
},
|
},
|
||||||
async licensePhotoHandler(file){// 开户许可证
|
async licensePhotoHandler(file){// 开户许可证
|
||||||
const formData = new FormData();
|
const formData = new FormData();
|
||||||
@@ -460,8 +442,8 @@
|
|||||||
ocrType: 15,
|
ocrType: 15,
|
||||||
imageUrl: this.licensePhoto,
|
imageUrl: this.licensePhoto,
|
||||||
})
|
})
|
||||||
this.form.accountInfoDTO.accountNumber=res?.data?.accountNumber || ''
|
this.form.accountInfoDTO.accountNumber=res?.data?.accountNumber
|
||||||
this.form.accountInfoDTO.accountName = res?.data?.accountBank || ''
|
this.form.accountInfoDTO.accountName = res?.data?.accountBank
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@@ -481,17 +463,6 @@
|
|||||||
padding-bottom: 100px;
|
padding-bottom: 100px;
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
}
|
}
|
||||||
.error_bar {
|
|
||||||
position: sticky;
|
|
||||||
top: 0;
|
|
||||||
z-index: 9999;
|
|
||||||
background-color: #e53935;
|
|
||||||
color: #ffffff;
|
|
||||||
font-size: 14px;
|
|
||||||
padding: 10px 16px;
|
|
||||||
text-align: center;
|
|
||||||
line-height: 1.5;
|
|
||||||
}
|
|
||||||
.top_banner {
|
.top_banner {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
img {
|
img {
|
||||||
|
|||||||
@@ -93,7 +93,7 @@
|
|||||||
<span v-if="orderDetailInfo.driverName && orderDetailInfo.proprietary?.code==1" class="driverPoiBtn" @click="noMultipleClicks(createDriverInfo)">生成司机信息</span>
|
<span v-if="orderDetailInfo.driverName && orderDetailInfo.proprietary?.code==1" class="driverPoiBtn" @click="noMultipleClicks(createDriverInfo)">生成司机信息</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="item" v-if="queryType == 9 || queryType ==11 || queryType ==12 || queryType ==5">
|
<div class="item" v-if="queryType == 9 || queryType ==11 || queryType ==12">
|
||||||
<span class="leftTitle fontColor">工单照片:</span><span class="rightContent">
|
<span class="leftTitle fontColor">工单照片:</span><span class="rightContent">
|
||||||
<span class="driverPoiBtn" @click="checkPhoto">查看照片</span>
|
<span class="driverPoiBtn" @click="checkPhoto">查看照片</span>
|
||||||
</span>
|
</span>
|
||||||
@@ -184,8 +184,12 @@ export default {
|
|||||||
})
|
})
|
||||||
if(result.data){
|
if(result.data){
|
||||||
// console.log('--result--',result.data)
|
// console.log('--result--',result.data)
|
||||||
let params=`姓名:${this.orderDetailInfo.driverName}\n身份证:${result.data.identityCardNumber}\n车牌:${this.orderDetailInfo.vehiclePlateNumber}\n手机:${this.orderDetailInfo.driverPhone}`
|
let params={
|
||||||
// console.log('params',params)
|
'姓名:':this.orderDetailInfo.driverName,
|
||||||
|
'身份证:':result.data.identityCardNumber,
|
||||||
|
'车牌:':this.orderDetailInfo.vehiclePlateNumber,
|
||||||
|
'手机:':this.orderDetailInfo.driverPhone,
|
||||||
|
}
|
||||||
let data = {"action":"copyToClipboard","params":params}
|
let data = {"action":"copyToClipboard","params":params}
|
||||||
var u = navigator.userAgent;
|
var u = navigator.userAgent;
|
||||||
var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);
|
var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);
|
||||||
|
|||||||
@@ -263,7 +263,6 @@ import {
|
|||||||
getDriverName,getDriverStatisticsKpi,
|
getDriverName,getDriverStatisticsKpi,
|
||||||
getRecentSupplierKpi,
|
getRecentSupplierKpi,
|
||||||
} from "@/api/kpi.js"
|
} from "@/api/kpi.js"
|
||||||
import { getUserBO } from "@/api/order"
|
|
||||||
// querySupplierDriverStatisticsScore
|
// querySupplierDriverStatisticsScore
|
||||||
import {myMixins} from "@/utils/myMixins"
|
import {myMixins} from "@/utils/myMixins"
|
||||||
import CircleChar from "@/views/kpi/components/circleChar.vue";
|
import CircleChar from "@/views/kpi/components/circleChar.vue";
|
||||||
@@ -331,10 +330,6 @@ export default {
|
|||||||
showScoreChart:true,
|
showScoreChart:true,
|
||||||
continueMonthKpi:[],
|
continueMonthKpi:[],
|
||||||
isBtn:false,//是否有信息变更申请按钮权限
|
isBtn:false,//是否有信息变更申请按钮权限
|
||||||
source: 'App',
|
|
||||||
currentSupplierId: '',
|
|
||||||
userId: '',
|
|
||||||
enterTime: dayjs().format('YYYY-MM-DD HH:mm:ss'),
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
@@ -343,41 +338,13 @@ export default {
|
|||||||
this.isZd = urlParams?.get('isZd') || ''
|
this.isZd = urlParams?.get('isZd') || ''
|
||||||
this.supplierId = urlParams?.get('supplierId') || ''
|
this.supplierId = urlParams?.get('supplierId') || ''
|
||||||
this.isBtn= Number(urlParams?.get('isBtn'))
|
this.isBtn= Number(urlParams?.get('isBtn'))
|
||||||
this.source = urlParams?.get('source') || 'App'
|
|
||||||
},
|
},
|
||||||
async mounted() {
|
async mounted() {
|
||||||
await this.checkMobile();
|
await this.checkMobile();
|
||||||
await this.initDate();
|
await this.initDate();
|
||||||
await this.selectSupplierNameHandle();
|
await this.selectSupplierNameHandle();
|
||||||
await this.getUserInfo();
|
|
||||||
document.addEventListener('visibilitychange', async ( ) => {
|
|
||||||
let state = document.visibilityState
|
|
||||||
if (state == 'hidden') { // 用户离开了
|
|
||||||
if( this.source == 'App' ) {
|
|
||||||
this.setLogHandler({
|
|
||||||
supplierId: this.currentSupplierId, // 服务商 id
|
|
||||||
userId: this.userId, // userId
|
|
||||||
source: '服务商KPI',
|
|
||||||
event: this.source, // 区分 App 还是 system
|
|
||||||
openTime: this.enterTime, // log 时间,其中 阅读时长是由 enter 和 leave 的时间计算而来
|
|
||||||
leaveTime: dayjs().format('YYYY-MM-DD HH:mm:ss'),
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (state == 'visible') {
|
|
||||||
this.enterTime = dayjs().format('YYYY-MM-DD HH:mm:ss');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
async getUserInfo() {
|
|
||||||
let res = await getUserBO();
|
|
||||||
this.userId = res.data.id;
|
|
||||||
this.currentSupplierId = res.data.supplierId
|
|
||||||
console.log('getUserBO', res)
|
|
||||||
},
|
|
||||||
applicateHandle() {
|
applicateHandle() {
|
||||||
if (window.parent) {
|
if (window.parent) {
|
||||||
const hasListener = window.parent.dispatchEvent(new Event('checkCloseDialog'));
|
const hasListener = window.parent.dispatchEvent(new Event('checkCloseDialog'));
|
||||||
|
|||||||
@@ -13,20 +13,23 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="contentWrap">
|
<div class="contentWrap">
|
||||||
<div>
|
<div>
|
||||||
为降低日常救援工作中的不可预期的车损赔付带来的运营风险和资金压力,减少由此衍生而来的投诉,顺应行业服务标准不断增长的局势,中道救援自有车辆已全部投保了救援职业责任险。
|
为降低日常救援工作中的不可预期的车损赔付带来的运营风险和资金压力,减少由此衍生而来的可能投诉,顺应行业服务标准不断增长的局势,中道救援自有车辆已全部投保了救援职业责任险。
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
通过交流了解,我们的合作服务商日常运营中会遇到责任险或者货物险的“投保难、理赔难”的问题,为此我们与保司沟通协调,特为与中道救援合作紧密的服务商,提供救援职业责任险参保渠道,解决大家的实际困难,实现共同进步。
|
通过日常的交流了解,此险种对于服务商而言,投保相对较难,很多服务商在无投保渠道的情况下选择了对于我们救援场景保障能力稍弱、不太匹配的货物险,从而从形成了现在很多救援车无保障、或者特殊场景货物险理赔难的局面。
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
为此中道救援经过与保司沟通协调,特为与中道救援合作紧密的服务商,提供救援职业责任险参保渠道,提升服务商服务能力,降低运营风险,实现共同进步。
|
||||||
</div>
|
</div>
|
||||||
<div>一、救援职业责任险简介:</div>
|
<div>一、救援职业责任险简介:</div>
|
||||||
<div> 1、保额有50万和100万两套方案可选。</div>
|
<div> 1、综合保额100万元(其中救援责任50万元,物流责任50万元),可全方位覆盖我们日常的经营活动。</div>
|
||||||
<div> 2、保费支付可采用救援服务费抵扣的方式,降低资金压力。</div>
|
<div> 2、保费支付可采用救援服务费抵扣的方式,降低资金压力。</div>
|
||||||
<div> 3、其他详情如需了解,请与辖区区域经理联系。</div>
|
<div> 3、详细保险条款、保费和其他问题,如需了解,请与辖区区域经理联系。</div>
|
||||||
<div> 二、如有好的建议需要交流,请与18621558505曲仁杰联系。</div>
|
<div> 二、其他意见建议如需交流,请与18621558505曲仁杰联系。</div>
|
||||||
<div> 三、如有参保需要,请点击下方“参保”按钮,我们会与您联系。</div>
|
<div> 三、如确认参保,请点击下方“参保”按钮,会有专人与贵司联系。</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="upload_btn_wrap">
|
<div class="upload_btn_wrap">
|
||||||
<div class="btn_save" :style="{'backgroundColor':used ? '#cccccc' : '#354D93'}" @click="showPoup = true">我想咨询</div>
|
<div class="btn_save" :style="{'backgroundColor':used ? '#cccccc' : '#354D93'}" @click="showPoup = true">参保</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="poupCommon" v-if="showPoup">
|
<div class="poupCommon" v-if="showPoup">
|
||||||
<div class="showPoupContainer">
|
<div class="showPoupContainer">
|
||||||
@@ -34,10 +37,12 @@
|
|||||||
<img class="insure" src="@/assets/insured.png">
|
<img class="insure" src="@/assets/insured.png">
|
||||||
<div class="con">
|
<div class="con">
|
||||||
<template v-if="used">
|
<template v-if="used">
|
||||||
<div class="title">咨询已收到,我们会与您联系。</div>
|
<div class="title">您已成功申请参保,请等待</div>
|
||||||
|
<div class="title">专人与贵司联系。</div>
|
||||||
</template>
|
</template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<div class="title">请确认咨询</div>
|
<div class="title">请确认</div>
|
||||||
|
<div class="title">是否参保救援职业责任险</div>
|
||||||
</template>
|
</template>
|
||||||
<div class="btnWrap">
|
<div class="btnWrap">
|
||||||
<div v-if="used" class="btn confirmBtn" @click="showPoup = false">确认</div>
|
<div v-if="used" class="btn confirmBtn" @click="showPoup = false">确认</div>
|
||||||
|
|||||||
@@ -54,11 +54,6 @@
|
|||||||
<span
|
<span
|
||||||
class="content">{{ orderInfo.carClothingToolAmount }}</span>
|
class="content">{{ orderInfo.carClothingToolAmount }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="item">
|
|
||||||
<span class="titleLeft">免拖:</span>
|
|
||||||
<span
|
|
||||||
class="content">{{ orderInfo.customerDistanceLimit }} {{orderInfo.hedgingMileage && orderInfo.hedgingMileage > 0 ? '(超限对冲,只结免拖)' : ''}}</span>
|
|
||||||
</div>
|
|
||||||
<div class="item">
|
<div class="item">
|
||||||
<span class="titleLeft">换电瓶费用:</span>
|
<span class="titleLeft">换电瓶费用:</span>
|
||||||
<span
|
<span
|
||||||
@@ -77,35 +72,35 @@
|
|||||||
<div class="inpInfo">
|
<div class="inpInfo">
|
||||||
<div class="titleContent">
|
<div class="titleContent">
|
||||||
<div class="flex-between" v-show="abState">
|
<div class="flex-between" v-show="abState">
|
||||||
<div><span style="color: red;">*</span> 到事发地距离:</div>
|
<div> 到事发地距离:</div>
|
||||||
<div class="halfOpcity"><input @input="validateIntegerInput" class="ipt" type="number" v-model="form.supplierSettleMileageAb"/>公里</div>
|
<div class="halfOpcity"><input @input="validateIntegerInput" class="ipt" type="number" v-model="form.supplierSettleMileageAb"/>公里</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="bcState">
|
<div class="flex-between" v-show="bcState">
|
||||||
<div><span style="color: red;">*</span> 拖车里程:</div>
|
<div> 拖车里程:</div>
|
||||||
<div class="halfOpcity"><input class="ipt" type="number" v-model="form.supplierSettleMileageBc"/>公里</div>
|
<div class="halfOpcity"><input class="ipt" type="number" v-model="form.supplierSettleMileageBc"/>公里</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="caState">
|
<div class="flex-between" v-show="caState">
|
||||||
<div><span style="color: red;">*</span>返程里程:</div>
|
<div>返程里程:</div>
|
||||||
<div class="halfOpcity"><input class="ipt" type="number" v-model="form.supplierSettleMileageCa"/>公里</div>
|
<div class="halfOpcity"><input class="ipt" type="number" v-model="form.supplierSettleMileageCa"/>公里</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="bridgeAbState">
|
<div class="flex-between" v-show="bridgeAbState">
|
||||||
<div><span v-show="!isUnsuccessfulSettle" style="color: red;">*</span>ab路桥费:</div>
|
<div>ab路桥费:</div>
|
||||||
<div class="halfOpcity"><input class="ipt" @input="validateIntegerInput" :disabled="isUnsuccessfulSettle" type="number" v-model="form.supplierBridgeAmountAb"/>元</div>
|
<div class="halfOpcity"><input class="ipt" @input="validateIntegerInput" :disabled="isUnsuccessfulSettle" type="number" v-model="form.supplierBridgeAmountAb"/>元</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="bridgeBcState">
|
<div class="flex-between" v-show="bridgeBcState">
|
||||||
<div><span v-show="!isUnsuccessfulSettle" style="color: red;">*</span>bc路桥费:</div>
|
<div>bc路桥费:</div>
|
||||||
<div class="halfOpcity"><input class="ipt" @input="validateIntegerInput" :disabled="isUnsuccessfulSettle" type="number" v-model="form.supplierBridgeAmountBc"/>元</div>
|
<div class="halfOpcity"><input class="ipt" @input="validateIntegerInput" :disabled="isUnsuccessfulSettle" type="number" v-model="form.supplierBridgeAmountBc"/>元</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="bridgeCaState">
|
<div class="flex-between" v-show="bridgeCaState">
|
||||||
<div><span v-show="!isUnsuccessfulSettle" style="color: red;">*</span>ca路桥费:</div>
|
<div>ca路桥费:</div>
|
||||||
<div class="halfOpcity"><input class="ipt" @input="validateIntegerInput" :disabled="isUnsuccessfulSettle" type="number" v-model="form.supplierBridgeAmountCa"/>元</div>
|
<div class="halfOpcity"><input class="ipt" @input="validateIntegerInput" :disabled="isUnsuccessfulSettle" type="number" v-model="form.supplierBridgeAmountCa"/>元</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="waitAmountState">
|
<div class="flex-between" v-show="waitAmountState">
|
||||||
<div><span style="color: red;">*</span>等候费:</div>
|
<div>等候费:</div>
|
||||||
<div class="halfOpcity inputContent"><input class="ipt" @input="validateIntegerInput" type="number" v-model="form.supplierWaitAmount"/>元</div>
|
<div class="halfOpcity inputContent"><input class="ipt" @input="validateIntegerInput" type="number" v-model="form.supplierWaitAmount"/>元</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="tyreAmountState">
|
<div class="flex-between" v-show="tyreAmountState">
|
||||||
<div><span v-show="!isUnsuccessfulSettle" style="color: red;">*</span>小轮个数:</div>
|
<div>小轮个数:</div>
|
||||||
<div class="halfOpcity inputContent"><input class="ipt" @input="validateIntegerInput" :disabled="isUnsuccessfulSettle" type="number" v-model="form.tyreNumber"/>个</div>
|
<div class="halfOpcity inputContent"><input class="ipt" @input="validateIntegerInput" :disabled="isUnsuccessfulSettle" type="number" v-model="form.tyreNumber"/>个</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="tyreAmountState">
|
<div class="flex-between" v-show="tyreAmountState">
|
||||||
@@ -113,11 +108,11 @@
|
|||||||
<div class="halfOpcity inputContent"><input @input="validateIntegerInput" disabled type="number" v-model="form.supplierTyreAmount"/>元</div>
|
<div class="halfOpcity inputContent"><input @input="validateIntegerInput" disabled type="number" v-model="form.supplierTyreAmount"/>元</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="dilemmaAmountState && basePriceDisabled">
|
<div class="flex-between" v-show="dilemmaAmountState && basePriceDisabled">
|
||||||
<div><span style="color: red;">*</span>困境费:</div>
|
<div>困境费:</div>
|
||||||
<div class="halfOpcity inputContent"><input class="ipt" @input="validateIntegerInput" type="number" v-model="form.supplierDilemmaAmount"/>元</div>
|
<div class="halfOpcity inputContent"><input class="ipt" @input="validateIntegerInput" type="number" v-model="form.supplierDilemmaAmount"/>元</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between" v-show="basementFeeState">
|
<div class="flex-between" v-show="basementFeeState">
|
||||||
<div><span v-show="isBasementSettle && !isUnsuccessfulSettle" style="color: red;">*</span>地库费:</div>
|
<div>地库费:</div>
|
||||||
<div class="halfOpcity inputContent"><input @input="validateIntegerInput" class="ipt" type="number" v-model="form.supplierBasementFee" :disabled="!isBasementSettle || isUnsuccessfulSettle" />元</div>
|
<div class="halfOpcity inputContent"><input @input="validateIntegerInput" class="ipt" type="number" v-model="form.supplierBasementFee" :disabled="!isBasementSettle || isUnsuccessfulSettle" />元</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between">
|
<div class="flex-between">
|
||||||
@@ -125,7 +120,7 @@
|
|||||||
<div class="halfOpcity inputContent"><input type="number" class="ipt" v-model="form.supplierCustomerAmount"/>元</div>
|
<div class="halfOpcity inputContent"><input type="number" class="ipt" v-model="form.supplierCustomerAmount"/>元</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-between bgDisable" :class=" { 'flex-between': true, 'bgDisable' : basePriceDisabled } ">
|
<div class="flex-between bgDisable" :class=" { 'flex-between': true, 'bgDisable' : basePriceDisabled } ">
|
||||||
<div><span v-show="!basePriceDisabled && !isBasementSettle" style="color: red;">*</span>基本费用:</div>
|
<div>基本费用:</div>
|
||||||
<div class="halfOpcity inputContent "><input class="disable" type="number" :readonly="basePriceDisabled || isBasementSettle"
|
<div class="halfOpcity inputContent "><input class="disable" type="number" :readonly="basePriceDisabled || isBasementSettle"
|
||||||
v-model="form.supplierBasePrice"/><span>元</span></div>
|
v-model="form.supplierBasePrice"/><span>元</span></div>
|
||||||
</div>
|
</div>
|
||||||
@@ -507,7 +502,6 @@ export default {
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
async compute() {
|
async compute() {
|
||||||
alert(11111)
|
|
||||||
if(this.orderInfo.contractSettleTypeString == '车主现收'){
|
if(this.orderInfo.contractSettleTypeString == '车主现收'){
|
||||||
this.form.supplierBasePrice = 0
|
this.form.supplierBasePrice = 0
|
||||||
this.form.supplierExtraPrice = 0
|
this.form.supplierExtraPrice = 0
|
||||||
@@ -663,49 +657,6 @@ export default {
|
|||||||
this.goback()
|
this.goback()
|
||||||
},
|
},
|
||||||
async save() {
|
async save() {
|
||||||
const isBlank = (v) => v === '' || v === null || v === undefined || parseFloat(v) < 0
|
|
||||||
if (this.abState && isBlank(this.form.supplierSettleMileageAb)) {
|
|
||||||
this.$toast('请填写到事发地距离'); return;
|
|
||||||
}
|
|
||||||
if (this.bcState && isBlank(this.form.supplierSettleMileageBc)) {
|
|
||||||
this.$toast('请填写拖车里程'); return;
|
|
||||||
}
|
|
||||||
if (this.caState && isBlank(this.form.supplierSettleMileageCa)) {
|
|
||||||
this.$toast('请填写返程里程'); return;
|
|
||||||
}
|
|
||||||
if (this.bridgeAbState && !this.isUnsuccessfulSettle && isBlank(this.form.supplierBridgeAmountAb)) {
|
|
||||||
this.$toast('请填写ab路桥费'); return;
|
|
||||||
}
|
|
||||||
if (this.bridgeBcState && !this.isUnsuccessfulSettle && isBlank(this.form.supplierBridgeAmountBc)) {
|
|
||||||
this.$toast('请填写bc路桥费'); return;
|
|
||||||
}
|
|
||||||
if (this.bridgeCaState && !this.isUnsuccessfulSettle && isBlank(this.form.supplierBridgeAmountCa)) {
|
|
||||||
this.$toast('请填写ca路桥费'); return;
|
|
||||||
}
|
|
||||||
if (this.waitAmountState && isBlank(this.form.supplierWaitAmount)) {
|
|
||||||
this.$toast('请填写等候费'); return;
|
|
||||||
}
|
|
||||||
if (!this.auditFormShow && this.tyreAmountState && !this.isUnsuccessfulSettle && isBlank(this.form.tyreNumber)) {
|
|
||||||
this.$toast('请填写小轮个数'); return;
|
|
||||||
}
|
|
||||||
if (this.dilemmaAmountState && this.basePriceDisabled && isBlank(this.form.supplierDilemmaAmount)) {
|
|
||||||
this.$toast('请填写困境费'); return;
|
|
||||||
}
|
|
||||||
if (this.basementFeeState && this.isBasementSettle && !this.isUnsuccessfulSettle && isBlank(this.form.supplierBasementFee)) {
|
|
||||||
this.$toast('请填写地库费'); return;
|
|
||||||
}
|
|
||||||
if (!this.basePriceDisabled && !this.isBasementSettle && isBlank(this.form.supplierBasePrice)) {
|
|
||||||
this.$toast('请填写基本费用'); return;
|
|
||||||
}
|
|
||||||
if (
|
|
||||||
this.orderInfo.customerDistanceLimit &&
|
|
||||||
parseFloat(this.form.supplierSettleMileageBc) > parseFloat(this.orderInfo.customerDistanceLimit)
|
|
||||||
) {
|
|
||||||
if (!this.form.supplierCustomerAmount || parseFloat(this.form.supplierCustomerAmount) == 0) {
|
|
||||||
this.$toast('拖车里程超出免拖范围,请填写收取客户金额');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (this.form.supplierOtherAmount > 0) {
|
if (this.form.supplierOtherAmount > 0) {
|
||||||
if (this.form.supplierOtherAmountRemark == '') {
|
if (this.form.supplierOtherAmountRemark == '') {
|
||||||
this.$toast('请填写其他费用说明');
|
this.$toast('请填写其他费用说明');
|
||||||
@@ -743,7 +694,6 @@ export default {
|
|||||||
await this.compute();
|
await this.compute();
|
||||||
const formData = new FormData();
|
const formData = new FormData();
|
||||||
let obj = this.form;
|
let obj = this.form;
|
||||||
console.log('obj',obj)
|
|
||||||
Object.keys(obj).forEach((key) => {
|
Object.keys(obj).forEach((key) => {
|
||||||
formData.append(key, obj[key]);
|
formData.append(key, obj[key]);
|
||||||
});
|
});
|
||||||
@@ -754,7 +704,7 @@ export default {
|
|||||||
formData.append('state', 0);
|
formData.append('state', 0);
|
||||||
formData.append('postfix', this.postfix);
|
formData.append('postfix', this.postfix);
|
||||||
formData.append('supplierBridgeAmount', parseInt(this.form.supplierBridgeAmountAb || 0) + parseInt(this.form.supplierBridgeAmountBc || 0) + parseInt(this.form.supplierBridgeAmountCa || 0));
|
formData.append('supplierBridgeAmount', parseInt(this.form.supplierBridgeAmountAb || 0) + parseInt(this.form.supplierBridgeAmountBc || 0) + parseInt(this.form.supplierBridgeAmountCa || 0));
|
||||||
/*let res = await updateAccountRecordInfo(formData);
|
let res = await updateAccountRecordInfo(formData);
|
||||||
if (res.code === 200) {
|
if (res.code === 200) {
|
||||||
this.$toast('操作成功')
|
this.$toast('操作成功')
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
@@ -767,7 +717,7 @@ export default {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
}, 2000)
|
}, 2000)
|
||||||
}*/
|
}
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
},
|
},
|
||||||
async confirmAudit() {
|
async confirmAudit() {
|
||||||
@@ -775,45 +725,6 @@ export default {
|
|||||||
this.$toast('已进入后续流程,不允许操作');
|
this.$toast('已进入后续流程,不允许操作');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const isBlank = (v) => v === '' || v === null || v === undefined || parseFloat(v) < 0
|
|
||||||
if (this.abState && isBlank(this.form.supplierSettleMileageAb)) {
|
|
||||||
this.$toast('请填写到事发地距离'); return;
|
|
||||||
}
|
|
||||||
if (this.bcState && isBlank(this.form.supplierSettleMileageBc)) {
|
|
||||||
this.$toast('请填写拖车里程'); return;
|
|
||||||
}
|
|
||||||
if (this.caState && isBlank(this.form.supplierSettleMileageCa)) {
|
|
||||||
this.$toast('请填写返程里程'); return;
|
|
||||||
}
|
|
||||||
if (this.bridgeAbState && !this.isUnsuccessfulSettle && isBlank(this.form.supplierBridgeAmountAb)) {
|
|
||||||
this.$toast('请填写ab路桥费'); return;
|
|
||||||
}
|
|
||||||
if (this.bridgeBcState && !this.isUnsuccessfulSettle && isBlank(this.form.supplierBridgeAmountBc)) {
|
|
||||||
this.$toast('请填写bc路桥费'); return;
|
|
||||||
}
|
|
||||||
if (this.bridgeCaState && !this.isUnsuccessfulSettle && isBlank(this.form.supplierBridgeAmountCa)) {
|
|
||||||
this.$toast('请填写ca路桥费'); return;
|
|
||||||
}
|
|
||||||
if (this.waitAmountState && isBlank(this.form.supplierWaitAmount)) {
|
|
||||||
this.$toast('请填写等候费'); return;
|
|
||||||
}
|
|
||||||
if (this.dilemmaAmountState && this.basePriceDisabled && isBlank(this.form.supplierDilemmaAmount)) {
|
|
||||||
this.$toast('请填写困境费'); return;
|
|
||||||
}
|
|
||||||
if (this.basementFeeState && this.isBasementSettle && !this.isUnsuccessfulSettle && isBlank(this.form.supplierBasementFee)) {
|
|
||||||
this.$toast('请填写地库费'); return;
|
|
||||||
}
|
|
||||||
if (!this.basePriceDisabled && !this.isBasementSettle && isBlank(this.form.supplierBasePrice)) {
|
|
||||||
this.$toast('请填写基本费用'); return;
|
|
||||||
}
|
|
||||||
if (
|
|
||||||
this.orderInfo.customerDistanceLimit &&
|
|
||||||
parseFloat(this.form.supplierSettleMileageBc) > parseFloat(this.orderInfo.customerDistanceLimit)
|
|
||||||
) {
|
|
||||||
if (!this.form.supplierCustomerAmount || parseFloat(this.form.supplierCustomerAmount) == 0) {
|
|
||||||
this.$toast('拖车里程超出免拖范围,请填写收取客户金额'); return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this.loading1 = true;
|
this.loading1 = true;
|
||||||
this.form.supplierExtraPrice = this.form.extraPrice || 0
|
this.form.supplierExtraPrice = this.form.extraPrice || 0
|
||||||
this.form.supplierBasePrice = this.form.basePrice || 0
|
this.form.supplierBasePrice = this.form.basePrice || 0
|
||||||
@@ -849,7 +760,7 @@ export default {
|
|||||||
formData.append('state', 0);
|
formData.append('state', 0);
|
||||||
formData.append('postfix', this.postfix);
|
formData.append('postfix', this.postfix);
|
||||||
formData.append('supplierBridgeAmount', parseInt(this.form.supplierBridgeAmountAb || 0) + parseInt(this.form.supplierBridgeAmountBc || 0) + parseInt(this.form.supplierBridgeAmountCa || 0));
|
formData.append('supplierBridgeAmount', parseInt(this.form.supplierBridgeAmountAb || 0) + parseInt(this.form.supplierBridgeAmountBc || 0) + parseInt(this.form.supplierBridgeAmountCa || 0));
|
||||||
/*let res = await updateAccountRecordInfo(formData);
|
let res = await updateAccountRecordInfo(formData);
|
||||||
if (res.code === 200) {
|
if (res.code === 200) {
|
||||||
this.$toast('操作成功')
|
this.$toast('操作成功')
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
@@ -862,7 +773,7 @@ export default {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
}, 2000)
|
}, 2000)
|
||||||
}*/
|
}
|
||||||
this.loading1 = false;
|
this.loading1 = false;
|
||||||
},
|
},
|
||||||
|
|
||||||
@@ -1031,7 +942,7 @@ img {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.baseInfo {
|
.baseInfo {
|
||||||
width: 100%;
|
@include wh(100%, 344px);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user