diff --git a/common/http.interceptor.js b/common/http.interceptor.js
index af7f478..21a6bb2 100644
--- a/common/http.interceptor.js
+++ b/common/http.interceptor.js
@@ -22,18 +22,7 @@ const install = (Vue, vm) => {
 	// 俞山岛:	wx4d178f8c80348214
     // 请求拦截部分
     Vue.prototype.$u.http.interceptor.request = (config) => {
-        // 引用token
-        // 方式一,存放在vuex的token,假设使用了uView封装的vuex方式
-        // 见:https://uviewui.com/components/globalVariable.html
-        // config.header.token = vm.token;
-
-        // 方式二,如果没有使用uView封装的vuex方法,那么需要使用$store.state获取
-        // config.header.token = vm.$store.state.token;
-
-        // 方式三,如果token放在了globalData,通过getApp().globalData获取
-
-        // 方式四,如果token放在了Storage本地存储中,拦截是每次请求都执行的
-        // 所以哪怕您重新登录修改了Storage,下一次的请求将会是最新值
+       
         const token = uni.getStorageSync('token');
 
         // const token = "Bearer eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6IjQ0ZDljYzBlLThjZjEtNGFkOC05OGFjLThlNThjMWIxYjQ3OSJ9.v-aMkp9t7Z_QfjfsZy6d_1Ng76hPYa0A--SWScMJY9to7UlNv9IxHQnTJylLKdYKGrr8fRZ47Bu12UPm1DgMQg"
@@ -46,6 +35,8 @@ const install = (Vue, vm) => {
         // #endif
         // 可以对某个url进行特别处理,此url参数为this.$u.get(url)中的url值
         if (config.url == '/user/login') config.header.noToken = true;
+		
+		
         // 最后需要将config进行return
         return config;
 
@@ -55,50 +46,7 @@ const install = (Vue, vm) => {
 
     // 响应拦截部分
     Vue.prototype.$u.http.interceptor.response = (res) => {
-        // if(res.code == 10022 || res.code == 10023) {
-        //     // res为服务端返回值,可能有code,result等字段
-        //     // 这里对res.result进行返回,将会在this.$u.post(url).then(res => {})的then回调中的res的到
-        //     // 如果配置了originalData为true,请留意这里的返回值
-        //     uni.redirectTo({
-        //         url:"/pages/login/login",
-        //         fail:function(mes){
-        //             console.log(mes)
-        //         },
-        //         success:function(mes){
-        //             console.log(mes)
-        //         }
-        //     })
-        //     // return res.result;
-        // }
-        // if (res.code == 401) {
-        //     wx.login({
-        //         success(res) {
-        //             if (res.code) {
-        //                 // console.log('登录!', res);
-        //                 let areaId = uni.getStorageSync('areaId');
-        //                 if (areaId) {
-        //                     vm.$u.post('/loginByopenid?jsCode=' + res.code + '&areaId=' + areaId).then(
-        //                         res => {
-        //                             uni.hideLoading();
-        //                             if (res.code == 200) {
-        //                                 uni.setStorageSync('token', res.token);
-        //                             } else if (res.code == 501) {
-        //                                 uni.showToast({
-        //                                     title: res.msg,
-        //                                     icon: 'none',
-        //                                     duration: 2000
-        //                                 });
-        //                             } else {
-        //                                 uni.navigateTo({
-        //                                     url: '/pages/login/login'
-        //                                 })
-        //                             }
-        //                         });
-        //                 }
-        //             }
-        //         },
-        //     });
-        // }
+      
         return res;
     }
 
diff --git a/page_user/jfgz.vue b/page_user/jfgz.vue
index 00da0dd..15b1b43 100644
--- a/page_user/jfgz.vue
+++ b/page_user/jfgz.vue
@@ -7,7 +7,7 @@
 					骑行服务费
 				</view>
 				<view class="card">
-					<view class="li">
+					<view class="li" v-if="false">
 						<view class="left">
 							预约服务费
 						</view>
@@ -16,17 +16,17 @@
 						</view>
 					</view>
 					
-					<view class="li" style="margin-top: 38rpx;">
+					<view class="li" >
 						<view class="left">
 							押金
 						</view>
 						<view class="right">
-							{{areaInfo.vehicleManagementFee}}元
+							{{areaInfo.deposit}}元
 						</view>
 					</view>
 					
 				</view>
-				<view class="tips" style="margin-top: 10rpx;margin-left: 5rpx;">
+				<view class="tips" style="margin-top: 10rpx;margin-left: 5rpx;" v-if="false">
 					<view class="yuan">
 					</view>
 					<view class="txt">
diff --git a/pages/index/index.vue b/pages/index/index.vue
index 98659cb..10770db 100644
--- a/pages/index/index.vue
+++ b/pages/index/index.vue
@@ -1440,67 +1440,127 @@ export default {
 				});
 				return;
 			}
+// this.showmap = false
+				// 发送请求获取数据
+				this.areaInfo = {}
+				// console.log(this.qParam, 'qParamqParamqParamqParam');
+				this.polyline = []
+				// if(this.qParam){
 
-			// 重置数据
-			this.areaInfo = {}
-			this.polyline = []
+				// }
+				// console.log(this.sn,'this.gps.sn this.gps.sn this.gps.sn ');
 
-			// 处理设备编号
-			if (this.orderinfo.sn) {
-				this.gps.sn = this.orderinfo.sn
-			}
-			if (/^\d{7}$/.test(this.qParam)) {
-				this.gps.sn = this.qParam
-			}
-			if (this.deviceInfos.sn) {
-				this.gps.sn = this.deviceInfos.sn
-			}
-			if (this.qParam != '' && this.qParam != null) {
-				this.sn = this.getSNFromQRCode(this.qParam);
-				if (this.sn != 0 && this.sn != '' && this.sn != null) {
-					this.gps.sn = this.sn
+				// console.log(this.qParam,'qParamqParamqParamqParam');
+				if (/^\d{7}$/.test(this.qParam)) {
+					this.gps.sn = this.qParam
+					console.log(this.gps.sn, 'this.gps.sn this.gps.sn this.gps.sn ');
+				}
+				if (this.orderinfo.sn != '') {
+					this.gps.sn = this.orderinfo.sn
+				}
+				if (this.deviceInfos.sn) {
+					this.gps.sn = this.deviceInfos.sn
+				}
+				if (this.qParam != '' && this.qParam != null) {
+					this.sn = this.getSNFromQRCode(this.qParam);
+
+					if (this.sn != 0 && this.sn != '' && this.sn != null) {
+						this.gps.sn = this.sn
+						console.log(this.sn, 'qParamqParamqParamqParam');
+
+					}
 				}
-			}
-			setTimeout(() => {
 				this.$u.get('/app/area/info?', this.gps).then((res) => {
-				if (res.code === 200) {
-					const polylines = this.convertBoundaryToPolyline(res.data.boundaryStr)
-					this.areaInfo = res.data
-					this.polyline.push(polylines)
-					uni.setStorageSync('areaId', res.data.areaId);
+					// this.showmap = true
+					if (res.code === 200) {
 
-					// 基础数据获取
-					this.getinfo()
-					this.getmarks()
-					this.getParking()
+						// 处理接口返回的数据,将边界数据转换为地图组件需要的折线结构
+						const polylines = this.convertBoundaryToPolyline(res.data.boundaryStr)
+					
+						// 更新折线数据
+						this.areaInfo = res.data
+						setTimeout(() => {
+							let abb = this.cleanedText()
+							console.log(abb.length, 'cleanedTextcleanedTextcleanedText');
 
-					if (uni.getStorageSync('token') && this.islogin) {
-						this.getisInOrder()
-					}
+							// 计算滚动时间,基于文本宽度
+							this.duration = abb.length * 0.3; // 50 px/s 的速度
+						}, 200)
+
+						this.polyline.push(polylines)
+						console.log();
+						// console.log(this.areaInfo, 'areaInfoareaInfo');
+						uni.setStorageSync('areaId', res.data.areaId);
+						this.getinfo()
+						this.getmarks()
+						// this.getlist()
+						this.getParking()
+						if (uni.getStorageSync('token')&&this.islogin) {
+							this.getisInOrder()
 
-					// 处理设备信息
-					if (this.gps.sn && /^\d{7}$/.test(this.gps.sn) && !this.isqrcode) {
-						if (!this.deviceInfos.sn) {
-							this.deviceInfo(this.qParam ? 1 : 0)
-							this.qParam = null
 						}
+						const hasShownPopup = uni.getStorageSync('hasShownPopup');
+						console.log(hasShownPopup, 'hasShownPopup');
+
+						if (hasShownPopup === '' || hasShownPopup === null) {
+							console.log('1111111111');
+
+							this.showTips = true;
+							this.startCountdown();
+							uni.setStorageSync('hasShownPopup', true);
+						} else {
+							console.log('222');
+							this.showTips = uni.getStorageSync('hasShownPopup');
+							console.log(this.showTips, 'this.showTips');
+							this.startCountdown();
+
+						}
+						if (this.gps.sn && /^\d{7}$/.test(this.gps.sn)) {
+							setTimeout(() => {
+								if (this.orderinfo.status) {
+									// this.showtcs = true
+								} else {
+									// if(this.showdevice==false&&){
+									// 	console.log('进入的判断1');
+									// 	this.deviceInfo(1)
+									// 	this.qParam = null
+									// } 
+									if (this.deviceInfos.sn) {
+
+									} else {
+										if (this.qParam) {
+											console.log('进入的判断2');
+											this.deviceInfo(1)
+											this.qParam = null
+										} else {
+											console.log('进入的判断3');
+											// if(this.de)
+											this.deviceInfo(0)
+											this.qParam = null
+										}
+									}
+
+
+
+								}
+
+							}, 200)
+
+						}
+
+						
+					} else {
+						uni.showToast({
+							title: res.msg,
+							icon: 'none',
+							duration: 2000
+						});
 					}
-				} else {
-					uni.showToast({
-						title: res.msg,
-						icon: 'none',
-						duration: 2000
-					});
-				}
-			}).catch(error => {
-				console.error("Error fetching area data:", error);
-			});
-			}, 500);
-
-
+				}).catch(error => {
+					console.error("Error fetching area data:", error);
+				});
 			
 		},
-
 		deviceInfo(num) {
 			if (!this.sn) return;
 
diff --git a/pages_admin/admin_worke.vue b/pages_admin/admin_worke.vue
index d741311..d8c613c 100644
--- a/pages_admin/admin_worke.vue
+++ b/pages_admin/admin_worke.vue
@@ -1,4 +1,4 @@
-<template>
+ <template>
 	<view class="page">
 		<view class="toptit" @click="shows()">
 			{{areaInfo.areaName}}
@@ -11,78 +11,62 @@
 				<image src="https://lxnapi.ccttiot.com/bike/img/static/uMlgu6j9jnDqP1ZFL7xj" mode=""></image>
 				应用入口
 			</view>
-			<view class="app_box">
-				<view class="cont" @click="topage(0)" v-if="deptId==100">
+			<view class="app_box" v-if="menuList.length>0">
+				<view class="cont" @click="topage(0)" v-if="hasMenuPermission('运营数据') ">
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/unnmUkUif2eWNKFq9fdg" mode=""></image>
 					<view class="text">
 						运营数据
 					</view>
 				</view>
-				<!-- <view class="cont"  @click="topage(1)">
-					<image src="https://lxnapi.ccttiot.com/bike/img/static/upJFJIIZ4hbSEuchNQi3" mode=""></image>
-					<view class="text">
-						收入对账
-					</view>
-				</view> -->
-				<view class="cont"  @click="topage(8)" v-if="deptId==101">
+				
+				<view class="cont"  @click="topage(8)" v-if="hasMenuPermission('财务报表')">
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/upJFJIIZ4hbSEuchNQi3" mode=""></image>
 					<view class="text">
 						财务报表
 					</view>
 				</view>
-				<view class="cont"  @click="topage(2)">
+				<view class="cont"  @click="topage(2)" v-if="hasMenuPermission('设备管理')">
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/uNfRjhtxYmMPKaX4DqTS" mode=""></image>
 					<view class="text">
 						设备管理
 					</view>
 				</view>
-				<!-- <view class="cont"  @click="topage(3)">
-					<image src="https://lxnapi.ccttiot.com/bike/img/static/ugC3s7fvhckzJN9vqsHa" mode=""></image>
-					<view class="text">
-						用户管理
-					</view>
-				</view> -->
-				<view class="cont" @click="topage(4)">
+				
+				<view class="cont" @click="topage(4)" v-if="hasMenuPermission('用户页面')">
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/uM4rBBaXc7b3TmsqQTvz" mode=""></image>
 					<view class="text">
 						用户页面
 					</view>
 				</view>
-				<view class="cont" @click="topage(5)" v-if="userinfo.sysUserId==1">
+				<view class="cont" @click="topage(5)" v-if="hasMenuPermission('车辆绑定')">
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/uM4rBBaXc7b3TmsqQTvz" mode=""></image>
 					<view class="text">
 						车辆绑定
 					</view>
 				</view>
-				<view class="cont" @click="topage(6)"  v-if="(userinfo.role == 9 || userinfo.role == 4) && deptId == 100">
+				<view class="cont" @click="topage(6)"  v-if="hasMenuPermission('账户明细')">
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/u47okd0YdEQBsyhLlQIt" mode="" style="width: 50rpx;height: 50rpx;"></image>
 					<view class="text">
 						账户明细
 					</view>
 				</view>
-				<view class="cont" @click="topage(7)" v-if="userinfo.role !=4">
+				<view class="cont" @click="topage(7)" v-if="hasMenuPermission('故障审核')" >
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/u47okd0YdEQBsyhLlQIt" mode="" style="width: 50rpx;height: 50rpx;"></image>
 					<view class="text">
 						故障审核
 					</view>
 				</view>
-				<view class="cont" @click="topage(9)" v-if="userinfo.role !=4">
+				<view class="cont" @click="topage(9)" v-if="hasMenuPermission('车型管理')">
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/ufE1T9RDOm7OmhLgTzXi" mode="" style="width: 100%;height: 100%;"></image>
-					<!-- <view class="text">
-						故障审核
-					</view> -->
+					
 				</view>
-				<view class="cont" @click="topage(10)" v-if="userinfo.role !=4">
+				<view class="cont" @click="topage(10)" v-if="hasMenuPermission('收费模版')">
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/uqG3ZQWu986qU0gU9vbb" mode="" style="width: 100%;height: 100%;"></image>
-					<!-- <view class="text">
-						故障审核
-					</view> -->
+					
 				</view>
-				<view class="cont" @click="topage(11)" style="width: 96rpx;height: 96rpx;" v-if="userinfo.role !=4"> 
+				<view class="cont" @click="topage(11)" style="width: 96rpx;height: 96rpx;" v-if="hasMenuPermission('运营设置')"> 
 					<image src="https://lxnapi.ccttiot.com/bike/img/static/uqCr4GrXEx6irmRNNsfM" mode="" style="width: 96rpx;height: 96rpx;"></image>
-					<!-- <view class="text">
-						故障审核
-					</view> -->
+					
 				</view>
 				
 			</view>
@@ -108,8 +92,8 @@
 				show: false,
 				info:{},
 				userinfo:{},
-				deptId:null
-			
+				deptId:null,
+				menuList:[]
 			}
 		},
 		onShow() {
@@ -133,13 +117,17 @@
 			},
 		},
 		methods: {
+			hasMenuPermission(menuName) {
+				return this.menuList.some(item => item.menuName === menuName);
+			},
 			getinfo() {
 				this.$u.get("/getAppInfo").then((res) => {
 							
 					if (res.code == 200) {
 						
 						this.userinfo = res.user
-						
+						this.menuList=res.menu
+						console.log(this.menuList,'menuListmenuListmenuListmenuList');
 					} else {
 						// setTimeout(() => {
 						// 	this.getinfo()