Compare commits
13 Commits
prod-25-08
...
dev-2025
Author | SHA1 | Date | |
---|---|---|---|
2c94eee160 | |||
4bbc53a9aa | |||
5c821e1fc0 | |||
a84dd52eae | |||
4dc0e9b835 | |||
e18be51b77 | |||
c7cc6bfec4 | |||
0d862caff1 | |||
cf60d22074 | |||
d99b0d126f | |||
0249e0863d | |||
314ab0b729 | |||
24b94ebc8c |
@ -317,3 +317,12 @@ export function unifiedOCRWithCompress(data){
|
|||||||
data
|
data
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 服务商是否培训
|
||||||
|
export function jumpPage(data){
|
||||||
|
return request({
|
||||||
|
url:'/supplierAppV2/dispatchApp/user/jumpPage',
|
||||||
|
method:'POST',
|
||||||
|
data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
@ -76,7 +76,7 @@
|
|||||||
import { Decimal } from 'decimal.js';
|
import { Decimal } from 'decimal.js';
|
||||||
import { Dialog } from "vant";
|
import { Dialog } from "vant";
|
||||||
import { myMixins } from "@/utils/myMixins"
|
import { myMixins } from "@/utils/myMixins"
|
||||||
import { uploadInvoice, getBillingInfo, deleteInvoice, createBatch } from "@/api/mine"
|
import { uploadInvoice, getBillingInfo, deleteInvoice, createBatch, jumpPage} from "@/api/mine"
|
||||||
export default {
|
export default {
|
||||||
name: "uploadInvoice",
|
name: "uploadInvoice",
|
||||||
mixins:[ myMixins ],
|
mixins:[ myMixins ],
|
||||||
@ -132,6 +132,10 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
async getJumpHandler() {
|
||||||
|
let res = await jumpPage();
|
||||||
|
return res
|
||||||
|
},
|
||||||
async initData() {
|
async initData() {
|
||||||
this.list = JSON.parse(localStorage.getItem('list'));
|
this.list = JSON.parse(localStorage.getItem('list'));
|
||||||
this.batchIds = [];
|
this.batchIds = [];
|
||||||
@ -230,7 +234,12 @@
|
|||||||
}).catch(() => {
|
}).catch(() => {
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
beforeRead (file) {
|
async beforeRead (file) {
|
||||||
|
let res = await this.getJumpHandler();
|
||||||
|
if(res?.data?.jump) {
|
||||||
|
this.$message.warning("您有没有完成的培训,请在中道调度APP上完成培训,再进行发票上传")
|
||||||
|
return false
|
||||||
|
}
|
||||||
const FileExt = file.name.replace(/.+\./, "");
|
const FileExt = file.name.replace(/.+\./, "");
|
||||||
if (['jpg', 'png', 'jpeg', 'pdf', 'ofd'].indexOf(FileExt.toLowerCase()) === -1) {
|
if (['jpg', 'png', 'jpeg', 'pdf', 'ofd'].indexOf(FileExt.toLowerCase()) === -1) {
|
||||||
this.$toast('请上传后缀名为jpg、jpeg、png、pdf、ofd的文件!')
|
this.$toast('请上传后缀名为jpg、jpeg、png、pdf、ofd的文件!')
|
||||||
|
@ -308,7 +308,7 @@ export default {
|
|||||||
}else{
|
}else{
|
||||||
this.supplierServiceList = this.oldSupplierServiceList
|
this.supplierServiceList = this.oldSupplierServiceList
|
||||||
}
|
}
|
||||||
|
this.setDefault();
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -321,6 +321,23 @@ export default {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods:{
|
methods:{
|
||||||
|
setDefault() {
|
||||||
|
if( this.vehicleLicenseInfo?.vehicleType?.includes('小型') || this.vehicleLicenseInfo?.vehicleType?.includes('微型') || this.vehicleLicenseInfo?.vehicleType?.includes('普通') || this.vehicleLicenseInfo?.vehicleType?.includes('摩托') ) {
|
||||||
|
this.vehicleTypes.map(item => {
|
||||||
|
if( item.value == 1 || item.value == 9 ) {
|
||||||
|
item.disabled = false;
|
||||||
|
} else {
|
||||||
|
item.disabled = true;
|
||||||
|
}
|
||||||
|
})
|
||||||
|
this.$forceUpdate();
|
||||||
|
} else {
|
||||||
|
this.vehicleTypes.map(item => {
|
||||||
|
item.disabled = false;
|
||||||
|
})
|
||||||
|
this.$forceUpdate();
|
||||||
|
}
|
||||||
|
},
|
||||||
getVehicleLicense(color) {
|
getVehicleLicense(color) {
|
||||||
if( color == '蓝' ) {
|
if( color == '蓝' ) {
|
||||||
this.vehicleLicense = 1
|
this.vehicleLicense = 1
|
||||||
@ -402,6 +419,7 @@ export default {
|
|||||||
this.vehicleLicenseInfo.registrationDate = frontInfo?.registerDate;
|
this.vehicleLicenseInfo.registrationDate = frontInfo?.registerDate;
|
||||||
this.vehicleLicenseInfo.issueDate = frontInfo?.issueDate;
|
this.vehicleLicenseInfo.issueDate = frontInfo?.issueDate;
|
||||||
this.vehicleLicenseInfo.issueAuthority = frontInfo?.seal;
|
this.vehicleLicenseInfo.issueAuthority = frontInfo?.seal;
|
||||||
|
this.setDefault();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async vehicleBackOcrHandler() { // 行驶证副页 ocr 识别
|
async vehicleBackOcrHandler() { // 行驶证副页 ocr 识别
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
:preview-src-list="[item]"
|
:preview-src-list="[item]"
|
||||||
class="swipeImg"
|
class="swipeImg"
|
||||||
/>
|
/>
|
||||||
<!-- <img v-if="item" class="swipeImg" :src="item" />-->
|
|
||||||
</el-carousel-item>
|
</el-carousel-item>
|
||||||
</el-carousel>
|
</el-carousel>
|
||||||
<van-swipe v-else @change="onChange" :autoplay="3000">
|
<van-swipe v-else @change="onChange" :autoplay="3000">
|
||||||
@ -34,8 +33,9 @@
|
|||||||
<span>{{ detailInfo.boardType?.label }}</span>
|
<span>{{ detailInfo.boardType?.label }}</span>
|
||||||
<span>{{ detailInfo.licenseType?.label }}</span>
|
<span>{{ detailInfo.licenseType?.label }}</span>
|
||||||
<span>{{detailInfo.brandModel?.match(/^[\u4e00-\u9fa5]+/)?.[0]?.replace(/牌$/, '')}}</span>
|
<span>{{detailInfo.brandModel?.match(/^[\u4e00-\u9fa5]+/)?.[0]?.replace(/牌$/, '')}}</span>
|
||||||
<span>{{ formatToWan(detailInfo.mileage) }}公里</span>
|
|
||||||
<span>{{ detailInfo.emissionStandard?.label }}</span>
|
<span>{{ detailInfo.emissionStandard?.label }}</span>
|
||||||
|
<span>{{ detailInfo.underpanBrand }}</span>
|
||||||
|
<span>{{ formatToWan(detailInfo.mileage) }}公里</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="time">
|
<div class="time">
|
||||||
<span>{{ detailInfo.createTime?.substring(0,10) }}</span><span>{{ detailInfo.areaName }}</span><span>发布</span>
|
<span>{{ detailInfo.createTime?.substring(0,10) }}</span><span>{{ detailInfo.areaName }}</span><span>发布</span>
|
||||||
|
@ -119,7 +119,7 @@
|
|||||||
<div class="right">
|
<div class="right">
|
||||||
<div class="title">{{item.vehicleType}}</div>
|
<div class="title">{{item.vehicleType}}</div>
|
||||||
<div v-if="activeTab==0" class="type">{{ item.boardType?.label ? item.boardType?.label+' | ' : ''}} {{ item.licenseType?.label }} |
|
<div v-if="activeTab==0" class="type">{{ item.boardType?.label ? item.boardType?.label+' | ' : ''}} {{ item.licenseType?.label }} |
|
||||||
{{ item.brandModel?.match(/^[\u4e00-\u9fa5]+/)?.[0]?.replace(/牌$/, '') }} | {{item.emissionStandard?.label}} | {{ formatToWan(item.mileage) }}公里</div>
|
{{ item.brandModel?.match(/^[\u4e00-\u9fa5]+/)?.[0]?.replace(/牌$/, '') }} | {{item.emissionStandard?.label}} | {{item.underpanBrand}} | {{ formatToWan(item.mileage) }}公里</div>
|
||||||
<div v-else class="type">{{ item.boardType?.label ? item.boardType?.label+' | ' : ''}} {{item.emissionStandard?.label}}</div>
|
<div v-else class="type">{{ item.boardType?.label ? item.boardType?.label+' | ' : ''}} {{item.emissionStandard?.label}}</div>
|
||||||
<div class="date" v-show="activeTab==0 && item.registerDate">注册日期: {{item.registerDate?.substring(0,10)}}</div>
|
<div class="date" v-show="activeTab==0 && item.registerDate">注册日期: {{item.registerDate?.substring(0,10)}}</div>
|
||||||
<div class="priceWrap" v-if="activeTab==0" >
|
<div class="priceWrap" v-if="activeTab==0" >
|
||||||
@ -354,6 +354,8 @@ export default {
|
|||||||
sessionStorage.setItem('areaCode',String(this.areaCode));
|
sessionStorage.setItem('areaCode',String(this.areaCode));
|
||||||
sessionStorage.setItem('areaName',this.areaName);
|
sessionStorage.setItem('areaName',this.areaName);
|
||||||
sessionStorage.setItem('dateVal',this.dateVal);
|
sessionStorage.setItem('dateVal',this.dateVal);
|
||||||
|
sessionStorage.setItem('brandModel',this.brandModel);
|
||||||
|
sessionStorage.setItem('underpanBrand',this.underpanBrand);
|
||||||
},
|
},
|
||||||
getSearchVal(){
|
getSearchVal(){
|
||||||
this.activeTab = Number(sessionStorage.getItem('indexActiveTab')) || 0;
|
this.activeTab = Number(sessionStorage.getItem('indexActiveTab')) || 0;
|
||||||
@ -367,6 +369,8 @@ export default {
|
|||||||
this.areaCode=Number(sessionStorage.getItem('areaCode')) || '';
|
this.areaCode=Number(sessionStorage.getItem('areaCode')) || '';
|
||||||
this.areaName=sessionStorage.getItem('areaName') || '';
|
this.areaName=sessionStorage.getItem('areaName') || '';
|
||||||
this.dateVal=sessionStorage.getItem('dateVal') || '';
|
this.dateVal=sessionStorage.getItem('dateVal') || '';
|
||||||
|
this.brandModel=sessionStorage.getItem('brandModel') || '';
|
||||||
|
this.underpanBrand=sessionStorage.getItem('underpanBrand') || '';
|
||||||
},
|
},
|
||||||
goMine(){//我的发布
|
goMine(){//我的发布
|
||||||
this.$router.push({ name: "mineRelease"})
|
this.$router.push({ name: "mineRelease"})
|
||||||
@ -428,6 +432,8 @@ export default {
|
|||||||
areaCode:this.areaCode,
|
areaCode:this.areaCode,
|
||||||
startTime:this.startTime,
|
startTime:this.startTime,
|
||||||
endTime:this.endTime,
|
endTime:this.endTime,
|
||||||
|
brandModel:this.brandModel,
|
||||||
|
underpanBrand:this.underpanBrand,
|
||||||
})
|
})
|
||||||
this.total=res.total
|
this.total=res.total
|
||||||
if(this.pageNum == 1){// 第一页直接赋值
|
if(this.pageNum == 1){// 第一页直接赋值
|
||||||
@ -686,9 +692,9 @@ export default {
|
|||||||
color: #282828;
|
color: #282828;
|
||||||
line-height: 23px;
|
line-height: 23px;
|
||||||
width: 200px;
|
width: 200px;
|
||||||
white-space: nowrap; /* 强制文本在一行显示 */
|
/* white-space: nowrap; !* 强制文本在一行显示 *!
|
||||||
overflow: hidden; /* 隐藏超出部分 */
|
overflow: hidden; !* 隐藏超出部分 *!
|
||||||
text-overflow: ellipsis; /* 超出部分显示省略号 */
|
text-overflow: ellipsis; !* 超出部分显示省略号 *!*/
|
||||||
}
|
}
|
||||||
.date{
|
.date{
|
||||||
font-weight: 400;
|
font-weight: 400;
|
||||||
|
@ -25,12 +25,12 @@
|
|||||||
<div class="label">{{item.startTime}}</div>
|
<div class="label">{{item.startTime}}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="alarm_content">
|
<div class="alarm_content">
|
||||||
<div class="label">车辆名称:</div>
|
<div class="label flexLabel">车辆名称:</div>
|
||||||
<div class="content">{{item.vehicleName}}</div>
|
<div class="content flexContent">{{item.vehicleName}}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="alarm_content">
|
<div class="alarm_content">
|
||||||
<div class="label">报警详情:</div>
|
<div class="label flexLabel">报警详情:</div>
|
||||||
<div class="content">{{item.alarmRemark}}</div>
|
<div class="content flexContent">{{item.alarmRemark}}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -200,6 +200,14 @@
|
|||||||
.label {
|
.label {
|
||||||
color: rgba(0, 0, 0, 0.5);
|
color: rgba(0, 0, 0, 0.5);
|
||||||
}
|
}
|
||||||
|
.flexLabel {
|
||||||
|
min-width: 50px;
|
||||||
|
flex-shrink: 0;
|
||||||
|
}
|
||||||
|
.flexContent {
|
||||||
|
flex: 1;
|
||||||
|
word-break: break-all;
|
||||||
|
}
|
||||||
.title_left {
|
.title_left {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
Reference in New Issue
Block a user