Compare commits
50 Commits
prod-26-03
...
dev-2026
| Author | SHA1 | Date | |
|---|---|---|---|
| 1addd5112b | |||
| cd51aec32a | |||
| 4a2513e100 | |||
| 7c40fbc4c5 | |||
| 336bb11c42 | |||
| 4aae54f9a5 | |||
| 57f839166e | |||
| e4757849dd | |||
| 61e8418459 | |||
| 80c15dcf1b | |||
| 8a053c5a80 | |||
| d5d777afd3 | |||
| 0483c2d0a7 | |||
| 3c1f238163 | |||
| 384a64b2c8 | |||
| c55f6b4045 | |||
| 0b4127a0e2 | |||
| 2970dca3e0 | |||
| 15d5c4694e | |||
| 1f7ce0da6d | |||
| 2bd56d8a9e | |||
| 0b388414c9 | |||
| b0b1abca01 | |||
| 4fdcd3e72e | |||
| 424ef98798 | |||
| 37aeba20da | |||
| a9382c11a4 | |||
| 4b94c614ad | |||
| b39ae0bdf1 | |||
| 709f125c42 | |||
| a0c1a2700a | |||
| 8c25f5a195 | |||
| ee50c3ba19 | |||
| 1477f94774 | |||
| 35fd987f00 | |||
| b6491a21d1 | |||
| 030417ba9c | |||
| c05bdb361b | |||
| e288d1e180 | |||
| a48e73bdb5 | |||
| 56a8ba66b7 | |||
| 8c62b8e704 | |||
| f1a3f7b45b | |||
| e7344a1f16 | |||
| 75dd0b9740 | |||
| aa5b724bed | |||
| ca99e068cf | |||
| aafd7ffdb5 | |||
| 112f42669c | |||
| 9bf8e1253d |
@@ -72,10 +72,12 @@ export function vehicleTypeList(){
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
// 服务商服务能力
|
// 服务商服务能力
|
||||||
export function supplierServiceTree(){
|
export function supplierServiceTree(data){
|
||||||
|
console.log('ddddddd0', data)
|
||||||
return request({
|
return request({
|
||||||
url:'/supplierAppV2/dispatchApp/user/supplierServiceTree',
|
url:'/supplierAppV2/dispatchApp/user/supplierServiceTree',
|
||||||
method:'POST'
|
method:'POST',
|
||||||
|
data
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -115,6 +117,15 @@ export function getSupplierInfo(key){
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 根据id查询潜在服务商
|
||||||
|
export function supplierSelectById(params){
|
||||||
|
return request({
|
||||||
|
url:'/supplier/potential/supplierSelectById',
|
||||||
|
method:'GET',
|
||||||
|
params
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
// 获取企微二维码
|
// 获取企微二维码
|
||||||
export function getOrCodeInfo(data){
|
export function getOrCodeInfo(data){
|
||||||
return request({
|
return request({
|
||||||
@@ -133,6 +144,15 @@ export function getContactQrCodeResult(data){
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 添加企微
|
||||||
|
export function updateWechatId(data){
|
||||||
|
return request({
|
||||||
|
url:'/supplier/potential/updateWechatId',
|
||||||
|
method:'POST',
|
||||||
|
data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
//司机列表
|
//司机列表
|
||||||
export function driverList(data){
|
export function driverList(data){
|
||||||
return request({
|
return request({
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ export function toDoAudit(data){
|
|||||||
data
|
data
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
// 工单详情
|
//
|
||||||
export function getOrderDetail(data){
|
export function getOrderDetail(data){
|
||||||
return request({
|
return request({
|
||||||
url:'/supplierAppV2/dispatchApp/order/getOrderDetail',
|
url:'/supplierAppV2/dispatchApp/order/getOrderDetail',
|
||||||
@@ -177,3 +177,23 @@ 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',
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -54,7 +54,7 @@ export function userFeedback(data){
|
|||||||
data
|
data
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
//二手拖车信息擦亮
|
//擦亮
|
||||||
export function usedCarPolish(data){
|
export function usedCarPolish(data){
|
||||||
return request({
|
return request({
|
||||||
url: `/toc-user/car-app/usedCarPolish/${data}`,
|
url: `/toc-user/car-app/usedCarPolish/${data}`,
|
||||||
|
|||||||
@@ -27,6 +27,14 @@ const routes = [
|
|||||||
title: '审核中',
|
title: '审核中',
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: '/addWechat',
|
||||||
|
name: 'addWechat',
|
||||||
|
component: () => import('@/views/index/addWechat'),
|
||||||
|
meta:{
|
||||||
|
title: '添加微信',
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
path: '/supplierInfo',
|
path: '/supplierInfo',
|
||||||
name: 'supplierInfo',
|
name: 'supplierInfo',
|
||||||
@@ -329,7 +337,7 @@ const routes = [
|
|||||||
name: 'goToApp',
|
name: 'goToApp',
|
||||||
component:()=>import('@/views/goToApp/goToApp.vue'),
|
component:()=>import('@/views/goToApp/goToApp.vue'),
|
||||||
meta: {
|
meta: {
|
||||||
title:'电瓶详情'
|
title:'中道小板运输'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
...kpiRouter,
|
...kpiRouter,
|
||||||
|
|||||||
@@ -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' && config?.params?.type==1){
|
if ((reqUrl=='/supplier/supplierTraining/trainingList' || reqUrl=='/supplier/supplierTraining/normalList') && config?.params?.type==1){
|
||||||
console.log('司机app使用该请求不挂token')
|
console.log('司机app使用该请求不挂token')
|
||||||
} else {
|
} else {
|
||||||
if(token) {
|
if(token) {
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
import { getLog } from "@/api/order"
|
||||||
|
|
||||||
|
let _setLogTimer = null
|
||||||
|
|
||||||
export const myMixins = {
|
export const myMixins = {
|
||||||
data() {
|
data() {
|
||||||
@@ -5,6 +8,11 @@ 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()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
180
src/views/index/addWechat.vue
Normal file
180
src/views/index/addWechat.vue
Normal file
@@ -0,0 +1,180 @@
|
|||||||
|
<template>
|
||||||
|
<div class="wrap">
|
||||||
|
<div class="top-wrap"></div>
|
||||||
|
<div class="center-info">
|
||||||
|
<div class="wei_code_wrap">
|
||||||
|
<div class="wei_title">请先添加企业微信,保证申请流程正常进行。</div>
|
||||||
|
<div class="wei_code_bg">
|
||||||
|
<img v-if="qrCodeUrl" :src="qrCodeUrl" alt="企业微信二维码" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="btn_wrap">
|
||||||
|
<div class="btn" @click="nextStep">下一步</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import QRCode from 'qrcode'
|
||||||
|
import {getOrCodeInfo, getContactQrCodeResult, saveSupplier} from "@/api/mine"
|
||||||
|
import {myMixins} from "@/utils/myMixins"
|
||||||
|
import {Toast, Dialog} from "vant";
|
||||||
|
export default {
|
||||||
|
name: "addWechat",
|
||||||
|
mixins: [myMixins],
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
name: '',
|
||||||
|
potentialFlag: '',
|
||||||
|
formPayload: null,
|
||||||
|
qrCodeUrl: '',
|
||||||
|
qrCode: '',
|
||||||
|
configId: '',
|
||||||
|
wechatId: '',
|
||||||
|
clickFlag: true,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
async mounted() {
|
||||||
|
const urlParams = new URLSearchParams(window.location.search);
|
||||||
|
this.potentialFlag = this.$route.query.potentialFlag || urlParams.get('potentialFlag') || '';
|
||||||
|
const cached = localStorage.getItem('supplierAddForm');
|
||||||
|
if (cached) {
|
||||||
|
this.formPayload = JSON.parse(cached);
|
||||||
|
this.name = this.formPayload.name;
|
||||||
|
}
|
||||||
|
if (this.name) {
|
||||||
|
await this.QrCodeHandler();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
async QrCodeHandler() {
|
||||||
|
await this.QrCodeInfo();
|
||||||
|
await this.getQrCode();
|
||||||
|
},
|
||||||
|
async QrCodeInfo() {
|
||||||
|
let res = await getOrCodeInfo({ name: this.name });
|
||||||
|
this.configId = res?.configId;
|
||||||
|
this.qrCode = res?.qrCode;
|
||||||
|
},
|
||||||
|
async getQrCode() {
|
||||||
|
try {
|
||||||
|
this.qrCodeUrl = await QRCode.toDataURL(this.qrCode, {
|
||||||
|
width: 150,
|
||||||
|
margin: 2,
|
||||||
|
color: { dark: '#000000', light: '#FFFFFF' },
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error('生成二维码失败:', error);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
async nextStep() {
|
||||||
|
if (!this.clickFlag) return;
|
||||||
|
let res = await getContactQrCodeResult({ configId: this.configId });
|
||||||
|
this.wechatId = res?.data?.wechatId;
|
||||||
|
if (!this.wechatId) {
|
||||||
|
Toast('请先添加企微再继续');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
this.clickFlag = false;
|
||||||
|
const res = await saveSupplier({
|
||||||
|
...this.formPayload,
|
||||||
|
wechatId: this.wechatId,
|
||||||
|
});
|
||||||
|
if (res?.noToast) {
|
||||||
|
if (res?.code != 0) {
|
||||||
|
Dialog.alert({ title: '提示', message: '该服务商已存在,查看信息' }).then(() => {
|
||||||
|
localStorage.removeItem('supplierAddForm');
|
||||||
|
const target = { name: 'supplierInfo', query: { id: res?.code, potentialFlag: this.potentialFlag } };
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify(target));
|
||||||
|
this.goPage('supplierInfo', { id: res?.code, potentialFlag: this.potentialFlag });
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
Toast('该服务商已存在');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
localStorage.removeItem('supplierAddForm');
|
||||||
|
const supplierId = res?.data;
|
||||||
|
const potentialFlag = this.potentialFlag;
|
||||||
|
const target = { name: 'supplierAddResult', query: { id: supplierId, potentialFlag } };
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify(target));
|
||||||
|
Dialog.confirm({
|
||||||
|
title: '提示',
|
||||||
|
message: '添加车辆和驾驶员会加快审核进度,是否去添加?',
|
||||||
|
confirmButtonText: '去添加',
|
||||||
|
cancelButtonText: '取消',
|
||||||
|
}).then(() => {
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify({ name: 'vehicleManage', query: { id: supplierId, potentialFlag } }));
|
||||||
|
this.goPage('vehicleManage', { id: supplierId, potentialFlag });
|
||||||
|
}).catch(() => {
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify({ name: 'supplierAddResult', query: { id: supplierId, potentialFlag } }));
|
||||||
|
this.goPage('supplierAddResult', { id: supplierId, potentialFlag });
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
Toast(e?.message || '提交失败');
|
||||||
|
} finally {
|
||||||
|
setTimeout(() => { this.clickFlag = true; }, 1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
@import "@/styles/mixin.scss";
|
||||||
|
@import "@/styles/common.scss";
|
||||||
|
.wrap {
|
||||||
|
@include wh(100%, 100%);
|
||||||
|
box-sizing: border-box;
|
||||||
|
padding-bottom: 100px;
|
||||||
|
overflow-y: auto;
|
||||||
|
background: linear-gradient(180deg, #FBFDFE 0%, #F6FBFF 73%, #F0F7FF 100%);
|
||||||
|
backdrop-filter: blur(5.602678571428572px);
|
||||||
|
}
|
||||||
|
.top-wrap {
|
||||||
|
width: 100%;
|
||||||
|
height: 175px;
|
||||||
|
background: linear-gradient(180deg, #DAECFF 0%, rgba(233, 243, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.center-info {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.wei_code_wrap {
|
||||||
|
margin-top: 10px;
|
||||||
|
.wei_title {
|
||||||
|
font-size: 15px;
|
||||||
|
color: #FF553B;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.wei_code_bg {
|
||||||
|
width: 163px;
|
||||||
|
height: 173px;
|
||||||
|
background-image: url("~@/assets/supplier/weiCodeBg.png");
|
||||||
|
background-size: 100% 100%;
|
||||||
|
margin: 8px auto;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.btn_wrap {
|
||||||
|
width: 100%;
|
||||||
|
padding: 15px 0;
|
||||||
|
position: fixed;
|
||||||
|
bottom: 10px;
|
||||||
|
z-index: 10000 !important;
|
||||||
|
.btn {
|
||||||
|
width: calc(100% - 80px);
|
||||||
|
margin-left: 40px;
|
||||||
|
height: 46px;
|
||||||
|
background: #0E76F4;
|
||||||
|
border-radius: 5px;
|
||||||
|
font-size: 15px;
|
||||||
|
color: #FFFFFF;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 46px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
@@ -122,7 +122,7 @@
|
|||||||
<span>司机状态</span>
|
<span>司机状态</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="isJoin">
|
<div class="isJoin">
|
||||||
<van-radio-group v-model="states" @change="isUse" class="joinWrap">
|
<van-radio-group v-model="states" @change="isUse" :disabled="statesDisabled" :class="{ 'disabled-tree': statesDisabled }" class="joinWrap">
|
||||||
<van-radio :name="1" style="margin-right: 26px" class="item">
|
<van-radio :name="1" style="margin-right: 26px" class="item">
|
||||||
启用
|
启用
|
||||||
<img
|
<img
|
||||||
@@ -163,6 +163,7 @@ export default {
|
|||||||
// baseURL:'',
|
// baseURL:'',
|
||||||
// licenseOcrInfo:'',
|
// licenseOcrInfo:'',
|
||||||
id:'',
|
id:'',
|
||||||
|
supplierId: '',
|
||||||
driverName:"",
|
driverName:"",
|
||||||
driverPhone:"",
|
driverPhone:"",
|
||||||
identityCardNumber:"",
|
identityCardNumber:"",
|
||||||
@@ -184,6 +185,7 @@ export default {
|
|||||||
iconList: [],
|
iconList: [],
|
||||||
driverInfo: {},
|
driverInfo: {},
|
||||||
drivingLicenceName: '',
|
drivingLicenceName: '',
|
||||||
|
potentialFlag: '',
|
||||||
idCardAuthority:'',
|
idCardAuthority:'',
|
||||||
idCardValidStartTime:'',
|
idCardValidStartTime:'',
|
||||||
idCardValidEndTime:'',
|
idCardValidEndTime:'',
|
||||||
@@ -204,6 +206,7 @@ export default {
|
|||||||
let token=localStorage.getItem('token')
|
let token=localStorage.getItem('token')
|
||||||
this.authorization.Authorization=token;*/
|
this.authorization.Authorization=token;*/
|
||||||
this.id = this.$route.params?.id;
|
this.id = this.$route.params?.id;
|
||||||
|
this.supplierId = this.$route.params?.supplierId || '';
|
||||||
this.driverName = this.$route.params?.name;
|
this.driverName = this.$route.params?.name;
|
||||||
this.driverPhone = this.$route.params?.phone;
|
this.driverPhone = this.$route.params?.phone;
|
||||||
this.drivingModel = this.$route.params?.drivingModel;
|
this.drivingModel = this.$route.params?.drivingModel;
|
||||||
@@ -220,6 +223,11 @@ export default {
|
|||||||
this.identityCardFront = this.$route.params?.identityCardFront;
|
this.identityCardFront = this.$route.params?.identityCardFront;
|
||||||
this.driverInfo.lssueDate = this.$route.params?.lssueDate;
|
this.driverInfo.lssueDate = this.$route.params?.lssueDate;
|
||||||
this.drivingLicenceName = this.$route.params?.drivingLicenceName;
|
this.drivingLicenceName = this.$route.params?.drivingLicenceName;
|
||||||
|
this.potentialFlag = this.$route.params?.potentialFlag || '';
|
||||||
|
console.log('this.potentialFlagthis.potentialFlag', this.potentialFlag)
|
||||||
|
if(!this.id && this.potentialFlag === '1') {
|
||||||
|
this.states = 0;
|
||||||
|
}
|
||||||
if( this.identityCardFront ) {
|
if( this.identityCardFront ) {
|
||||||
this.identityCardFrontList = [{ url : this.identityCardFront }];
|
this.identityCardFrontList = [{ url : this.identityCardFront }];
|
||||||
}
|
}
|
||||||
@@ -240,7 +248,7 @@ export default {
|
|||||||
const selectedValue = selectElement.value;
|
const selectedValue = selectElement.value;
|
||||||
this.drivingModel=selectedValue
|
this.drivingModel=selectedValue
|
||||||
});
|
});
|
||||||
|
console.log('statesDisabled', this.statesDisabled)
|
||||||
},
|
},
|
||||||
methods:{
|
methods:{
|
||||||
isUse(e){
|
isUse(e){
|
||||||
@@ -426,6 +434,7 @@ export default {
|
|||||||
}
|
}
|
||||||
await saveDriver({
|
await saveDriver({
|
||||||
driverId:this.id ? this.id : '',
|
driverId:this.id ? this.id : '',
|
||||||
|
supplierId: this.supplierId || undefined,
|
||||||
driverName:this.driverName ,
|
driverName:this.driverName ,
|
||||||
driverPhone:this.driverPhone,
|
driverPhone:this.driverPhone,
|
||||||
identityCardNumber:this.identityCardNumber,
|
identityCardNumber:this.identityCardNumber,
|
||||||
@@ -453,6 +462,11 @@ export default {
|
|||||||
},2000)
|
},2000)
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
computed: {
|
||||||
|
statesDisabled() {
|
||||||
|
return !this.id && this.potentialFlag === '1';
|
||||||
|
}
|
||||||
|
},
|
||||||
components:{
|
components:{
|
||||||
TwoCommonBtn,
|
TwoCommonBtn,
|
||||||
CellGroup
|
CellGroup
|
||||||
|
|||||||
@@ -3,14 +3,14 @@
|
|||||||
<div class="navBar">
|
<div class="navBar">
|
||||||
<van-nav-bar
|
<van-nav-bar
|
||||||
title="司机管理"
|
title="司机管理"
|
||||||
left-arrow
|
:left-arrow="!supplierId"
|
||||||
left-arrow-color="#FFFFFF"
|
left-arrow-color="#FFFFFF"
|
||||||
:border="false"
|
:border="false"
|
||||||
:fixed="true"
|
:fixed="true"
|
||||||
:safe-area-inset-top="true"
|
:safe-area-inset-top="true"
|
||||||
@click-left="goBack"
|
@click-left="goBack"
|
||||||
>
|
>
|
||||||
<template slot="right" v-if="permissonList.includes('driverAddBtn')">
|
<template slot="right" v-if="permissonList.includes('driverAddBtn') || supplierId">
|
||||||
<div class="rightWrap" @click="addDriver" >
|
<div class="rightWrap" @click="addDriver" >
|
||||||
<img src="@/assets/addImg.png" />
|
<img src="@/assets/addImg.png" />
|
||||||
<span class="addTxt">添加</span>
|
<span class="addTxt">添加</span>
|
||||||
@@ -62,14 +62,14 @@
|
|||||||
finished-text="没有更多了"
|
finished-text="没有更多了"
|
||||||
@load="onLoad"
|
@load="onLoad"
|
||||||
>
|
>
|
||||||
<div class="itemWrap" v-for="(item,index) in driverList" :key="index" @click.stop="updateDriver(item)">
|
<div class="itemWrap" v-for="(item,index) in driverList" :key="index" @click.stop="!isMiniProgram(item) && updateDriver(item)">
|
||||||
<div class="name-status">
|
<div class="name-status">
|
||||||
<div class="namephone">{{ item.driverName }} / {{ item.driverPhone }}
|
<div class="namephone">{{ item.driverName }} / {{ item.driverPhone }}
|
||||||
<span style="margin-left: 10px" :class="item.states?.code == 1 ? 'statusYes' : 'statusNo'">{{ item.states?.label }}</span>
|
<span style="margin-left: 10px" :class="item.states?.code == 1 ? 'statusYes' : 'statusNo'">{{ item.states?.label }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="twoBtn">
|
<div class="twoBtn">
|
||||||
<!-- 只有启用状态下才展示停用按钮-->
|
<!-- 只有启用状态下才展示停用按钮,小程序来源司机不显示-->
|
||||||
<button v-if="permissonList.includes('driverModifyBtn') && item.states?.code==1" class="del" @click.stop="handleStatus(item)">停用</button>
|
<button v-if="!isMiniProgram(item) && permissonList.includes('driverModifyBtn') && item.states?.code==1" class="del" @click.stop="handleStatus(item)">停用</button>
|
||||||
<!-- <button v-if="permissonList.includes('driverModifyBtn')" class="revise" @click="updateDriver(item)">修改</button>-->
|
<!-- <button v-if="permissonList.includes('driverModifyBtn')" class="revise" @click="updateDriver(item)">修改</button>-->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -103,7 +103,7 @@
|
|||||||
<span class="halfOpci">身份证号:</span>
|
<span class="halfOpci">身份证号:</span>
|
||||||
<span class="allOpci">{{ item.identityCardNumber }}</span>
|
<span class="allOpci">{{ item.identityCardNumber }}</span>
|
||||||
</div>
|
</div>
|
||||||
<van-icon class="arrow_position" v-if="permissonList.includes('driverModifyBtn')" name="arrow" />
|
<van-icon class="arrow_position" v-if="!isMiniProgram(item) && permissonList.includes('driverModifyBtn')" name="arrow" />
|
||||||
<!-- <div>
|
<!-- <div>
|
||||||
<span class="halfOpci">状 态:</span>
|
<span class="halfOpci">状 态:</span>
|
||||||
<span :class="item.states?.code == 1 ? 'statusYes' : 'statusNo'">{{ item.states?.label }}</span>
|
<span :class="item.states?.code == 1 ? 'statusYes' : 'statusNo'">{{ item.states?.label }}</span>
|
||||||
@@ -113,6 +113,9 @@
|
|||||||
</van-pull-refresh>
|
</van-pull-refresh>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
<div class="btn_wrap" v-if="supplierId">
|
||||||
|
<div class="btn" @click="nextToResult">下一步</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@@ -131,6 +134,10 @@ export default {
|
|||||||
total:'',
|
total:'',
|
||||||
driverList:[],
|
driverList:[],
|
||||||
states:'',
|
states:'',
|
||||||
|
supplierId: '',
|
||||||
|
routeId: '',
|
||||||
|
initialized: false,
|
||||||
|
potentialFlag: '',
|
||||||
supplierType:'',
|
supplierType:'',
|
||||||
count: 0,
|
count: 0,
|
||||||
isLoading: false,
|
isLoading: false,
|
||||||
@@ -176,10 +183,24 @@ export default {
|
|||||||
mounted() {
|
mounted() {
|
||||||
const urlParams = new URLSearchParams(window.location.search);
|
const urlParams = new URLSearchParams(window.location.search);
|
||||||
this.supplierType = urlParams.get('supplierType');
|
this.supplierType = urlParams.get('supplierType');
|
||||||
|
const rawId = this.$route.query.id || urlParams.get('id');
|
||||||
|
this.supplierId = rawId ? Number(rawId) : '';
|
||||||
|
const potentialId = this.$route.query.potentialId || urlParams.get('potentialId');
|
||||||
|
this.routeId = potentialId;
|
||||||
|
this.potentialFlag = this.$route.query.potentialFlag || urlParams.get('potentialFlag') || '';
|
||||||
|
if(!rawId) {
|
||||||
this.getPermissions();
|
this.getPermissions();
|
||||||
|
}
|
||||||
// this.getDriverList()
|
// this.getDriverList()
|
||||||
},
|
},
|
||||||
methods:{
|
methods:{
|
||||||
|
nextToResult() {
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify({ name: 'supplierAddResult', query: { id: this.routeId, potentialFlag: this.potentialFlag } }));
|
||||||
|
this.goPage('supplierAddResult', { id: this.routeId, potentialFlag: this.potentialFlag });
|
||||||
|
},
|
||||||
|
isMiniProgram(item) {
|
||||||
|
return item.registerFrom === '小程序' || (item.jobNumber && item.jobNumber.includes('小程序'))
|
||||||
|
},
|
||||||
getClass(id) {
|
getClass(id) {
|
||||||
const ids = String(id)
|
const ids = String(id)
|
||||||
const steps = {
|
const steps = {
|
||||||
@@ -236,6 +257,7 @@ export default {
|
|||||||
}else{
|
}else{
|
||||||
this.$router.push({
|
this.$router.push({
|
||||||
name: 'driverAdd',
|
name: 'driverAdd',
|
||||||
|
params: { supplierId: this.supplierId || undefined, potentialFlag: this.potentialFlag || undefined }
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -247,6 +269,7 @@ export default {
|
|||||||
idCardStatusList: this.idCardStatusList,
|
idCardStatusList: this.idCardStatusList,
|
||||||
driverLicenseStatusList: this.driverLicenseStatusList,
|
driverLicenseStatusList: this.driverLicenseStatusList,
|
||||||
authStatusList: this.authStatusList,
|
authStatusList: this.authStatusList,
|
||||||
|
supplierId: this.supplierId || undefined,
|
||||||
});
|
});
|
||||||
if(res.code == 200){
|
if(res.code == 200){
|
||||||
this.total=res.total
|
this.total=res.total
|
||||||
@@ -517,4 +540,22 @@ export default {
|
|||||||
.flex-between{
|
.flex-between{
|
||||||
line-height: 24px;
|
line-height: 24px;
|
||||||
}
|
}
|
||||||
|
.btn_wrap {
|
||||||
|
width: 100%;
|
||||||
|
padding: 15px 0;
|
||||||
|
position: fixed;
|
||||||
|
bottom: 10px;
|
||||||
|
z-index: 10000;
|
||||||
|
.btn {
|
||||||
|
width: calc(100% - 80px);
|
||||||
|
margin-left: 40px;
|
||||||
|
height: 46px;
|
||||||
|
background: #0E76F4;
|
||||||
|
border-radius: 5px;
|
||||||
|
font-size: 15px;
|
||||||
|
color: #FFFFFF;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 46px;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -153,12 +153,17 @@ export default {
|
|||||||
if (this.notifyList.length >= this.total) {
|
if (this.notifyList.length >= this.total) {
|
||||||
this.finished = true;
|
this.finished = true;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// 未开票不需要分页,直接标记加载完成
|
||||||
|
this.loading = false;
|
||||||
|
this.finished = true;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async changeTabHandler() {
|
async changeTabHandler() {
|
||||||
this.pageNum = 1;
|
this.pageNum = 1;
|
||||||
this.notifyList = [];
|
this.notifyList = [];
|
||||||
this.checkList = [];
|
this.checkList = [];
|
||||||
|
this.finished = false;
|
||||||
if (this.active == 1) { // 全部, 需要分页
|
if (this.active == 1) { // 全部, 需要分页
|
||||||
this.status = '';
|
this.status = '';
|
||||||
this.dispatchAppSearchInvoiced = '';
|
this.dispatchAppSearchInvoiced = '';
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
<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>
|
||||||
@@ -84,8 +85,8 @@
|
|||||||
</el-tree>
|
</el-tree>
|
||||||
</template>
|
</template>
|
||||||
</van-field>
|
</van-field>
|
||||||
<van-field :border="true" v-model="form.trailCount" name="trailCount" label="拖车数量" placeholder="请输入" />
|
<van-field :border="true" v-model="form.trailCount" type="digit" class="required" name="trailCount" label="拖车数量" placeholder="请输入" :rules="countVerify" />
|
||||||
<van-field :border="true" v-model="form.minorCount" name="minorCount" label="抢修车数量" placeholder="请输入" />
|
<van-field :border="true" v-model="form.minorCount" type="digit" class="required" name="minorCount" label="抢修车数量" placeholder="请输入" :rules="countVerify" />
|
||||||
<van-field :border="true" class="required" label="服务区域" placeholder="请选择">
|
<van-field :border="true" class="required" label="服务区域" placeholder="请选择">
|
||||||
<template #input>
|
<template #input>
|
||||||
<el-cascader
|
<el-cascader
|
||||||
@@ -99,12 +100,12 @@
|
|||||||
clearable></el-cascader>
|
clearable></el-cascader>
|
||||||
</template>
|
</template>
|
||||||
</van-field>
|
</van-field>
|
||||||
<div class="wei_code_wrap" v-if="form.name && !id">
|
<!-- <div class="wei_code_wrap" v-if="form.name && !id">
|
||||||
<div class="wei_title">请先添加企业微信,保证申请流程正常进行。</div>
|
<div class="wei_title">请先添加企业微信,保证申请流程正常进行。</div>
|
||||||
<div class="wei_code_bg">
|
<div class="wei_code_bg">
|
||||||
<img v-if="qrCodeUrl" :src="qrCodeUrl" alt="企业微信二维码" />
|
<img v-if="qrCodeUrl" :src="qrCodeUrl" alt="企业微信二维码" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>-->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -134,8 +135,10 @@
|
|||||||
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: '邮箱格式不正确' }],
|
||||||
|
countVerify: [{ required: true, message: '请输入数量' }, { validator: value => /^\d+$/.test(value) && Number(value) >= 0, message: '请输入大于等于0的整数' }],
|
||||||
id:'', //车辆Id
|
id:'', //车辆Id
|
||||||
idBackPhotoList: [],
|
idBackPhotoList: [],
|
||||||
idBackPhoto: '',
|
idBackPhoto: '',
|
||||||
@@ -200,7 +203,14 @@
|
|||||||
},
|
},
|
||||||
async mounted() {
|
async mounted() {
|
||||||
const urlParams = new URLSearchParams(window.location.search);
|
const urlParams = new URLSearchParams(window.location.search);
|
||||||
|
const lastRoute = localStorage.getItem('lastRoute');
|
||||||
this.id = this.$route.query.id || urlParams.get('id');
|
this.id = this.$route.query.id || urlParams.get('id');
|
||||||
|
if (lastRoute && !this.id) {
|
||||||
|
const { name, query } = JSON.parse(lastRoute);
|
||||||
|
this.$router.replace({ name, query });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
await this.getAreaTree();
|
await this.getAreaTree();
|
||||||
if(this.id) {
|
if(this.id) {
|
||||||
await this.getInfoHandler();
|
await this.getInfoHandler();
|
||||||
@@ -219,7 +229,6 @@
|
|||||||
});
|
});
|
||||||
this.configId = res?.configId;
|
this.configId = res?.configId;
|
||||||
this.qrCode = res?.qrCode
|
this.qrCode = res?.qrCode
|
||||||
console.log('idid', res);
|
|
||||||
},
|
},
|
||||||
async getInfoHandler() {
|
async getInfoHandler() {
|
||||||
let res = await getSupplierInfo({
|
let res = await getSupplierInfo({
|
||||||
@@ -231,7 +240,11 @@
|
|||||||
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 }];
|
||||||
}
|
}
|
||||||
@@ -249,54 +262,65 @@
|
|||||||
}
|
}
|
||||||
if(_data?.serviceAreaCode) {
|
if(_data?.serviceAreaCode) {
|
||||||
this.$set(this.form, 'serviceAreaCode', _data?.serviceAreaCode.split(',').map(item => Number(item)));
|
this.$set(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.$toast('法人身份证人像页未上传')
|
this.showError('法人身份证人像页未上传')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if( !this.idBackPhoto ) {
|
if( !this.idBackPhoto ) {
|
||||||
this.$toast('法人身份证国徽页未上传')
|
this.showError('法人身份证国徽页未上传')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if( !this.companyPhoto ) {
|
if( !this.companyPhoto ) {
|
||||||
this.$toast('营业执照未上传')
|
this.showError('营业执照未上传')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if(this.form.person != this.form.legalName){
|
if(this.form.person != this.form.legalName){
|
||||||
this.$toast('身份证法人姓名和营业执照法人不一致')
|
this.showError('身份证法人姓名和营业执照法人不一致')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if( !this.licensePhoto ) {
|
if( !this.licensePhoto ) {
|
||||||
this.$toast('开户许可证未上传')
|
this.showError('开户许可证未上传')
|
||||||
|
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.$toast('服务区域不能为空')
|
this.showError('服务区域不能为空')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
// this.wechatId='wmOTNXBwAABrvKkE_Fh8ZN8Xm2S9v2wQ'
|
|
||||||
if(!this.wechatId) {
|
|
||||||
await this.QrCodeResult();
|
|
||||||
if( !this.wechatId ) {
|
|
||||||
this.$toast('请先添加企微再申请')
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if( this.$refs.tree.getCheckedKeys().length > 0 ) {
|
if( this.$refs.tree.getCheckedKeys().length > 0 ) {
|
||||||
await this.saveHandler()
|
let _node = this.$refs.areaCascader.getCheckedNodes();
|
||||||
} else {
|
let checkArr = [];
|
||||||
this.$toast('服务能力不能为空')
|
_node.map(item => { checkArr.push(item.data.id) });
|
||||||
return
|
const payload = {
|
||||||
|
id: this.id,
|
||||||
|
...this.form,
|
||||||
|
accountInfoJson: JSON.stringify(this.form.accountInfoDTO),
|
||||||
|
accountInfoDTO: {},
|
||||||
|
idCardFrontUrl: this.idFrontPhoto,
|
||||||
|
idCardBackUrl: this.idBackPhoto,
|
||||||
|
businessLicense: this.companyPhoto,
|
||||||
|
accountUrl: this.licensePhoto,
|
||||||
|
service: this.$refs.tree.getCheckedKeys().join(','),
|
||||||
|
serviceAreaCode: checkArr.join(','),
|
||||||
|
};
|
||||||
|
localStorage.setItem('supplierAddForm', JSON.stringify(payload));
|
||||||
|
this.goPage('addWechat', { potentialFlag: 1 });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async QrCodeResult() { //获取添加企微结果
|
async QrCodeResult() { //获取添加企微结果
|
||||||
let res = await getContactQrCodeResult({
|
let res = await getContactQrCodeResult({
|
||||||
configId: this.configId
|
configId: this.configId
|
||||||
});
|
});
|
||||||
console.log('resres', res)
|
|
||||||
this.wechatId = res?.data?.wechatId
|
this.wechatId = res?.data?.wechatId
|
||||||
},
|
},
|
||||||
async saveHandler() {
|
async saveHandler() {
|
||||||
@@ -319,17 +343,38 @@
|
|||||||
accountUrl:this.licensePhoto,
|
accountUrl:this.licensePhoto,
|
||||||
service: this.$refs.tree.getCheckedKeys().join(',') ,
|
service: this.$refs.tree.getCheckedKeys().join(',') ,
|
||||||
serviceAreaCode: checkArr.join(','),
|
serviceAreaCode: checkArr.join(','),
|
||||||
wechatId: this.wechatId,
|
|
||||||
});
|
});
|
||||||
|
console.log('rererere', res)
|
||||||
|
if( res?.noToast ) { // 服务商已存在
|
||||||
|
this.showError('当前服务商已存在')
|
||||||
|
if( res?.code != 0 ) {
|
||||||
|
Dialog.alert({
|
||||||
|
title: '提示',
|
||||||
|
message: "该服务商已存在,查看信息"
|
||||||
|
}).then(async () => {
|
||||||
|
const target = { name: 'supplierAddResult', query: { id: res?.code } };
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify(target));
|
||||||
|
this.goPage('supplierAddResult', { id : res?.code })
|
||||||
|
setTimeout(() => {
|
||||||
|
this.clickFlag = true
|
||||||
|
}, 1000)
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
Dialog.alert({
|
Dialog.alert({
|
||||||
title: '提示',
|
title: '提示',
|
||||||
message: "操作成功"
|
message: "操作成功"
|
||||||
}).then(async () => {
|
}).then(async () => {
|
||||||
|
const target = { name: 'supplierAddResult', query: { id: res?.data } };
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify(target));
|
||||||
this.goPage('supplierAddResult', { id : res?.data })
|
this.goPage('supplierAddResult', { id : res?.data })
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
this.clickFlag = true
|
this.clickFlag = true
|
||||||
}, 1000)
|
}, 1000)
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
this.showError(e)
|
||||||
} finally {
|
} finally {
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
this.clickFlag = true
|
this.clickFlag = true
|
||||||
@@ -428,7 +473,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();
|
||||||
@@ -442,8 +487,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: {
|
||||||
@@ -463,6 +508,17 @@
|
|||||||
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 {
|
||||||
|
|||||||
@@ -19,15 +19,26 @@
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
id: '',
|
id: '',
|
||||||
|
potentialFlag: '',
|
||||||
|
name: '',
|
||||||
|
qrCodeUrl: '',
|
||||||
|
qrCode: '',
|
||||||
|
configId: '',
|
||||||
|
wechatId: '',
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async mounted() {
|
async mounted() {
|
||||||
const urlParams = new URLSearchParams(window.location.search);
|
const urlParams = new URLSearchParams(window.location.search);
|
||||||
this.id = this.$route.query.id || urlParams.get('id');
|
this.id = this.$route.query.id || urlParams.get('id');
|
||||||
|
this.potentialFlag = this.$route.query.potentialFlag || urlParams.get('potentialFlag') || '';
|
||||||
|
if (this.id) {
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify({ name: 'supplierAddResult', query: { id: this.id, potentialFlag: this.potentialFlag } }));
|
||||||
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
searchInfo() {
|
async searchInfo() {
|
||||||
this.goPage('supplierInfo', { id : this.id })
|
localStorage.setItem('lastRoute', JSON.stringify({ name: 'supplierInfo', query: { id: this.id, potentialFlag: this.potentialFlag } }));
|
||||||
|
this.goPage('supplierInfo', { id: this.id, potentialFlag: this.potentialFlag })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -80,4 +91,23 @@
|
|||||||
line-height: 46px;
|
line-height: 46px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.wei_code_wrap {
|
||||||
|
margin-top: 10px;
|
||||||
|
.wei_title {
|
||||||
|
font-size: 15px;
|
||||||
|
color: #FF553B;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.wei_code_bg {
|
||||||
|
width: 163px;
|
||||||
|
height: 173px;
|
||||||
|
background-image: url("~@/assets/supplier/weiCodeBg.png");
|
||||||
|
background-size: 100% 100%;
|
||||||
|
margin: 8px auto;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -87,11 +87,11 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="info_item">
|
<div class="info_item">
|
||||||
<div class="label">拖车数量:</div>
|
<div class="label">拖车数量:</div>
|
||||||
<div class="content">{{supplierInfo?.trailCount || ''}}</div>
|
<div class="content">{{supplierInfo.trailCount>=0 ? supplierInfo.trailCount : ''}}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="info_item">
|
<div class="info_item">
|
||||||
<div class="label">抢修车数量:</div>
|
<div class="label">抢修车数量:</div>
|
||||||
<div class="content">{{supplierInfo?.minorCount || ''}}</div>
|
<div class="content">{{supplierInfo.minorCount >= 0 ? supplierInfo.minorCount : ''}}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="info_item">
|
<div class="info_item">
|
||||||
<div class="label">服务区域:</div>
|
<div class="label">服务区域:</div>
|
||||||
@@ -124,7 +124,9 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<!-- <div class="btn_wrap" style="margin-bottom: 5px">
|
||||||
|
<div class="btn" @click="goAddVehicle">完善信息</div>
|
||||||
|
</div>-->
|
||||||
<div class="btn_wrap" v-if="type == 'show' && supplierInfo?.state == 99 && origin != 'web'">
|
<div class="btn_wrap" v-if="type == 'show' && supplierInfo?.state == 99 && origin != 'web'">
|
||||||
<div class="btn" @click="goModifyPage">修改信息</div>
|
<div class="btn" @click="goModifyPage">修改信息</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -152,6 +154,7 @@
|
|||||||
supplierInfo: {},
|
supplierInfo: {},
|
||||||
type: 'show',
|
type: 'show',
|
||||||
origin: '',
|
origin: '',
|
||||||
|
potentialFlag: '',
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async mounted() {
|
async mounted() {
|
||||||
@@ -159,9 +162,15 @@
|
|||||||
this.id=this.$route.query.id || urlParams.get('id');
|
this.id=this.$route.query.id || urlParams.get('id');
|
||||||
this.type=this.$route.query.type || urlParams.get('type') || 'show';
|
this.type=this.$route.query.type || urlParams.get('type') || 'show';
|
||||||
this.origin = this.$route.query.origin || ''
|
this.origin = this.$route.query.origin || ''
|
||||||
|
this.potentialFlag = this.$route.query.potentialFlag || urlParams.get('potentialFlag') || '';
|
||||||
await this.getInfoHandler();
|
await this.getInfoHandler();
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
goAddVehicle() {
|
||||||
|
const supplierId = this.id
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify({ name: 'vehicleManage', query: { id: supplierId, potentialFlag: this.potentialFlag } }));
|
||||||
|
this.goPage('vehicleManage', { id: supplierId, potentialFlag: this.potentialFlag });
|
||||||
|
},
|
||||||
goModifyPage() {
|
goModifyPage() {
|
||||||
this.goPage('supplierAdd', { id : this.id })
|
this.goPage('supplierAdd', { id : this.id })
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -287,10 +287,10 @@
|
|||||||
if(!res.data.ocrInvoiceRes.data.sellerName.startsWith("国家税务总局") &&
|
if(!res.data.ocrInvoiceRes.data.sellerName.startsWith("国家税务总局") &&
|
||||||
conList.every(a => {
|
conList.every(a => {
|
||||||
let items = a.itemName.split("*")
|
let items = a.itemName.split("*")
|
||||||
return (!items[1].includes("现代服务") && !items[1].includes("运输服务")) || (!items[2].includes("拖车") && !items[2].includes("救援") && !items[2].includes("施救") && !items[2].includes("清障") && !items[2].includes("道路救援"))
|
return (!items[1].includes("生产生活服务") && !items[1].includes("交通运输服务")) || (!items[2].includes("拖车") && !items[2].includes("救援") && !items[2].includes("施救") && !items[2].includes("清障") && !items[2].includes("道路救援"))
|
||||||
})
|
})
|
||||||
){
|
){
|
||||||
errorStr = errorStr + "分类必须包含:现代服务/运输服务,服务名称必须包含:拖车/救援/施救/清障/道路救援 ;例如《*现代服务*拖车费》";
|
errorStr = errorStr + "分类必须包含:生产生活服务/交通运输服务,服务名称必须包含:拖车/救援/施救/清障/道路救援 ;例如《*现代服务*拖车费》";
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !flag ) {
|
if( !flag ) {
|
||||||
|
|||||||
@@ -197,7 +197,7 @@
|
|||||||
<span>车辆状态</span>
|
<span>车辆状态</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="isJoin">
|
<div class="isJoin">
|
||||||
<van-radio-group v-model="vehicleStatus" :class="{ 'disabled-tree': vehicleInfoDisabled }" :disabled="vehicleInfoDisabled" @change="isVehicleChange" class="joinWrap">
|
<van-radio-group v-model="vehicleStatus" :class="{ 'disabled-tree': vehicleInfoDisabled || vehicleStatusDisabled }" :disabled="vehicleInfoDisabled || vehicleStatusDisabled" @change="isVehicleChange" class="joinWrap">
|
||||||
<van-radio :name="1" style="margin-right: 14px">
|
<van-radio :name="1" style="margin-right: 14px">
|
||||||
启用
|
启用
|
||||||
<img
|
<img
|
||||||
@@ -470,7 +470,8 @@ export default {
|
|||||||
maxDate: new Date(2099, 11, 31), // 设置最大可选日期(2099年12月31日)
|
maxDate: new Date(2099, 11, 31), // 设置最大可选日期(2099年12月31日)
|
||||||
checkList: [],
|
checkList: [],
|
||||||
virtualVehicle: '',
|
virtualVehicle: '',
|
||||||
vehicleStatus: '',
|
potentialFlag: new URLSearchParams(window.location.search).get('potentialFlag') || '',
|
||||||
|
vehicleStatus: new URLSearchParams(window.location.search).get('potentialFlag') === '1' ? 2 : '',
|
||||||
showDatePicker: false,
|
showDatePicker: false,
|
||||||
dateVal: '',
|
dateVal: '',
|
||||||
trailerService: '',//拖车服务
|
trailerService: '',//拖车服务
|
||||||
@@ -648,6 +649,9 @@ export default {
|
|||||||
} else {
|
} else {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
vehicleStatusDisabled() {
|
||||||
|
return !this.id && this.potentialFlag === '1';
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
watch:{
|
watch:{
|
||||||
@@ -686,6 +690,9 @@ export default {
|
|||||||
async mounted() {
|
async mounted() {
|
||||||
this.id=this.$route.params?.id
|
this.id=this.$route.params?.id
|
||||||
this.approvalForm.supplierId=this.$route.params?.supplierId
|
this.approvalForm.supplierId=this.$route.params?.supplierId
|
||||||
|
const urlParams = new URLSearchParams(window.location.search);
|
||||||
|
const rawId = this.$route.query.supplierId || urlParams.get('supplierId');
|
||||||
|
this.supplierId = rawId ? Number(rawId) : '';
|
||||||
await this.getSupplierServiceTree();
|
await this.getSupplierServiceTree();
|
||||||
await this.getTypeList();
|
await this.getTypeList();
|
||||||
if( this.id){
|
if( this.id){
|
||||||
@@ -948,7 +955,7 @@ export default {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
async getSupplierServiceTree(){
|
async getSupplierServiceTree(){
|
||||||
let res = await supplierServiceTree();
|
let res = await supplierServiceTree({ supplierId: this.supplierId });
|
||||||
this.supplierServiceList=res.data
|
this.supplierServiceList=res.data
|
||||||
this.oldSupplierServiceList=this.supplierServiceList
|
this.oldSupplierServiceList=this.supplierServiceList
|
||||||
},
|
},
|
||||||
@@ -1212,12 +1219,17 @@ export default {
|
|||||||
this.insuranceChange=false
|
this.insuranceChange=false
|
||||||
},
|
},
|
||||||
back() {
|
back() {
|
||||||
|
if( this.supplierId ) {
|
||||||
|
this.$router.back();
|
||||||
|
} else {
|
||||||
this.$router.push({
|
this.$router.push({
|
||||||
name:'vehicleManage',
|
name:'vehicleManage',
|
||||||
params:{
|
params:{
|
||||||
id: this.id
|
id: this.id
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
async submitBtn(){
|
async submitBtn(){
|
||||||
if( !this.vehicleLicenseFront ) {
|
if( !this.vehicleLicenseFront ) {
|
||||||
@@ -1303,6 +1315,7 @@ export default {
|
|||||||
// return
|
// return
|
||||||
await saveVehicle({
|
await saveVehicle({
|
||||||
vehicleId:this.id ? this.id : '',
|
vehicleId:this.id ? this.id : '',
|
||||||
|
supplierId: this.supplierId || undefined,
|
||||||
plateNumber:this.carNum ? this.carNum :'',
|
plateNumber:this.carNum ? this.carNum :'',
|
||||||
vehicleType:this.selectedOption?.length>0 ? this.selectedOption.join(',') : '',
|
vehicleType:this.selectedOption?.length>0 ? this.selectedOption.join(',') : '',
|
||||||
// hasPolymerization:this.isJoin,
|
// hasPolymerization:this.isJoin,
|
||||||
|
|||||||
@@ -3,15 +3,15 @@
|
|||||||
<div class="navBar">
|
<div class="navBar">
|
||||||
<van-nav-bar
|
<van-nav-bar
|
||||||
title="车辆管理"
|
title="车辆管理"
|
||||||
left-arrow
|
:left-arrow="!supplierId"
|
||||||
left-arrow-color="#FFFFFF"
|
left-arrow-color="#FFFFFF"
|
||||||
:border="false"
|
:border="false"
|
||||||
:fixed="true"
|
:fixed="true"
|
||||||
:safe-area-inset-top="true"
|
:safe-area-inset-top="true"
|
||||||
@click-left="goBack"
|
@click-left="goBack"
|
||||||
>
|
>
|
||||||
<template slot="right" v-if="permissonList.includes('vehicleAddBtn')">
|
<template slot="right" v-if="permissonList.includes('vehicleAddBtn') || supplierId">
|
||||||
<div class="rightWrap" @click="goPage('vehicleAdd')">
|
<div class="rightWrap" @click="goPage('vehicleAdd', supplierId ? { supplierId, potentialFlag } : {})">
|
||||||
<img src="@/assets/addImg.png" />
|
<img src="@/assets/addImg.png" />
|
||||||
<span class="addTxt">添加</span>
|
<span class="addTxt">添加</span>
|
||||||
</div>
|
</div>
|
||||||
@@ -71,6 +71,7 @@
|
|||||||
<div class="wrap_cls">
|
<div class="wrap_cls">
|
||||||
<van-pull-refresh v-model="isLoading" @refresh="onRefresh">
|
<van-pull-refresh v-model="isLoading" @refresh="onRefresh">
|
||||||
<van-list
|
<van-list
|
||||||
|
v-if="initialized"
|
||||||
v-model="loading"
|
v-model="loading"
|
||||||
:finished="finished"
|
:finished="finished"
|
||||||
finished-text="没有更多了"
|
finished-text="没有更多了"
|
||||||
@@ -114,6 +115,9 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<van-dialog v-model="show" title="确定删除吗" show-cancel-button @confirm="handleConfirm"></van-dialog>
|
<van-dialog v-model="show" title="确定删除吗" show-cancel-button @confirm="handleConfirm"></van-dialog>
|
||||||
|
<div class="btn_wrap" v-if="supplierId">
|
||||||
|
<div class="btn" @click="nextToDriver">下一步</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</template>
|
</template>
|
||||||
@@ -121,7 +125,7 @@
|
|||||||
<script>
|
<script>
|
||||||
import {Dialog} from "vant";
|
import {Dialog} from "vant";
|
||||||
import { myMixins} from "@/utils/myMixins";
|
import { myMixins} from "@/utils/myMixins";
|
||||||
import {supplierVehicleList, deleteVehicle, userOperationPermissions, enableVehicle} from "@/api/mine"
|
import {supplierVehicleList, deleteVehicle, userOperationPermissions, enableVehicle, supplierSelectById} from "@/api/mine"
|
||||||
export default {
|
export default {
|
||||||
name: "vehicleManage",
|
name: "vehicleManage",
|
||||||
mixins:[myMixins],
|
mixins:[myMixins],
|
||||||
@@ -130,6 +134,9 @@ export default {
|
|||||||
vehicleList:[],
|
vehicleList:[],
|
||||||
show:false,
|
show:false,
|
||||||
id:'',
|
id:'',
|
||||||
|
supplierId: '',
|
||||||
|
routeId: '',
|
||||||
|
initialized: false,
|
||||||
pageNum:1,
|
pageNum:1,
|
||||||
pageSize:10,
|
pageSize:10,
|
||||||
total:'',
|
total:'',
|
||||||
@@ -142,6 +149,7 @@ export default {
|
|||||||
searchVal: '',
|
searchVal: '',
|
||||||
authStates: [],
|
authStates: [],
|
||||||
liabilityInsuranceAuditList: [],
|
liabilityInsuranceAuditList: [],
|
||||||
|
potentialFlag: '',
|
||||||
inputStatusListOptions: [{
|
inputStatusListOptions: [{
|
||||||
name: '行驶证未录入',
|
name: '行驶证未录入',
|
||||||
value: 0
|
value: 0
|
||||||
@@ -189,10 +197,31 @@ export default {
|
|||||||
}],
|
}],
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted() {
|
async mounted() {
|
||||||
|
const urlParams = new URLSearchParams(window.location.search);
|
||||||
|
const rawId = this.$route.query.id || urlParams.get('id');
|
||||||
|
this.potentialFlag = this.$route.query.potentialFlag || urlParams.get('potentialFlag') || '';
|
||||||
|
if (rawId) {
|
||||||
|
this.routeId = rawId;
|
||||||
|
await this.getSupplierById(Number(rawId));
|
||||||
|
} else {
|
||||||
|
this.initialized = true;
|
||||||
|
}
|
||||||
|
let _token = localStorage.getItem('token')
|
||||||
|
if( _token ) {
|
||||||
this.getPermissions();
|
this.getPermissions();
|
||||||
|
}
|
||||||
},
|
},
|
||||||
methods:{
|
methods:{
|
||||||
|
nextToDriver() {
|
||||||
|
localStorage.setItem('lastRoute', JSON.stringify({ name: 'driverManage', query: { id: this.supplierId, potentialId: this.routeId, potentialFlag: this.potentialFlag } }));
|
||||||
|
this.goPage('driverManage', { id: this.supplierId, potentialId: this.routeId, potentialFlag: this.potentialFlag });
|
||||||
|
},
|
||||||
|
async getSupplierById(id) {
|
||||||
|
let res = await supplierSelectById({ id });
|
||||||
|
this.supplierId = res?.data?.supplierId || '';
|
||||||
|
this.initialized = true;
|
||||||
|
},
|
||||||
showTip(msg) {
|
showTip(msg) {
|
||||||
Dialog.alert({
|
Dialog.alert({
|
||||||
title: '未通过原因',
|
title: '未通过原因',
|
||||||
@@ -277,6 +306,7 @@ export default {
|
|||||||
inputStatusList: this.inputStatusList,
|
inputStatusList: this.inputStatusList,
|
||||||
authStates: this.authStates,
|
authStates: this.authStates,
|
||||||
liabilityInsuranceAuditList: this.liabilityInsuranceAuditList,
|
liabilityInsuranceAuditList: this.liabilityInsuranceAuditList,
|
||||||
|
supplierId: this.supplierId || undefined,
|
||||||
})
|
})
|
||||||
this.total=result.total
|
this.total=result.total
|
||||||
if(this.pageNum == 1){// 第一页直接赋值
|
if(this.pageNum == 1){// 第一页直接赋值
|
||||||
@@ -585,5 +615,23 @@ export default {
|
|||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
margin-left: 10px;
|
margin-left: 10px;
|
||||||
}
|
}
|
||||||
|
.btn_wrap {
|
||||||
|
width: 100%;
|
||||||
|
padding: 15px 0;
|
||||||
|
position: fixed;
|
||||||
|
bottom: 10px;
|
||||||
|
z-index: 10000;
|
||||||
|
.btn {
|
||||||
|
width: calc(100% - 80px);
|
||||||
|
margin-left: 40px;
|
||||||
|
height: 46px;
|
||||||
|
background: #0E76F4;
|
||||||
|
border-radius: 5px;
|
||||||
|
font-size: 15px;
|
||||||
|
color: #FFFFFF;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 46px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -1,41 +1,57 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="wrap">
|
<div class="wrap">
|
||||||
<div class="baseInfo common" :style="{'height':orderDetailInfo.contractParentId == 110 ? '300px' : '240px'}">
|
<div class="baseInfo common">
|
||||||
<div class="title">基本信息:</div>
|
<div class="title">基本信息:</div>
|
||||||
<div class="line"></div>
|
<div class="line"></div>
|
||||||
<div class="infoWrap fontColor">
|
<div class="infoWrap fontColor">
|
||||||
<div class="leftTitle">
|
<div class="infoRow">
|
||||||
<div class="leftItem">工单编号:</div>
|
<span class="leftItem">工单编号:</span>
|
||||||
<div class="leftItem">合同:</div>
|
<span class="rightItem" style="display: flex;align-items: center;">
|
||||||
<template v-if="orderDetailInfo.contractParentId == 110">
|
|
||||||
<div class="leftItem">机构名称:</div>
|
|
||||||
<div class="leftItem">销售人员:</div>
|
|
||||||
<div class="leftItem">司机号码:</div>
|
|
||||||
</template>
|
|
||||||
<div class="leftItem">结算方式:</div>
|
|
||||||
<div class="leftItem">客户姓名:</div>
|
|
||||||
<div class="leftItem">客户电话:</div>
|
|
||||||
<div class="leftItem">车牌号:</div>
|
|
||||||
<div class="leftItem">车型品牌:</div>
|
|
||||||
</div>
|
|
||||||
<div class="rightContent">
|
|
||||||
<div class="rightItem" style="display: flex;align-items: center;">
|
|
||||||
<span id="copyText">{{orderDetailInfo.orderCode}}</span>
|
<span id="copyText">{{orderDetailInfo.orderCode}}</span>
|
||||||
<img @click="copyText" src="@/assets/copy.png" style="width: 35px;height: 15px;margin-left: 10px"/>
|
<img @click="copyText" src="@/assets/copy.png" style="width: 35px;height: 15px;margin-left: 10px"/>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<div class="infoRow" v-if="!([7,9,11,12].includes(Number(queryType)))">
|
||||||
|
<span class="leftItem">合同:</span>
|
||||||
|
<span class="rightItem">{{ orderDetailInfo.contractName }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="rightItem">{{ orderDetailInfo.contractName }}</div>
|
|
||||||
<template v-if="orderDetailInfo.contractParentId == 110">
|
<template v-if="orderDetailInfo.contractParentId == 110">
|
||||||
<div class="rightItem">{{ orderDetailInfo.organizeName }}</div>
|
<div class="infoRow">
|
||||||
<div class="rightItem">{{ orderDetailInfo.saleName }}</div>
|
<span class="leftItem">机构名称:</span>
|
||||||
<div class="rightItem">{{ orderDetailInfo.driverPhone ? orderDetailInfo.driverPhone : ' '}}</div>
|
<span class="rightItem">{{ orderDetailInfo.organizeName }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="infoRow">
|
||||||
|
<span class="leftItem">销售人员:</span>
|
||||||
|
<span class="rightItem">{{ orderDetailInfo.saleName }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="infoRow">
|
||||||
|
<span class="leftItem">司机号码:</span>
|
||||||
|
<span class="rightItem">{{ orderDetailInfo.driverPhone ? orderDetailInfo.driverPhone : ' '}}</span>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<div class="rightItem">{{ orderDetailInfo.contractSettleType?.label }}</div>
|
<div class="infoRow">
|
||||||
<div class="rightItem">{{ maskName(orderDetailInfo.userName) }}</div>
|
<span class="leftItem">结算方式:</span>
|
||||||
<div class="rightItem">{{ maskPhone(orderDetailInfo.userPhone) }}</div>
|
<span class="rightItem">{{ orderDetailInfo.contractSettleType?.label }}</span>
|
||||||
<div class="rightItem">{{ orderDetailInfo.plateNumber }}</div>
|
</div>
|
||||||
<!-- <div class="rightItem" >理想智动LXA6500SHEVM理想智动LXA6500SHEVM</div>-->
|
<div class="infoRow">
|
||||||
<div class="rightItem" >{{orderDetailInfo.model}}{{ orderDetailInfo.brand }}</div>
|
<span class="leftItem">客户姓名:</span>
|
||||||
|
<span class="rightItem">{{ [7,9,11,12].includes(Number(queryType)) ? maskName(orderDetailInfo.userName) : orderDetailInfo.userName }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="infoRow">
|
||||||
|
<span class="leftItem">客户电话:</span>
|
||||||
|
<span class="rightItem">{{ maskPhone(orderDetailInfo.userPhone) }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="infoRow">
|
||||||
|
<span class="leftItem">车牌号:</span>
|
||||||
|
<span class="rightItem">{{ [7,9,11,12].includes(Number(queryType)) ? maskPlate(orderDetailInfo.plateNumber) : orderDetailInfo.plateNumber }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="infoRow">
|
||||||
|
<span class="leftItem">车型品牌:</span>
|
||||||
|
<span class="rightItem">{{orderDetailInfo.model}}{{ orderDetailInfo.brand }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="infoRow" v-if="!([7,9,11,12].includes(Number(queryType)))">
|
||||||
|
<span class="leftItem">车架号:</span>
|
||||||
|
<span class="rightItem">{{orderDetailInfo.vinNo}}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -77,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">
|
<div class="item" v-if="queryType == 9 || queryType ==11 || queryType ==12 || queryType ==5">
|
||||||
<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>
|
||||||
@@ -153,7 +169,7 @@ export default {
|
|||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
this.initMap();
|
this.initMap();
|
||||||
});
|
});
|
||||||
|
console.log('queryType', this.queryType)
|
||||||
},
|
},
|
||||||
methods:{
|
methods:{
|
||||||
async getConfigByCodeHandler() {
|
async getConfigByCodeHandler() {
|
||||||
@@ -168,19 +184,15 @@ export default {
|
|||||||
})
|
})
|
||||||
if(result.data){
|
if(result.data){
|
||||||
// console.log('--result--',result.data)
|
// console.log('--result--',result.data)
|
||||||
let params={
|
let params=`姓名:${this.orderDetailInfo.driverName}\n身份证:${result.data.identityCardNumber}\n车牌:${this.orderDetailInfo.vehiclePlateNumber}\n手机:${this.orderDetailInfo.driverPhone}`
|
||||||
'姓名:':this.orderDetailInfo.driverName,
|
// console.log('params',params)
|
||||||
'身份证:':result.data.identityCardNumber,
|
let data = {"action":"copyToClipboard","params":params}
|
||||||
'车牌:':this.orderDetailInfo.plateNumber,
|
|
||||||
'手机:':this.orderDetailInfo.driverPhone,
|
|
||||||
}
|
|
||||||
let data = {"action":"copyToClipboard","params":JSON.stringify(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/);
|
||||||
if(isiOS){
|
if(isiOS){
|
||||||
window.webkit.messageHandlers.nativeObject.postMessage(data);
|
window.webkit.messageHandlers.nativeObject.postMessage(data);
|
||||||
}else {
|
}else {
|
||||||
window.android.copyToClipboard(JSON.stringify(params));
|
window.android.copyToClipboard(params);
|
||||||
}
|
}
|
||||||
}else {
|
}else {
|
||||||
this.$toast('未获取到司机信息')
|
this.$toast('未获取到司机信息')
|
||||||
@@ -276,6 +288,11 @@ export default {
|
|||||||
if (str.length <= 7) return str;
|
if (str.length <= 7) return str;
|
||||||
return str.slice(0, 3) + '*'.repeat(str.length - 7) + str.slice(-4);
|
return str.slice(0, 3) + '*'.repeat(str.length - 7) + str.slice(-4);
|
||||||
},
|
},
|
||||||
|
maskPlate(plate) {
|
||||||
|
if (!plate) return '';
|
||||||
|
if (plate.length <= 2) return plate;
|
||||||
|
return plate.slice(0, 1) + '*'.repeat(plate.length - 2) + plate.slice(-1);
|
||||||
|
},
|
||||||
async getDriverPoi(){
|
async getDriverPoi(){
|
||||||
let res=await showVehiclePositionInfo({
|
let res=await showVehiclePositionInfo({
|
||||||
userOrderId:this.userOrderId,
|
userOrderId:this.userOrderId,
|
||||||
@@ -332,21 +349,25 @@ export default {
|
|||||||
}
|
}
|
||||||
.baseInfo{
|
.baseInfo{
|
||||||
width: 100%;
|
width: 100%;
|
||||||
//@include wh(100%,260px);
|
|
||||||
margin-bottom: 12px;
|
margin-bottom: 12px;
|
||||||
.infoWrap{
|
.infoWrap{
|
||||||
|
.infoRow{
|
||||||
display: flex;
|
display: flex;
|
||||||
.leftTitle{
|
align-items: center;
|
||||||
|
min-height: 24px;
|
||||||
|
.leftItem{
|
||||||
|
width: 60px;
|
||||||
|
flex-shrink: 0;
|
||||||
margin-left: 5px;
|
margin-left: 5px;
|
||||||
margin-right: 6px;
|
margin-right: 6px;
|
||||||
@include wh(60px,189px);
|
|
||||||
opacity: .5;
|
opacity: .5;
|
||||||
}
|
}
|
||||||
.rightContent{
|
|
||||||
height: 189px;
|
|
||||||
width: calc(100% - 60px);
|
|
||||||
.rightItem{
|
.rightItem{
|
||||||
height: 24px;
|
flex: 1;
|
||||||
|
min-width: 0;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -263,6 +263,7 @@ 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";
|
||||||
@@ -330,6 +331,10 @@ 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() {
|
||||||
@@ -338,13 +343,41 @@ 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,23 +13,20 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="contentWrap">
|
<div class="contentWrap">
|
||||||
<div>
|
<div>
|
||||||
为降低日常救援工作中的不可预期的车损赔付带来的运营风险和资金压力,减少由此衍生而来的可能投诉,顺应行业服务标准不断增长的局势,中道救援自有车辆已全部投保了救援职业责任险。
|
为降低日常救援工作中的不可预期的车损赔付带来的运营风险和资金压力,减少由此衍生而来的投诉,顺应行业服务标准不断增长的局势,中道救援自有车辆已全部投保了救援职业责任险。
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
通过日常的交流了解,此险种对于服务商而言,投保相对较难,很多服务商在无投保渠道的情况下选择了对于我们救援场景保障能力稍弱、不太匹配的货物险,从而从形成了现在很多救援车无保障、或者特殊场景货物险理赔难的局面。
|
通过交流了解,我们的合作服务商日常运营中会遇到责任险或者货物险的“投保难、理赔难”的问题,为此我们与保司沟通协调,特为与中道救援合作紧密的服务商,提供救援职业责任险参保渠道,解决大家的实际困难,实现共同进步。
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
为此中道救援经过与保司沟通协调,特为与中道救援合作紧密的服务商,提供救援职业责任险参保渠道,提升服务商服务能力,降低运营风险,实现共同进步。
|
|
||||||
</div>
|
</div>
|
||||||
<div>一、救援职业责任险简介:</div>
|
<div>一、救援职业责任险简介:</div>
|
||||||
<div> 1、综合保额100万元(其中救援责任50万元,物流责任50万元),可全方位覆盖我们日常的经营活动。</div>
|
<div> 1、保额有50万和100万两套方案可选。</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">
|
||||||
@@ -37,12 +34,10 @@
|
|||||||
<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>
|
||||||
|
|||||||
@@ -16,7 +16,7 @@
|
|||||||
<img class="mine" src="@/assets/secondHandCar/mine.png" @click="goMine" />
|
<img class="mine" src="@/assets/secondHandCar/mine.png" @click="goMine" />
|
||||||
<el-input
|
<el-input
|
||||||
@blur="getList"
|
@blur="getList"
|
||||||
placeholder="请输入"
|
placeholder="牌照|车辆类型|落板|排放|品牌|描述|底座|刹车|自营"
|
||||||
v-model.trim="topSearch">
|
v-model.trim="topSearch">
|
||||||
<img slot="suffix" class="search" src="@/assets/secondHandCar/search.png"/>
|
<img slot="suffix" class="search" src="@/assets/secondHandCar/search.png"/>
|
||||||
</el-input>
|
</el-input>
|
||||||
@@ -99,6 +99,11 @@
|
|||||||
></i>
|
></i>
|
||||||
</template>
|
</template>
|
||||||
</el-input>
|
</el-input>
|
||||||
|
<div class="customSel wantSourceSel" @click.stop="toggleWantSource">
|
||||||
|
<img v-if="wantSource === 1" class="checkIcon" src="@/assets/secondHandCar/checked.png" />
|
||||||
|
<img v-else class="checkIcon" src="@/assets/secondHandCar/uncheck.png" />
|
||||||
|
<span :class="{'has-price': wantSource === 1}">想要的车源</span>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="contentWrap" v-show="!show">
|
<div class="contentWrap" v-show="!show">
|
||||||
<van-pull-refresh v-model="isLoading" @refresh="onRefresh" style="min-height:85vh">
|
<van-pull-refresh v-model="isLoading" @refresh="onRefresh" style="min-height:85vh">
|
||||||
@@ -223,6 +228,7 @@ export default {
|
|||||||
showDatePicker: false,
|
showDatePicker: false,
|
||||||
areaShow:false,
|
areaShow:false,
|
||||||
isClearing:false,
|
isClearing:false,
|
||||||
|
wantSource: 0,
|
||||||
minDate: new Date(1970, 0, 1), // 设置最小可选日期(1970年1月1日)
|
minDate: new Date(1970, 0, 1), // 设置最小可选日期(1970年1月1日)
|
||||||
maxDate: new Date(2099, 11, 31) // 设置最大可选日期(2099年12月31日)
|
maxDate: new Date(2099, 11, 31) // 设置最大可选日期(2099年12月31日)
|
||||||
}
|
}
|
||||||
@@ -267,6 +273,10 @@ export default {
|
|||||||
this.setSearchVal();
|
this.setSearchVal();
|
||||||
this.getList()
|
this.getList()
|
||||||
},
|
},
|
||||||
|
wantSource(){
|
||||||
|
this.setSearchVal();
|
||||||
|
this.getList()
|
||||||
|
},
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
this.getSearchVal();
|
this.getSearchVal();
|
||||||
@@ -281,6 +291,9 @@ export default {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
methods:{
|
methods:{
|
||||||
|
toggleWantSource(){
|
||||||
|
this.wantSource = this.wantSource === 1 ? 0 : 1;
|
||||||
|
},
|
||||||
confirmHandle(val){
|
confirmHandle(val){
|
||||||
if(val[0].name.includes('市')){
|
if(val[0].name.includes('市')){
|
||||||
this.areaName=val[0].name
|
this.areaName=val[0].name
|
||||||
@@ -356,6 +369,7 @@ export default {
|
|||||||
sessionStorage.setItem('dateVal',this.dateVal);
|
sessionStorage.setItem('dateVal',this.dateVal);
|
||||||
sessionStorage.setItem('brandModel',this.brandModel);
|
sessionStorage.setItem('brandModel',this.brandModel);
|
||||||
sessionStorage.setItem('underpanBrand',this.underpanBrand);
|
sessionStorage.setItem('underpanBrand',this.underpanBrand);
|
||||||
|
sessionStorage.setItem('wantSource',String(this.wantSource));
|
||||||
},
|
},
|
||||||
getSearchVal(){
|
getSearchVal(){
|
||||||
this.activeTab = Number(sessionStorage.getItem('indexActiveTab')) || 0;
|
this.activeTab = Number(sessionStorage.getItem('indexActiveTab')) || 0;
|
||||||
@@ -371,6 +385,7 @@ export default {
|
|||||||
this.dateVal=sessionStorage.getItem('dateVal') || '';
|
this.dateVal=sessionStorage.getItem('dateVal') || '';
|
||||||
this.brandModel=sessionStorage.getItem('brandModel') || '';
|
this.brandModel=sessionStorage.getItem('brandModel') || '';
|
||||||
this.underpanBrand=sessionStorage.getItem('underpanBrand') || '';
|
this.underpanBrand=sessionStorage.getItem('underpanBrand') || '';
|
||||||
|
this.wantSource=Number(sessionStorage.getItem('wantSource')) || 0;
|
||||||
},
|
},
|
||||||
goMine(){//我的发布
|
goMine(){//我的发布
|
||||||
this.$router.push({ name: "mineRelease"})
|
this.$router.push({ name: "mineRelease"})
|
||||||
@@ -434,6 +449,7 @@ export default {
|
|||||||
endTime:this.endTime,
|
endTime:this.endTime,
|
||||||
brandModel:this.brandModel,
|
brandModel:this.brandModel,
|
||||||
underpanBrand:this.underpanBrand,
|
underpanBrand:this.underpanBrand,
|
||||||
|
wantSource:this.wantSource,
|
||||||
})
|
})
|
||||||
this.total=res.total
|
this.total=res.total
|
||||||
if(this.pageNum == 1){// 第一页直接赋值
|
if(this.pageNum == 1){// 第一页直接赋值
|
||||||
@@ -526,6 +542,9 @@ export default {
|
|||||||
border-radius: 20px;
|
border-radius: 20px;
|
||||||
border: 2px solid #264B94;
|
border: 2px solid #264B94;
|
||||||
}
|
}
|
||||||
|
::v-deep .el-input__inner::placeholder{
|
||||||
|
font-size: 10px;
|
||||||
|
}
|
||||||
::v-deep .el-input__suffix{
|
::v-deep .el-input__suffix{
|
||||||
top: 12px;
|
top: 12px;
|
||||||
right: 10px;
|
right: 10px;
|
||||||
@@ -622,6 +641,22 @@ export default {
|
|||||||
.has-price{
|
.has-price{
|
||||||
color: #007BE9 !important;
|
color: #007BE9 !important;
|
||||||
}
|
}
|
||||||
|
.wantSourceSel{
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
gap: 3px;
|
||||||
|
width: 68px;
|
||||||
|
cursor: pointer;
|
||||||
|
.checkIcon{
|
||||||
|
width: 13px;
|
||||||
|
height: 13px;
|
||||||
|
}
|
||||||
|
span{
|
||||||
|
font-size: 10px;
|
||||||
|
color: #323233;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
.contentWrap{
|
.contentWrap{
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
|||||||
@@ -54,6 +54,11 @@
|
|||||||
<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
|
||||||
@@ -72,35 +77,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> 到事发地距离:</div>
|
<div><span style="color: red;">*</span> 到事发地距离:</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> 拖车里程:</div>
|
<div><span style="color: red;">*</span> 拖车里程:</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>返程里程:</div>
|
<div><span style="color: red;">*</span>返程里程:</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>ab路桥费:</div>
|
<div><span v-show="!isUnsuccessfulSettle" style="color: red;">*</span>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>bc路桥费:</div>
|
<div><span v-show="!isUnsuccessfulSettle" style="color: red;">*</span>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>ca路桥费:</div>
|
<div><span v-show="!isUnsuccessfulSettle" style="color: red;">*</span>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>等候费:</div>
|
<div><span style="color: red;">*</span>等候费:</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>小轮个数:</div>
|
<div><span v-show="!isUnsuccessfulSettle" style="color: red;">*</span>小轮个数:</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">
|
||||||
@@ -108,11 +113,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>困境费:</div>
|
<div><span style="color: red;">*</span>困境费:</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>地库费:</div>
|
<div><span v-show="isBasementSettle && !isUnsuccessfulSettle" style="color: red;">*</span>地库费:</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">
|
||||||
@@ -120,7 +125,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>基本费用:</div>
|
<div><span v-show="!basePriceDisabled && !isBasementSettle" style="color: red;">*</span>基本费用:</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>
|
||||||
@@ -657,6 +662,49 @@ 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('请填写其他费用说明');
|
||||||
@@ -694,6 +742,7 @@ 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]);
|
||||||
});
|
});
|
||||||
@@ -725,6 +774,45 @@ 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
|
||||||
@@ -942,7 +1030,7 @@ img {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.baseInfo {
|
.baseInfo {
|
||||||
@include wh(100%, 344px);
|
width: 100%;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user