This commit is contained in:
Sliverber 2024-07-03 18:02:10 +08:00
parent efd58a0571
commit a677eb52fd
6 changed files with 596 additions and 1505 deletions

File diff suppressed because it is too large Load Diff

View File

@ -473,12 +473,13 @@
border-bottom: 2rpx solid #fff;
}
.qs_li{
margin-top: 10rpx;
// margin-top: 10rpx;
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: space-between;
border-bottom: 2rpx solid #D8D8D8;
border-bottom: 2rpx solid #D8D8D870;
padding-top: 26rpx;
padding-bottom: 26rpx;
.qs_li_txt{

View File

@ -174,7 +174,8 @@
areaInfo: "",
isback:false,
showBack:false,
loadingmask:false
loadingmask:false,
ispaid:false
}
@ -337,6 +338,8 @@
});
},
sub4() {
if(this.ispaid==false){
this.ispaid=true
let id = uni.getStorageSync('areaId');
let data = {
userId: this.userId,
@ -349,10 +352,11 @@
}
let that = this
this.$u.post('/appVerify/pre/order', data).then((res) => {
if (res.code === 200) {
// this.freList=res.rows
let that = this
uni.requestPayment({
provider: 'wxpay',
timeStamp: res.data.timeStamp,
@ -365,6 +369,7 @@
// uni.showLoading({
// title: ''
// })
that.ispaid=false
that.loadingmask=true
setTimeout(() => {
@ -379,6 +384,7 @@
},
fail(err) {
that.ispaid=false
//
uni.showToast({
title: '支付失败',
@ -388,6 +394,7 @@
}
});
} else {
that.ispaid=false
uni.showToast({
title: res.data,
icon: 'none',
@ -395,6 +402,10 @@
});
}
})
}
},
}
}

View File

@ -748,7 +748,7 @@
<view class="maskpage1" v-if="maskepage==5">
<view class="top_info">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uG3cbPgvPDzwlq6IHHxK" mode=""></image>
<view class="masktxt">
<view class="masktxt" v-if="orderinfo.sn">
蓝牙连接失败
</view>
</view>
@ -764,9 +764,13 @@
</view>
<view class="btn_box">
<view class="btn4" @click="maskloading=false">
<view class="btn4" @click="maskloading=false" v-if="orderinfo.sn">
继续用车
</view>
<view class="btn4" @click="maskloading=false" v-else>
返回
</view>
<view class="btn3" @click="Binddevice">
重新连接
@ -797,6 +801,30 @@
</view>
</view>
</view>
<view class="maskpage1" v-if="maskepage==7">
<view class="top_info">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uvAGhjbhjhSaxCru8dSN" mode=""
style="width: 25rpx;"></image>
<view class="masktxt">
设备电量过低
</view>
</view>
<view class="masktips" style="width: 100%;margin-top: 45rpx;">
请使用附近其他车辆
</view>
<view class="tipsimg" style="margin-top: 90rpx;">
<image src="https://lxnapi.ccttiot.com/bike/img/static/ugvqmfB3QYujZ6SnfTia" mode=""></image>
</view>
<view class="btn_box" style="justify-content: center;">
<view class="btn3" @click="maskloading=false" style="width: 600rpx;">
换车解锁
</view>
</view>
</view>
</view>
<view class="fixdivce">
</view>
</view>
</template>
@ -805,7 +833,8 @@
const app = getApp();
var xBlufi = require("@/utils/blufi/xBlufi.js");
let _this = null;
import QQMapWX from '@/common/qqmap-wx-jssdk.js'
import QQMapWX from '@/common/qqmap-wx-jssdk.min.js'
var qqmapsdk
export default {
data() {
return {
@ -920,8 +949,15 @@
navBarHeight: 0,
mappolyline: [],
qqmapsdk: {},
qqmapsdk: null,
index: 0,
lastClickedMarkerId: null, // To store the ID of the last clicked marker
defaultMarkerIconPath: 'https://api.ccttiot.com/smartmeter/img/static/uF9qLejuAZErNTrRuHq7',
clickedMarkerIconPath: 'https://lxnapi.ccttiot.com/bike/img/static/uf2TwgtQ2sKJrUY3wTz4',
ispaid:false,
isInParkingArea:null,
specificDeviceMarkerId:null
}
},
watch: {
@ -949,7 +985,7 @@
// #endif
this.qqmapsdk = new QQMapWX({
qqmapsdk = new QQMapWX({
key: 'E7OBZ-KRKWW-5VKRH-36XXR-TB3NS-MUFHB' // key
});
@ -993,40 +1029,7 @@
}, 500)
},
onShow() {
this.timers = setInterval(() => {
// console.log('...');
this.getmarks()
//
if (this.orderinfo.sn) {
this.$u.get('/app/device/info?sn=' + this.orderinfo.sn).then((res) => {
if (res.code === 200) {
this.mac = this.OrderdeviceInfos.mac
if (this.OrderdeviceInfos.onlineStatus != res.data.onlineStatus) {
this.OrderdeviceInfos = res.data
// this.OrderdeviceInfos.onlineStatus ='0'
// if (this.OrderdeviceInfos.onlineStatus == 0 && this.orderinfo.status !=
// 3) {
// if (this.carstause == false) {
// this.isnoline = true
// }
// }
}
} else {
//
}
}).catch(error => {
//
});
}
}, 3000); //
this.timestare()
//
uni.getBluetoothAdapterState({
success: function(res) {
@ -1085,7 +1088,7 @@
that.latitude = lb.latitude;
that.longitude = lb.longitude;
that.routePlanning(27.10557727,120.25709224)
console.log(that.areaInfo, 'that.areaInfo');
that.getArea()
if (that.qParam != 'null' && that.showagre == false) {
@ -1221,8 +1224,8 @@
routePlanning(end_lat, end_long) {
console.log('调用了');
let that = this
that.qqmapsdk.direction({
mode: 'driving', //
qqmapsdk.direction({
mode: 'walking', //
from: { // ()
latitude: that.latitude,
longitude: that.longitude
@ -1248,18 +1251,24 @@
longitude: coors[i + 1]
})
}
console.log('点串数组', pl)
// console.log('', pl)
// polyline线
that.mappolyline = [{
points: pl,
color: '#367EEF', // 线
width: 3, //
borderWidth: 2, // 线
borderColor: '#5B98FD', // 线
lineCap: 'square', // 线
showArrow: true, // 沿线
// color: '#367EEF', // 线
// width: 3, //
// borderWidth: 2, // 线
// borderColor: '#5B98FD', // 线
// lineCap: 'square', // 线
// showArrow: true, // 沿线
width: 8,
arrowLine: true,
color: '#00AF99',
strokeWidth: 2,
strokeColor: '#00AF99',
fillColor: '#00AF99'
}]
console.log(that.mappolyline,'that.mappolylinethat.mappolyline');
// console.log(that.mappolyline, 'that.mappolylinethat.mappolyline');
},
fail(res) {
console.log('resresresresresresres', res)
@ -1267,6 +1276,302 @@
})
},
onMapTap(event) {
this.showdevice = false
this.deviceIndex = 0
// this.sn = ''
this.type = 0
this.freeInfo = {}
this.freeListIndex = 0
this.mappolyline=[]
// const {
// latitude,
// longitude
// } = event.detail;
// console.log('Map tapped at:', latitude, longitude);
// this.close()
//
},
onMarkerTap(e) {
this.showdevice = false;
this.deviceIndex = 0;
this.type = 0;
this.freeInfo = {};
this.freeListIndex = 0;
if (e.type === 'markertap') {
console.log('Clicked marker:', e.markerId);
const markerExists = this.listData.some(item => item.sn == e.markerId);
if (markerExists) {
this.sn = e.markerId;
this.deviceInfo(0);
// Revert the last clicked marker to the default image
if (this.lastClickedMarkerId !== null) {
this.markers = this.markers.map(marker => {
if (marker.id === this.lastClickedMarkerId) {
return {
...marker,
iconPath: this.defaultMarkerIconPath
};
}
return marker;
});
}
// Update the clicked marker's image
this.markers = this.markers.map(marker => {
if (marker.id === e.markerId) {
return {
...marker,
iconPath: this.clickedMarkerIconPath
};
}
return marker;
});
// Store the ID of the currently clicked marker
this.lastClickedMarkerId = e.markerId;
// Get the latitude and longitude of the clicked marker
const clickedMarker = this.markers.find(marker => marker.id === e.markerId);
if (clickedMarker) {
const {
latitude,
longitude
} = clickedMarker;
console.log(`Clicked marker location - Latitude: ${latitude}, Longitude: ${longitude}`);
this.routePlanning(latitude, longitude)
// Find nearby markers
this.getNearbyMarkers(latitude, longitude);
}
// console.log(this.markers, 'Updated markers');
} else {
console.log('Marker ID does not exist in the list data');
}
// Prevent event bubbling
e.stopPropagation();
}
},
getNearbyMarkers(clickedLat, clickedLon) {
const nearbyMarkers = this.listData.filter(item => {
if (item.latitude && item.longitude) {
const distance = this.haversineDistance(
parseFloat(clickedLat),
parseFloat(clickedLon),
parseFloat(item.latitude),
parseFloat(item.longitude)
);
return distance <= 15;
}
return false;
});
console.log('Nearby markers within 15 meters:', nearbyMarkers);
},
haversineDistance(lat1, lon1, lat2, lon2) {
const R = 6371e3; // Earth radius in meters
const toRad = angle => angle * Math.PI / 180;
const dLat = toRad(lat2 - lat1);
const dLon = toRad(lon2 - lon1);
const a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
Math.cos(toRad(lat1)) * Math.cos(toRad(lat2)) *
Math.sin(dLon / 2) * Math.sin(dLon / 2);
const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
return R * c;
},
getmarks() {
let data = {
areaId: this.areaInfo.areaId
};
if (this.areaInfo.areaId) {
this.$u.get(`/app/allVehicleByArea`, data).then((res) => {
if (res.code === 200 && res.data != '') {
this.listData = res.data;
const newDeviceMarkers = this.listData.map(item => ({
id: parseFloat(item.sn),
latitude: parseFloat(item.latitude),
longitude: parseFloat(item.longitude),
width: 40,
height: 28,
iconPath: this.defaultMarkerIconPath,
isDeviceMarker: true //
}));
//
const preservedMarkers = this.markers.filter(marker => marker.isParkingMarker || marker.id === this.specificDeviceMarkerId);
// markers
let updatedMarkers = [...newDeviceMarkers, ...preservedMarkers];
//
if (this.lastClickedMarkerId !== null) {
updatedMarkers = updatedMarkers.map(marker => {
if (marker.id === this.lastClickedMarkerId) {
return {
...marker,
iconPath: this.clickedMarkerIconPath
};
}
return marker;
});
}
// 使this.$setVue
this.$set(this, 'markers', updatedMarkers);
this.oldMarkers = [...this.markers];
}
}).catch(error => {
console.error("Error fetching device data:", error);
});
}
},
timestare() {
this.timers = setInterval(() => {
this.getmarks();
if (this.orderinfo.sn) {
this.$u.get('/app/device/info?sn=' + this.orderinfo.sn).then((res) => {
if (res.code === 200) {
this.mac = this.OrderdeviceInfos.mac;
if (this.OrderdeviceInfos.onlineStatus != res.data.onlineStatus) {
this.OrderdeviceInfos = res.data;
}
// console.log(parseFloat(res.data.latitude),parseFloat(res.data.longitude),'');
// //
// this.specificDeviceMarkerId = parseFloat(this.orderinfo.sn);
// const specificDeviceMarker = {
// id: this.specificDeviceMarkerId,
// latitude: parseFloat(res.data.latitude),
// longitude: parseFloat(res.data.longitude),
// width: 40,
// height: 28,
// iconPath: 'https://lxnapi.ccttiot.com/bike/img/static/u5Im6YipwNSYiiaMTHxH',
// // isSpecificDeviceMarker: true //
// };
// //
// const preservedMarkers = this.markers.filter(marker => marker.id !== this.specificDeviceMarkerId);
// // markers
// const updatedMarkers = [...preservedMarkers, specificDeviceMarker];
// this.$set(this, 'markers', updatedMarkers);
} else {
//
}
}).catch(error => {
console.error("Error fetching specific device data:", error);
});
}
}, 3000); // 3
},
toggleIconAndCallout() {
this.showIconAndCallout = !this.showIconAndCallout;
this.markers = this.markers.map(marker => {
if (this.showIconAndCallout) {
// Show callout
if (marker.isParkingMarker) {
marker.callout.display = 'ALWAYS';
marker.isCalloutVisible = true;
}
} else {
// Hide callout
if (marker.isParkingMarker) {
marker.callout.display = 'BYCLICK';
marker.isCalloutVisible = false;
}
}
return marker;
});
// Force update markers array
this.$set(this, 'markers', [...this.markers]);
},
getParking() {
// Send request to get data
let data = {
areaId: this.areaInfo.areaId
};
this.$u.get('/app/parking/list?', data).then((res) => {
if (res.code === 200) {
// Process returned data
const type1Data = [];
const type2Data = [];
const type3Data = [];
res.rows.forEach(row => {
if (row.type == 1) {
type1Data.push(row);
} else if (row.type == 2) {
type2Data.push(row);
} else if (row.type == 3) {
type3Data.push(row);
}
});
const validBoundaries = type1Data.map(row => row.boundaryStr).filter(
boundary => typeof boundary === 'string' && boundary.trim() !== '');
const polylines = this.convertBoundaryToPolylines(validBoundaries, 1);
const validBoundaries1 = type2Data.map(row => row.boundaryStr).filter(
boundary => typeof boundary === 'string' && boundary.trim() !== '');
const polylines1 = this.convertBoundaryToPolylines(validBoundaries1, 2);
const validBoundaries2 = type3Data.map(row => row.boundaryStr).filter(
boundary => typeof boundary === 'string' && boundary.trim() !== '');
const polylines2 = this.convertBoundaryToPolylines(validBoundaries2, 3);
// Add processed data to this.polyline
this.polyline = this.polyline.concat(polylines2);
this.polyline = this.polyline.concat(polylines1);
this.polyline = this.polyline.concat(polylines);
this.parkingList = res.rows;
// Set parking markers and distinguish them
const newParkingMarkers = res.rows.map(item => ({
id: parseFloat(item.parkingId),
latitude: parseFloat(item.latitude),
longitude: parseFloat(item.longitude),
width: 20,
height: 29,
iconPath: item.type == 1 ?
'https://lxnapi.ccttiot.com/bike/img/static/up2xXqAgwCX5iER600k3' :
item.type == 2 ?
'https://lxnapi.ccttiot.com/bike/img/static/u53BAQcFIX3vxsCzEZ7t' :
'https://lxnapi.ccttiot.com/bike/img/static/uDNY5Q4zOiZTCBTA2Jdq',
callout: {
content: item.parkingName,
color: '#ffffff',
fontSize: 14,
borderRadius: 10,
bgColor: item.type == 1 ? '#3A7EDB' : item.type == 2 ?
'#FFC107' : '#FF473E',
padding: 6,
display: 'BYCLICK' // Initially do not show callout
},
isCalloutVisible: false, // Initially do not show callout
isParkingMarker: true // Distinguish as parking marker
}));
// Preserve device markers and specific device marker
const preservedMarkers = this.markers.filter(marker => marker.isDeviceMarker || marker.id === this.specificDeviceMarkerId);
// Merge parking markers and device markers
this.markers = [...newParkingMarkers, ...preservedMarkers];
this.$set(this, 'markers', [...this.markers]);
}
}).catch(error => {
console.error("Error fetching parking data:", error);
});
},
totxtpage() {
this.seeDetail = true
uni.navigateTo({
@ -1313,6 +1618,9 @@
// this.showYjTip = true;
} else if (res.msg == '【扫码/编号开锁骑行】发送开锁命令失败') {
this.maskepage = 3
} else if (res.msg == '低电量不得骑行') {
this.maskepage = 7
// this.offopencar()
} else {
// uni.showToast({
// title: res.msg,
@ -1322,7 +1630,11 @@
this.toploadtxt = '开锁失败';
setTimeout(() => {
this.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 800);
}
}
@ -1516,7 +1828,8 @@
let data = {
latitude: lb.latitude,
longitude: lb.longitude,
areaId: that.areaInfo.areaId
areaId: that.areaInfo.areaId,
sn:that.OrderdeviceInfos.sn
}
that.backgps.latitude = lb.latitude
that.backgps.longitude = lb.longitude
@ -1528,6 +1841,7 @@
let parkingReturn = res.data
.parkingReturn /** 强制停车点还车 true:开启false:关闭*/
let isInParkingArea = res.data.isInParkingArea /** 是否在停车区内*/
that.isInParkingArea=res.data.isInParkingArea
if (parkingReturn) {
//
if (isInParkingArea) {
@ -1544,7 +1858,7 @@
'/appVerify/device/return?returnType=1&orderNo=' +
that.orderinfo.orderNo + '&isBluetooth=true' +
'&lon=' + that.backgps.longitude + '&lat=' +
that.backgps.latitude).then((
that.backgps.latitude+'&isInParkingArea='+that.isInParkingArea).then((
res) => {
if (res.code === 200) {
@ -1564,6 +1878,11 @@
that.toploadtxt = '还车失败';
setTimeout(() => {
that.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 1000);
}
@ -1593,7 +1912,7 @@
that.orderinfo
.orderNo + '&isBluetooth=true' + '&lon=' + that
.backgps.longitude + '&lat=' + that.backgps
.latitude).then((
.latitude+'&isInParkingArea='+that.isInParkingArea).then((
res) => {
if (res.code === 200) {
@ -1614,6 +1933,11 @@
that.toploadtxt = '还车失败';
setTimeout(() => {
that.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 1000);
}
})
@ -1671,6 +1995,11 @@
that.toploadtxt = '校验失败';
setTimeout(() => {
that.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 1000);
// uni.showToast({
// title: res.msg,
@ -1730,7 +2059,7 @@
this.$u.post('/appVerify/device/return?returnType=1&orderNo=' + this.orderinfo
.orderNo + '&isBluetooth=true' + '&lon=' + this.backgps.longitude +
'&lat=' + this.backgps
.latitude).then((
.latitude+'&isInParkingArea='+this.isInParkingArea).then((
res) => {
if (res.code === 200) {
@ -1753,6 +2082,11 @@
this.buletxt = '还车失败!';
setTimeout(() => {
this.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
this.getisInOrder();
}, 1000);
// uni.showToast({
@ -1776,7 +2110,7 @@
},
backDevice() {
this.$u.post('/appVerify/device/return?returnType=1&orderNo=' + this.orderinfo.orderNo).then((
this.$u.post('/appVerify/device/return?returnType=1&orderNo=' + this.orderinfo.orderNo+'&isInParkingArea='+this.isInParkingArea).then((
res) => {
if (res.code === 200) {
@ -1793,6 +2127,11 @@
this.toploadtxt = '还车失败';
setTimeout(() => {
this.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 1000);
}
})
@ -1976,6 +2315,8 @@
this.$u.post('/appVerify/device/snSwitch', data).then((res) => {
// uni.hideLoading();
this.seeDetail = false;
// res.code=500
// res.msg=''
if (res.code === 200) {
this.loadimg = 'https://lxnapi.ccttiot.com/bike/img/static/upNvRa9ZQMyiwxLliF5z';
this.toploadtxt = '开锁成功';
@ -1990,18 +2331,21 @@
this.maskepage = 6
// this.showYjTip = true;
} else if (res.msg == '【扫码/编号开锁骑行】发送开锁命令失败') {
// this.maskepage=3
// this.maskepage=3
this.offopencar()
} else if (res.msg == '低电量不得骑行') {
this.maskepage = 7
// this.offopencar()
} else {
// uni.showToast({
// title: res.msg,
// icon: 'none',
// duration: 2000
// });
this.toploadtxt = '开锁失败';
setTimeout(() => {
this.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 800);
}
}
@ -2389,6 +2733,11 @@
that.buletxt = '开锁失败';
setTimeout(() => {
that.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 1000);
// if (res.msg == '10500-----') {
// uni.showToast({
@ -2454,6 +2803,11 @@
this.toploadtxt = '锁车失败';
setTimeout(() => {
this.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 1000);
// if (res.msg == '10500-----') {
@ -2512,6 +2866,11 @@
that.buletxt = '锁车失败';
setTimeout(() => {
that.maskloading = false;
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}, 1000);
@ -3090,21 +3449,7 @@
url: '/page_user/agreement'
})
},
onMapTap(event) {
this.showdevice = false
this.deviceIndex = 0
// this.sn = ''
this.type = 0
this.freeInfo = {}
this.freeListIndex = 0
// const {
// latitude,
// longitude
// } = event.detail;
// console.log('Map tapped at:', latitude, longitude);
// this.close()
//
},
// lockDevice() {
// if (this.orderinfo.status) {
// this.showtcs = true
@ -3399,6 +3744,8 @@
},
//
topay1() {
if(this.ispaid==false){
this.ispaid=true
let data = {
userId: this.userId,
sn: this.orderinfo.sn,
@ -3427,12 +3774,18 @@
signType: res.data.signType,
paySign: res.data.paySign,
success(res) {
that.ispaid=false
console.log('支付成功');
//
clearInterval(that.timer)
that.orderinfo = {}
that.showdevice = false
that.deviceIndex = 0
that.getisInOrder()
},
fail(err) {
that.ispaid=false
//
uni.showToast({
title: '支付失败',
@ -3442,6 +3795,7 @@
}
});
} else {
that.ispaid=false
uni.showToast({
title: res.msg,
icon: 'none',
@ -3449,6 +3803,9 @@
});
}
})
}
},
@ -3860,95 +4217,21 @@
});
},
findBike() {
uni.showToast({
title: '响铃请求发送成功',
icon: 'none',
duration: 2000
});
uni.showLoading({
})
// uni.showToast({
// title: '',
// icon: 'none',
// duration: 2000
// });
this.$u.post('/app/device/ring?sn=' + this.sn).then((res) => {
if (res.code === 200) {
uni.hideLoading()
}
})
},
onMarkerTap(e) {
this.showdevice = false
this.deviceIndex = 0
// this.sn = ''
this.type = 0
this.freeInfo = {}
this.freeListIndex = 0
if (e.type === 'markertap') {
console.log('点击了标记:', e.markerId);
//
// \
const markerExists = this.listData.some(item => item.sn == e.markerId);
if (markerExists) {
//
this.sn = e.markerId;
this.deviceInfo(0);
// this.markers = this.markers.map(item => {
// if (item.sn === e.markerId) { // markersmarksn
// //
// return {
// ...item,
// width: item.width * 2, // 2550
// height: item.height * 2 // 2550
// };
// }
// return item;
// });
console.log(this.markers, 'this.markersthis.markers');
} else {
console.log('标记ID不存在于列表数据中');
}
//
e.stopPropagation();
}
},
getmarks() {
let data = {
areaId: this.areaInfo.areaId
};
if (this.areaInfo.areaId) {
this.$u.get(`/app/allVehicleByArea`, data).then((res) => {
if (res.code === 200 && res.data != '') {
this.listData = res.data
// this.listData[0].onlineStatus=0
// this.listData = res.data.filter(item => item.onlineStatus != 0);
const newDeviceMarkers = this.listData.map(item => ({
id: parseFloat(item.sn),
latitude: parseFloat(item.latitude),
longitude: parseFloat(item.longitude),
width: 40,
height: 28, //
iconPath: 'https://api.ccttiot.com/smartmeter/img/static/uF9qLejuAZErNTrRuHq7',
isDeviceMarker: true //
}));
//
const preservedMarkers = this.markers.filter(marker => marker.isParkingMarker);
// markers
this.markers = [...newDeviceMarkers, ...preservedMarkers];
this.$set(this, 'markers', [...this.markers]);
this.oldMarkers = [...this.markers];
}
}).catch(error => {
console.error("Error fetching device data:", error);
});
}
},
isMarkersChanged(newMarkers) {
if (this.oldMarkers.length !== newMarkers.length) {
return true;
@ -4121,106 +4404,7 @@
console.error("Error fetching area data:", error);
});
},
toggleIconAndCallout() {
this.showIconAndCallout = !this.showIconAndCallout;
this.markers = this.markers.map(marker => {
if (this.showIconAndCallout) {
//
if (marker.isParkingMarker) {
marker.callout.display = 'ALWAYS';
marker.isCalloutVisible = true;
}
} else {
//
if (marker.isParkingMarker) {
marker.callout.display = 'BYCLICK';
marker.isCalloutVisible = false;
}
}
return marker;
});
// markers
this.$set(this, 'markers', [...this.markers]);
},
getParking() {
//
let data = {
areaId: this.areaInfo.areaId
}
this.$u.get('/app/parking/list?', data).then((res) => {
if (res.code === 200) {
//
const type1Data = [];
const type2Data = [];
const type3Data = [];
res.rows.forEach(row => {
if (row.type == 1) {
type1Data.push(row);
} else if (row.type == 2) {
type2Data.push(row);
} else if (row.type == 3) {
type3Data.push(row);
}
});
const validBoundaries = type1Data.map(row => row.boundaryStr).filter(
boundary =>
typeof boundary === 'string' && boundary.trim() !== '');
const polylines = this.convertBoundaryToPolylines(validBoundaries, 1);
const validBoundaries1 = type2Data.map(row => row.boundaryStr).filter(
boundary =>
typeof boundary === 'string' && boundary.trim() !== '');
const polylines1 = this.convertBoundaryToPolylines(validBoundaries1, 2);
const validBoundaries2 = type3Data.map(row => row.boundaryStr).filter(
boundary =>
typeof boundary === 'string' && boundary.trim() !== '');
const polylines2 = this.convertBoundaryToPolylines(validBoundaries2, 3);
// this.polyline
this.polyline = this.polyline.concat(polylines2);
this.polyline = this.polyline.concat(polylines1);
this.polyline = this.polyline.concat(polylines);
this.parkingList = res.rows;
//
const newParkingMarkers = res.rows.map(item => ({
id: parseFloat(item.parkingId),
latitude: parseFloat(item.latitude),
longitude: parseFloat(item.longitude),
width: 20,
height: 29,
iconPath: item.type == 1 ?
'https://lxnapi.ccttiot.com/bike/img/static/up2xXqAgwCX5iER600k3' :
item
.type == 2 ?
'https://lxnapi.ccttiot.com/bike/img/static/u53BAQcFIX3vxsCzEZ7t' :
'https://lxnapi.ccttiot.com/bike/img/static/uDNY5Q4zOiZTCBTA2Jdq',
callout: {
content: item.parkingName,
color: '#ffffff',
fontSize: 14,
borderRadius: 10,
bgColor: item.type == 1 ? '#3A7EDB' : item.type == 2 ?
'#FFC107' : '#FF473E',
padding: 6,
display: 'BYCLICK' //
},
isCalloutVisible: false, //
isParkingMarker: true //
}));
//
const preservedMarkers = this.markers.filter(marker => marker.isDeviceMarker);
//
this.markers = [...newParkingMarkers, ...preservedMarkers];
this.$set(this, 'markers', [...this.markers]);
}
}).catch(error => {
console.error("Error fetching parking data:", error);
});
},
convertBoundaryToPolyline(boundary) {
if (!boundary) return null;
@ -4590,7 +4774,7 @@
duration: 4000
});
} else if (this.deviceInfos.status == 1) {
this.routePlanning(res.data.latitude,res.data.longitude)
// this.routePlanning(res.data.latitude, res.data.longitude)
this.showdevice = true
this.type = 1;
this.deviceIndex = 1;
@ -4633,7 +4817,8 @@
this.deviceInfos = res.data;
if (num == 0) {
this.routePlanning(res.data.latitude,res.data.longitude)
// this.routePlanning(res.data.latitude,
// res.data.longitude)
this.showdevice = true;
this.type = 0;
} else {
@ -4705,7 +4890,9 @@
} else if (this.deviceInfos
.status ==
1) {
this.routePlanning(res.data.latitude,res.data.longitude)
// this.routePlanning(res.data
// .latitude, res.data
// .longitude)
this.showdevice = true;
this.type = 1;
this.deviceIndex = 1;
@ -4792,7 +4979,9 @@
.page {
width: 750rpx;
// .fixdivce{
// }
.maskload {
position: fixed;
@ -5084,7 +5273,7 @@
width: 370rpx;
height: 73rpx;
position: fixed;
bottom: 600rpx;
bottom: 35.5vh;
left: 38rpx;
.tipss {

View File

@ -135,7 +135,7 @@
infonum: {},
rangeMin: 0,
rangMax: 100,
rangeValue: [1, 100],
rangeValue: [0, 100],
status0: [], //
status1: [], //
status2: [], //

View File

@ -37,24 +37,36 @@
</view>
<view class="info">
<view class="info_li">
总营收
订单总费用
<span style="color: #4C97E7;" >{{displayAmount(info.income.totalFee) }}</span>
</view>
<view class="info_li">
手续费
<span style="color: #4C97E7;" >{{displayAmount(info.income.handlingFee)}}</span>
</view>
</view>
<view class="info">
<view class="info_li">
总营收:
<span style="color: #4C97E7;" v-if="info.income.totalIncome">{{info.income.totalIncome}}</span>
<span style="color: #4C97E7;" v-else>--</span>
</view>
<view class="info_li">
累计待支付
累计待支付:
<span style="color: #4C97E7;" v-if="info.income.totalUnpaid">{{info.income.totalUnpaid}}</span>
<span style="color: #4C97E7;" v-else>--</span>
</view>
</view>
<view class="info">
<view class="info_li">
已支付
已支付:
<span style="color: #3D3D3D;" v-if="info.income.totalPaid">{{info.income.totalPaid}}</span>
<span style="color: #3D3D3D;" v-else>--</span>
</view>
<view class="info_li">
已退款
已退款:
<span style="color: #3D3D3D;" v-if="info.income.totalRefund">{{info.income.totalRefund}}</span>
<span style="color: #3D3D3D;" v-else>--</span>
</view>