This commit is contained in:
tx 2024-08-09 18:03:26 +08:00
parent 2a081c7166
commit 77175a85d0
9 changed files with 367 additions and 139 deletions

View File

@ -1,20 +1,5 @@
const install = (Vue, vm) => {
// Vue.prototype.$u.http.setConfig({
// baseURL: 'https://yruibao.com/admin',
// // baseUrl: 'http://192.168.10.104:8088',
// method: 'POST',
// // 设置为json返回后会对数据进行一次JSON.parse()
// dataType: 'json',
// showLoading: true, // 是否显示请求中的loading
// loadingText: '请求加载中...', // 请求loading中的文字提示
// loadingTime: 10000, // 在此时间内请求还没回来的话就显示加载中动画单位ms
// originalData: false, // 是否在拦截器中返回服务端的原始数据
// loadingMask: true, // 展示loading的时候是否给一个透明的蒙层防止触摸穿透
// // 配置请求头信息
// header: {
// 'content-type': 'application/json;charset=UTF-8',
// },
// });
uni.setStorageSync('deptId', 100);
Vue.prototype.$u.http.setConfig({
@ -30,7 +15,8 @@ const install = (Vue, vm) => {
'content-type': 'application/json;charset=UTF-8',
},
});
// 创特:wx3428c498d5061192
// 俞山岛: wx4d178f8c80348214
// 请求拦截部分
Vue.prototype.$u.http.interceptor.request = (config) => {
// 引用token

View File

@ -40,12 +40,15 @@
style="margin-top: 18rpx;font-weight: 700;font-size: 92rpx;color: #3D3D3D;line-height: 72rpx;"><span
style="font-size: 52rpx;"></span>{{userinfo.balance}}</view>
<view class="btn" v-if="userinfo.balance!=0" @click="show=true">
<view class="btn" v-if="userinfo.balance!=0&&isInAuditOrder.length==0" @click="show=true">
提现
</view>
<view class="btn " v-else="false" @click="sub4">
充值押金
<view class="tit" v-if="isInAuditOrder.length!=0" style="font-size: 32rpx;color: #808080;margin-top: 0;">
有订单审核中暂时无法提现
</view>
<!-- <view class="btn " v-else="false" @click="sub4">
充值押金
</view> -->
</view>
<view class="card2" style="padding-bottom: 30rpx;">
<view class="card_top">
@ -203,7 +206,8 @@
loadingmask:true,
ispaid:false,
showtxtip:false,
showList:false
showList:false,
isInAuditOrder:[]
}
@ -213,7 +217,14 @@
// // ...
// });
this.$u.post("/app/user/isInAuditOrder?userId=" + this.userId).then((res) => {
if (res.code == 200) {
this.isInAuditOrder=res.data
} else {
}
});
this.getarea()
},
onLoad(e) {
@ -288,6 +299,7 @@
} else {
uni.hideLoading()
uni.showToast({
title: res.msg,
icon: 'none',
@ -670,7 +682,7 @@
padding: 28rpx 0;
margin: 30rpx auto;
width: 680rpx;
height: 406rpx;
// height: 406rpx;
background: #FFFFFF;
box-shadow: 0rpx 10rpx 64rpx 0rpx rgba(0, 0, 0, 0.08);
border-radius: 20rpx 20rpx 20rpx 20rpx;

View File

@ -159,15 +159,7 @@
"enablePullDownRefresh" : false
}
}
// {
// "path" : "worke/bind_sn",
// "style" :
// {
// "navigationBarTitleText" : "",
// "navigationStyle": "custom",
// "enablePullDownRefresh" : false
// }
// }
// ... A
]
@ -216,6 +208,22 @@
}
// ... A
]
},
{
"root": "pages_adminSet", // A
"pages": [
{
"path": "shgl",
"style": {
"navigationBarTitleText": "上传",
"enablePullDownRefresh": false,
"navigationStyle": "custom"
}
}
// ... A
]
},

View File

@ -305,8 +305,6 @@
</view> -->
</view>
<view class="bot" style="margin-top: 20rpx;" v-if="orderinfo.status==0">
<view class="btn" style=" margin-right: 16rpx;" @click="unlockdevice()">
解锁骑行
</view>
@ -318,14 +316,12 @@
</view>
</view>
<view class="bot" style="margin-top: 20rpx;" v-if="orderinfo.status==2">
<view class="changebiketip" @click="tochange()">
换车骑行 <view class="iconfont icon-xiangyou1">
</view>
</view>
<view class="btn" style=" margin-right: 16rpx;"
v-if="OrderdeviceInfos.status==3||OrderdeviceInfos.status==6" @click="taploadmask (2)">
v-if="OrderdeviceInfos.sn!='' && (OrderdeviceInfos.status == 3 || OrderdeviceInfos.status == 6)" @click="taploadmask (2)">
临时锁车
</view>
<view class="btn" style=" margin-right: 16rpx;" v-if="OrderdeviceInfos.status==4"
@ -1056,7 +1052,11 @@
isupload: false,
showparkinfo: false,
parkinfo: {},
netonlines: false
netonlines: false,
isqrcode:false,
deviceGps:{
}
}
},
watch: {
@ -1206,8 +1206,8 @@
that.latitude = lb.latitude;
that.longitude = lb.longitude;
that.deviceGps.latitude = lb.latitude;
that.deviceGps.longitude = lb.longitude;
console.log(that.areaInfo, 'that.areaInfo');
that.getArea()
if (that.qParam != 'null' && that.showagre == false) {
@ -1483,7 +1483,7 @@
// this.sn = ''
this.type = 0
this.freeInfo = {}
this.freeListIndex = 0
// this.freeListIndex = 0
this.mappolyline = []
// this.showparkinfo=false
// this.parkinfo={}
@ -1547,7 +1547,7 @@
this.deviceIndex = 0;
this.type = 0;
this.freeInfo = {};
this.freeListIndex = 0;
// this.freeListIndex = 0;
this.parkinfo = {}
this.showparkinfo = false
if (e.type === 'markertap') {
@ -1565,7 +1565,7 @@
if (markerExists) {
this.sn = e.markerId;
this.deviceInfo(0);
this.deviceInfo(1);
// Revert the last clicked marker to the default image and zIndex
if (this.lastClickedMarkerId !== null) {
@ -1650,57 +1650,7 @@
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 === parseFloat(this.OrderdeviceInfos.sn));
// markers
let updatedMarkers = [...newDeviceMarkers, ...preservedMarkers];
//
if (this.lastClickedMarkerId != null) {
updatedMarkers = updatedMarkers.map(marker => {
if (marker.id === this.lastClickedMarkerId) {
return {
...marker,
width: 50,
height: 35,
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();
@ -1708,6 +1658,7 @@
if (this.orderinfo.sn) {
this.$u.get('/app/device/info?sn=' + this.orderinfo.sn).then((res) => {
if (res.code === 200) {
this.isqrcode=false
this.mac = this.OrderdeviceInfos.mac;
// this.OrderdeviceInfos.onlineStatus = '1'
if (this.OrderdeviceInfos.onlineStatus !== res.data.onlineStatus) {
@ -2590,11 +2541,124 @@
})
},
getmarks() {
if(this.isqrcode){
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 === parseFloat(this.OrderdeviceInfos.sn));
// markers
let updatedMarkers = [...newDeviceMarkers, ...preservedMarkers];
//
if (this.lastClickedMarkerId != null) {
updatedMarkers = updatedMarkers.map(marker => {
if (marker.id === this.lastClickedMarkerId) {
return {
...marker,
width: 50,
height: 35,
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);
});
}
}else{
let data = {
longitude: this.deviceGps.longitude,
latitude: this.deviceGps.latitude,
}
this.$u.get(`/app/vehicleLocalization?`, data).then((res) => {
if (res.code === 200) {
if (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 === parseFloat(this.OrderdeviceInfos.sn));
// markers
let updatedMarkers = [...newDeviceMarkers, ...preservedMarkers];
//
if (this.lastClickedMarkerId != null) {
updatedMarkers = updatedMarkers.map(marker => {
if (marker.id === this.lastClickedMarkerId) {
return {
...marker,
width: 50,
height: 35,
iconPath: this.clickedMarkerIconPath
};
}
return marker;
});
}
// 使this.$setVue
this.$set(this, 'markers', updatedMarkers);
this.oldMarkers = [...this.markers];
} else {
// res.data markers
this.markers = this.markers.filter(marker => marker.isParkingMarker || marker.id === parseFloat(this.OrderdeviceInfos.sn));
// 使this.$setVue
this.$set(this, 'markers', this.markers);
}
}
}).catch(error => {
console.error("Error fetching device data:", error);
});
}
},
onMapRegionChange(event) {
// console.log('regionchange', event)
if (event.detail.type == 'end') {
// this.getCenterLanLat()
this.getCenterLanLat()
}
//
},
@ -2604,9 +2668,9 @@
type: 'gcj02',
success: (res) => {
console.log("当前地图中心的经纬度", res)
that.gps.latitude = res.latitude;
that.gps.longitude = res.longitude;
that.getAreas()
that.deviceGps.latitude = res.latitude;
that.deviceGps.longitude = res.longitude;
that.getmarks()
//
},
fail: (err) => {}
@ -2637,7 +2701,7 @@
this.setMapScale()
// this.setMapScale()
// if(!hasShownPopup){
// console.log(typeof(hasShownPopup),'hasShownPopuphasShownPopup');
// this.showTips=uni.getStorageSync('hasShownPopup')
@ -3550,7 +3614,7 @@
});
},
async setMapScale(e, val) {
console.log('调用了');
console.log('调用了校验');
let mapContext = uni.createMapContext('map', this);
let setScale = () => {
return new Promise((resolve, reject) => {
@ -4189,6 +4253,7 @@
changefree(item, index) {
this.freeInfo = item
this.freeListIndex = index
},
getlist() {
this.freList = []
@ -4206,6 +4271,13 @@
}
return item;
});
setTimeout(()=>{
this.freeInfo = this.freList[0]
this.freeListIndex = 1
console.log(this.freeListIndex,'this.freeListIndexthis.freeListIndexthis.freeListIndex');
},300)
console.log(this.freList, ' this.freList this.freList');
} else {
uni.showToast({
@ -4340,7 +4412,7 @@
}
},
getArea() {
this.showmap = false
// this.showmap = false
//
this.areaInfo = {}
console.log(this.qParam, 'qParamqParamqParamqParam');
@ -4357,12 +4429,10 @@
if (this.sn != '') {
this.gps.sn = this.sn
}
setTimeout(() => {
this.setMapScale()
}, 300)
this.$u.get('/app/area/info?', this.gps).then((res) => {
this.showmap = true
// this.showmap = true
if (res.code === 200) {
// 线
@ -4410,9 +4480,14 @@
}
if (this.sn) {
setTimeout(()=>{
this.deviceInfo(1)
this.qParam = null
},500)
if (this.orderinfo.status) {
this.showtcs = true
}else{
this.deviceInfo(1)
this.qParam = null
}
},800)
}
@ -4752,6 +4827,7 @@
this.$u.get('/app/device/info?sn=' + this.sn).then((res) => {
if (res.code === 200) {
this.isqrcode=true
this.deviceInfos = res.data;
if (!this.orderinfo.sn) {
this.mac = res.data.mac
@ -4863,6 +4939,7 @@
.then((
res) => {
if (res.code === 200) {
this.isqrcode=true
this.deviceInfos = res.data;
if (num == 0) {

View File

@ -651,50 +651,87 @@
运营区外调度费
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.dispatchFee" placeholder="0.00" class="input"
<input type="text" v-model="dispatchFee" placeholder="0.00" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('dispatchFee')">
</view>
</view>
<view class="ipt_box" style="width:100%;margin-top: 6rpx;">
<view class="width:10% ;">
</view>
<view style="color: #ccc;margin-left: auto; font-size: 24rpx;">
最大可退款金额:{{orderInfo.dispatchFee}}
</view>
</view>
<view class="ipt_box">
<view class="text">
停车点外调度费
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.manageFee" placeholder="0.00" class="input"
<input type="text" v-model="manageFee" placeholder="0.00" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('manageFee')">
</view>
</view>
<view class="ipt_box" style="width:100%;margin-top: 6rpx;">
<view class="width:10% ;">
</view>
<view style="color: #ccc;margin-left: auto; font-size: 24rpx;">
最大可退款金额:{{orderInfo.manageFee}}
</view>
</view>
<view class="ipt_box">
<view class="text">
骑行费
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.ridingFee" placeholder="0.00" class="input"
<input type="text" v-model="ridingFee" placeholder="0.00" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('ridingFee')">
</view>
</view>
<view class="ipt_box" style="width:100%;margin-top: 6rpx;">
<view class="width:10% ;">
</view>
<view style="color: #ccc;margin-left: auto; font-size: 24rpx;">
最大可退款金额:{{orderInfo.ridingFee}}
</view>
</view>
<view class="ipt_box">
<view class="text">
预约费
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.appointmentFee" placeholder="0.00" class="input"
<input type="text" v-model="appointmentFee" placeholder="0.00" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('appointmentFee')">
</view>
</view>
<view class="ipt_box" style="width:100%;margin-top: 6rpx;">
<view class="width:10% ;">
</view>
<view style="color: #ccc;margin-left: auto; font-size: 24rpx;">
最大可退款金额:{{orderInfo.appointmentFee}}
</view>
</view>
<view class="ipt_box">
<view class="text">
原因
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.reason" placeholder="选填" class="input"
<input type="text" v-model="reason" placeholder="选填" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('reason')">
</view>
</view>
</view>
<view class="bot">
<view class="bot_left" @click="closetk()">
@ -764,8 +801,13 @@
],
typeidx: '2',
areainfo:{},
passList:[]
passList:[],
dispatchFee:0,
manageFee:0,
ridingFee:0,
appointmentFee:0,
}
},
onShow() {
@ -919,7 +961,19 @@
appointmentFee: this.orderInfo.appointmentFee,
reason: this.orderInfo.reason
}
if (
data.dispatchFee > this.orderInfo.dispatchFee ||
data.manageFee > this.orderInfo.manageFee ||
data.ridingFee > this.orderInfo.ridingFee ||
data.appointmentFee > this.orderInfo.appointmentFee
) {
uni.showToast({
title: '退款金额不能大于实际支付金额',
icon: 'none',
duration: 2000
});
return; //
}
this.$u.put('/appVerify/order/refund', data).then((res) => {
if (res.code === 200) {
// 线

View File

@ -54,6 +54,12 @@
账户明细
</view>
</view>
<view class="cont" @click="topage(7)" >
<image src="https://lxnapi.ccttiot.com/bike/img/static/u47okd0YdEQBsyhLlQIt" mode="" style="width: 50rpx;height: 50rpx;"></image>
<view class="text">
故障审核
</view>
</view>
</view>
</view>
<u-select v-model="show" :list="list" title='选择运营区' @confirm="confirm"></u-select>
@ -212,6 +218,10 @@
uni.navigateTo({
url:'/pages_admin/worke/AccountDetails'
})
}else if(num==7){
uni.navigateTo({
url:'/pages_adminSet/shgl'
})
}
}
}

View File

@ -187,6 +187,9 @@
<view class="btn" @click="btn(7)">
车牌修改
</view>
<view class="btn" @click="btn(8)">
坐垫锁
</view>
<!-- <view class="btn" @click="tipshow=true" v-if="info.type==1">
维修处理
</view>
@ -572,7 +575,7 @@
}).catch(error => {
console.error("Error fetching area data:", error);
});
} else if (num == 4) {
} else if (num == 4) {
uni.showLoading({})
this.$u.post('/app/device/ring?sn=' + this.sn).then((res) => {
if (res.code == 200) {
@ -650,6 +653,23 @@
})
}else if (num == 9) {
this.$u.put('/appVerify/device/seatCushionLock?sn=' + this.sn).then((res) => {
if (res.code == 200) {
this.deviceInfo()
uni.showToast({
title: '操作成功',
icon: 'none',
duration: 2000
});
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
})
}
},

View File

@ -50,7 +50,20 @@
</view>
<view class="lines"></view>
<view class="cont">
<view class="info_li">
<view class="half_infoli" v-if="deviceInfos.onlineStatus==0">
网络状态<span style="color: #FF4444;">离线</span>
</view>
<view class="half_infoli" v-if="deviceInfos.onlineStatus==1">
网络状态<span >在线</span>
</view>
<view class="half_infoli" v-if="deviceInfos.lockStatus==0">
锁状态<span >关锁</span>
</view>
<view class="half_infoli" v-if="deviceInfos.lockStatus==1">
锁状态<span >开锁</span>
</view>
</view>
<view class="info_li">
<view class="half_infoli">
车牌号
@ -63,26 +76,16 @@
<span v-else>--</span>
</view>
</view>
<view class="info_li">
<view class="half_infoli" v-if="deviceInfos.onlineStatus==0">
网络状态<span >离线</span>
</view>
<view class="half_infoli" v-if="deviceInfos.onlineStatus==1">
网络状态<span >在线</span>
</view>
<!-- <view class="info_li">
<view class="half_infoli">
运营区域:
<span v-if="orderInfo.area">{{orderInfo.area}}</span>
<span v-else>--</span>
</view>
</view>
</view> -->
<view class="info_li">
<view class="half_infoli" v-if="deviceInfos.lockStatus==0">
锁状态<span >关锁</span>
</view>
<view class="half_infoli" v-if="deviceInfos.lockStatus==1">
锁状态<span >开锁</span>
</view>
</view>
</view>
@ -310,7 +313,7 @@
</view>
<u-mask :show="showload" :z-index='100' />
<u-mask :show="show" @click="show = false" :z-index='100' />
<u-mask :show="show" :z-index='100' />
<u-mask :show="showfzhc" @click="show = false" :z-index='100' />
<u-mask :show="showgj" :z-index='100' />
<view class="tip_box1" v-if="showgj">
@ -399,41 +402,77 @@
运营区外调度费
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.dispatchFee" placeholder="0.00" class="input"
<input type="text" v-model="dispatchFee" placeholder="0.00" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('dispatchFee')">
</view>
</view>
<view class="ipt_box" style="width:100%;margin-top: 6rpx;">
<view class="width:10% ;">
</view>
<view style="color: #ccc;margin-left: auto; font-size: 24rpx;">
最大可退款金额:{{orderInfo.dispatchFee}}
</view>
</view>
<view class="ipt_box">
<view class="text">
停车点外调度费
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.manageFee" placeholder="0.00" class="input"
<input type="text" v-model="manageFee" placeholder="0.00" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('manageFee')">
</view>
</view>
<view class="ipt_box" style="width:100%;margin-top: 6rpx;">
<view class="width:10% ;">
</view>
<view style="color: #ccc;margin-left: auto; font-size: 24rpx;">
最大可退款金额:{{orderInfo.manageFee}}
</view>
</view>
<view class="ipt_box">
<view class="text">
骑行费
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.ridingFee" placeholder="0.00" class="input"
<input type="text" v-model="ridingFee" placeholder="0.00" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('ridingFee')">
</view>
</view>
<view class="ipt_box" style="width:100%;margin-top: 6rpx;">
<view class="width:10% ;">
</view>
<view style="color: #ccc;margin-left: auto; font-size: 24rpx;">
最大可退款金额:{{orderInfo.ridingFee}}
</view>
</view>
<view class="ipt_box">
<view class="text">
预约费
</view>
<view class="ipt">
<input type="text" v-model="orderInfo.appointmentFee" placeholder="0.00" class="input"
<input type="text" v-model="appointmentFee" placeholder="0.00" class="input"
placeholder-style="color:#C7CDD3" @input="checkAndUpdate('appointmentFee')">
</view>
</view>
<view class="ipt_box" style="width:100%;margin-top: 6rpx;">
<view class="width:10% ;">
</view>
<view style="color: #ccc;margin-left: auto; font-size: 24rpx;">
最大可退款金额:{{orderInfo.appointmentFee}}
</view>
</view>
<view class="ipt_box">
<view class="text">
原因
@ -520,7 +559,11 @@
showload:false,
showfzhc:false,
showgj:false,
deviceInfos:{}
deviceInfos:{},
dispatchFee:0,
manageFee:0,
ridingFee:0,
appointmentFee:0,
}
},
@ -1124,7 +1167,19 @@
appointmentFee: this.orderInfo.appointmentFee,
reason: this.orderInfo.reason
}
if (
data.dispatchFee > this.orderInfo.dispatchFee ||
data.manageFee > this.orderInfo.manageFee ||
data.ridingFee > this.orderInfo.ridingFee ||
data.appointmentFee > this.orderInfo.appointmentFee
) {
uni.showToast({
title: '退款金额不能大于实际支付金额',
icon: 'none',
duration: 2000
});
return; //
}
this.$u.put('/appVerify/order/refund', data).then((res) => {
if (res.code === 200) {
// 线

View File

@ -212,11 +212,17 @@
},
onLoad() {
// if(uni.getStorageSync('adminAreaid')){
// this.areaId = uni.getStorageSync('adminAreaid')
// this.getDevice()
// }
},
onShow() {
if(uni.getStorageSync('adminAreaid')){
this.areaId = uni.getStorageSync('adminAreaid')
this.getDevice()
}
},
computed: {
isAllSelected() {