|
@@ -1,4 +1,6 @@
|
|
|
|
|
|
+// const log = require('../../utils/log')
|
|
|
+const { getCache, setCache, CacheKeys } = require('../../utils/cache')
|
|
|
var app = getApp()
|
|
|
var interval;
|
|
|
var inter1;
|
|
@@ -10,7 +12,7 @@ const util = require('../../utils/utils.js');
|
|
|
var interval;
|
|
|
//蓝牙操作方法
|
|
|
var BluetoothOperate = require('../../service/bluetooth.js');
|
|
|
-const { content } = require('../../service/dataTransition.js');
|
|
|
+//const { content } = require('../../service/dataTransition.js');
|
|
|
let bluetoothOperate = new BluetoothOperate();
|
|
|
let machineNO = "" //设备编号
|
|
|
let key = "" //蓝牙密钥
|
|
@@ -18,6 +20,13 @@ let operateType = '' //'open'开锁 'close'上锁 'bell'寻铃 'temporaryClose'
|
|
|
|
|
|
Page({
|
|
|
data: {
|
|
|
+ marqueeDistance: 520, //初始滚动距离 用到
|
|
|
+ marqueeWidth: 560, //通知公告用到
|
|
|
+ marqueePace: 0.6, //滚动速度
|
|
|
+ length: '',//通知公告
|
|
|
+ size: 26, //通知公告用到
|
|
|
+ notice: '',//通知公告
|
|
|
+ currentSwiper: 0,
|
|
|
nowBikeStatus: '',//当前车辆的状态
|
|
|
money: { time_money: 0, dispatch_money: 0, total_money: 0 },//骑行费用
|
|
|
steps: 1,//开锁步骤
|
|
@@ -57,21 +66,23 @@ Page({
|
|
|
countTimeShow: false,
|
|
|
dispatch_money: 0,//调度费
|
|
|
area_id: '',//区域id
|
|
|
+ mapHeight: 'calc(100vh - 300px)',
|
|
|
|
|
|
},
|
|
|
onShow: function () {
|
|
|
let that = this
|
|
|
- that.setData({
|
|
|
- polygons1:[],
|
|
|
- polygons:[]
|
|
|
+ that.setData({
|
|
|
+ polygons1: [],
|
|
|
+ polygons: []
|
|
|
})
|
|
|
my.setNavigationBar({
|
|
|
title: app.globalData.title
|
|
|
})
|
|
|
clearInterval(locationTerval);
|
|
|
- that.userState()
|
|
|
- that.posiLoca()
|
|
|
+
|
|
|
app.login().then(res => {
|
|
|
+ that.userState()
|
|
|
+ that.posiLoca()
|
|
|
that.chushiPosiloc()
|
|
|
if (that.data.code) {
|
|
|
that.getBikeMessage()
|
|
@@ -80,6 +91,7 @@ Page({
|
|
|
if (that.data.order != undefined) {
|
|
|
that.chushi()
|
|
|
}
|
|
|
+ // that.reloadMap()
|
|
|
},
|
|
|
//初始化位之信息并获取区域
|
|
|
chushiPosiloc: function () {
|
|
@@ -103,6 +115,18 @@ Page({
|
|
|
fail: function (err) {
|
|
|
console.log(err)
|
|
|
my.hideLoading()
|
|
|
+ if (err.error == 11) {
|
|
|
+
|
|
|
+ my.showAuthGuide({
|
|
|
+ authType: 'LBS',
|
|
|
+ success: (res) => {
|
|
|
+
|
|
|
+ },
|
|
|
+ fail: (error) => {
|
|
|
+ my.alert({ content: '获取位置授权失败' });
|
|
|
+ },
|
|
|
+ })
|
|
|
+ }
|
|
|
my.getSetting({
|
|
|
success: function (res) {
|
|
|
// console.log(res)
|
|
@@ -119,9 +143,34 @@ Page({
|
|
|
})
|
|
|
},
|
|
|
onLoad: function (options) {
|
|
|
- console.log(options, '--------------------------')
|
|
|
let that = this
|
|
|
-
|
|
|
+ // if (options != null && options instanceof Object && options.hasOwnProperty('q')) {
|
|
|
+ // var code1 = decodeURIComponent(options.q)
|
|
|
+ // var index = code1.lastIndexOf("\=");
|
|
|
+ // let code = code1.substring(index + 1, code1.length);
|
|
|
+ // that.setData({
|
|
|
+ // code: code
|
|
|
+ // })
|
|
|
+ // } else if (options != null && options instanceof Object && options.hasOwnProperty('order') && options.order.length > 20) {
|
|
|
+ // that.setData({
|
|
|
+ // order: options.order,
|
|
|
+ // })
|
|
|
+ // } else if (options != null && options instanceof Object && options.hasOwnProperty('code')) {
|
|
|
+ // that.setData({
|
|
|
+ // code: options.code
|
|
|
+ // })
|
|
|
+ // } else {
|
|
|
+ // my.alert({
|
|
|
+ // title: '提示',
|
|
|
+ // content: '车牌号有误,请重试~',
|
|
|
+ // success: function (res) {
|
|
|
+ // my.reLaunch({
|
|
|
+ // url: '/pages/index/index',
|
|
|
+ // })
|
|
|
+ // }
|
|
|
+ // })
|
|
|
+ // return
|
|
|
+ // }
|
|
|
if (app.globalData.scanCode) {
|
|
|
// console.log('扫码加载')
|
|
|
// var code1 = decodeURIComponent(options.query.qrCode)
|
|
@@ -140,64 +189,124 @@ Page({
|
|
|
code: options.code
|
|
|
})
|
|
|
}
|
|
|
- // let that = this
|
|
|
- // let token = my.getStorageSync({ 'key': 'token' }).data
|
|
|
- // let data = Math.round(new Date().getTime() / 1000).toString();;
|
|
|
- // let tokenTime = my.getStorageSync({ 'key': 'token_time' }).data
|
|
|
- // let cha = data - tokenTime
|
|
|
- // let data1 = 60 * 60 * 24
|
|
|
- // if (!token) {
|
|
|
- // that.token()
|
|
|
- // } else if (cha > data1) {
|
|
|
- // my.removeStorageSync({ 'key': 'token' }).data
|
|
|
- // that.token()
|
|
|
- // } else {
|
|
|
- // console.log(options, 'order_no')
|
|
|
- // let home = my.getStorageSync({ 'key': 'home' }).data
|
|
|
- // // that.posiLoca();
|
|
|
- // let area_id = home.id
|
|
|
- // that.ban_stop(area_id)
|
|
|
- // if (options.order != undefined) {
|
|
|
- // that.setData({
|
|
|
- // order: options.order,
|
|
|
- // })
|
|
|
- // that.chushi()
|
|
|
- // }
|
|
|
- // if (options.code != undefined) {
|
|
|
- // that.setData({
|
|
|
- // code: options.code
|
|
|
- // })
|
|
|
- // this.getBikeMessage(options)
|
|
|
- // }
|
|
|
+ },
|
|
|
+ getNotice(id) {
|
|
|
+ let data = {
|
|
|
+ 'area_id': id
|
|
|
+ }
|
|
|
+ let isCache = getCache('Notice:' + id)
|
|
|
+ console.log(isCache, 'isCache')
|
|
|
+ if (isCache) {
|
|
|
+ if (isCache != null && isCache instanceof Object && !isCache.hasOwnProperty('id')) return
|
|
|
+ this.setData({ notice: isCache })
|
|
|
+ var length = isCache.description.length * this.data.size; //计算文字的长度
|
|
|
+ this.setData({
|
|
|
+ length: length
|
|
|
+ })
|
|
|
+ if (this.data.length > this.data.marqueeWidth) {
|
|
|
+ this.noticeRun();
|
|
|
+ } else {
|
|
|
+ this.setData({
|
|
|
+ marqueeDistance: 0
|
|
|
+ })
|
|
|
+ }
|
|
|
+ return
|
|
|
+ }
|
|
|
+ app.request("/index/an", data, "GET").then(res => {
|
|
|
+ if (200 == res.status) {
|
|
|
+ setCache('Notice:' + id, res.data)
|
|
|
+ if (res.data != null && res.data instanceof Object && !res.data.hasOwnProperty('id')) return
|
|
|
|
|
|
- // this.setData({
|
|
|
- // code: options.code
|
|
|
- // })
|
|
|
- // }
|
|
|
+ this.setData({ notice: res.data })
|
|
|
+ var length = res.data.description.length * this.data.size; //计算文字的长度
|
|
|
+ this.setData({
|
|
|
+ length: length
|
|
|
+ })
|
|
|
+ if (this.data.length > this.data.marqueeWidth) {
|
|
|
+ this.noticeRun();
|
|
|
+ } else {
|
|
|
+ this.setData({
|
|
|
+ marqueeDistance: 0
|
|
|
+ })
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }).catch(err => {
|
|
|
+ // console.log(err)
|
|
|
+ })
|
|
|
+ },
|
|
|
+ noticeRun: function () {
|
|
|
+ var that = this;
|
|
|
+ clearInterval(mytime);
|
|
|
+ mytime = setInterval(function () {
|
|
|
+ if (-that.data.marqueeDistance < that.data.length) {
|
|
|
+ that.setData({
|
|
|
+ marqueeDistance: that.data.marqueeDistance - that.data.marqueePace,
|
|
|
+ })
|
|
|
+ } else {
|
|
|
+ clearInterval(mytime);
|
|
|
+ that.setData({
|
|
|
+ marqueeDistance: that.data.marqueeWidth
|
|
|
+ });
|
|
|
+ that.noticeRun();
|
|
|
+ }
|
|
|
+ }, 10)
|
|
|
},
|
|
|
- //获取token
|
|
|
- // token: function () {
|
|
|
- // my.getAuthCode({
|
|
|
- // success: function (res) {
|
|
|
- // var data = {
|
|
|
- // 'code': res.authCode,
|
|
|
- // 'appid': app.globalData.appid,
|
|
|
- // 'type': 1
|
|
|
- // };
|
|
|
- // app.request('/auth/weapp-login', data, 'post').then(res => {
|
|
|
- // my.setStorageSync({ 'key': 'token', data: res.data.token });
|
|
|
- // my.setStorageSync({ 'key': 'session_key', data: res.data.session_key });
|
|
|
- // my.setStorageSync({ 'key': 'token_time', data: res.data.exp });
|
|
|
- // my.setStorageSync({ 'key': 'user_ID', data: res.data.user.id });
|
|
|
- // })
|
|
|
- // }
|
|
|
- // })
|
|
|
- // },
|
|
|
+ //广告列表
|
|
|
+ adsList: function (id) {
|
|
|
+ var that = this;
|
|
|
+ var area_id = ''
|
|
|
+ if (id != undefined) {
|
|
|
+ area_id = id
|
|
|
+ } else {
|
|
|
+ area_id = 0
|
|
|
+ }
|
|
|
+
|
|
|
+ let isCache = getCache('ads:' + id)
|
|
|
+ if (isCache) {
|
|
|
+ if (isCache != '') return
|
|
|
+ if (isCache != null && isCache instanceof Object && isCache.hasOwnProperty('header')) {
|
|
|
+ that.setData({
|
|
|
+ ads: isCache.header
|
|
|
+ })
|
|
|
+ }
|
|
|
+ if (isCache != null && isCache instanceof Object && isCache.hasOwnProperty('mid')) {
|
|
|
+ that.setData({
|
|
|
+ mid: res.data.mid,
|
|
|
+ adFrame: true
|
|
|
+ })
|
|
|
+ }
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ app.request("/ads?area_id=" + area_id + "&position[]=mid&position[]=header&position[]=footer", '', "GET").then(res => {
|
|
|
+ if (res.status == 200) {
|
|
|
+ setCache('ads:' + id, res.data)
|
|
|
+ if (res.data != '') return
|
|
|
+ if (res.data.header) {
|
|
|
+ that.setData({
|
|
|
+ ads: res.data.header
|
|
|
+ })
|
|
|
+ }
|
|
|
+ if (res.data.mid) {
|
|
|
+ that.setData({
|
|
|
+ mid: res.data.mid,
|
|
|
+ adFrame: true
|
|
|
+ })
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }).catch(err => {
|
|
|
+ // console.log(err)
|
|
|
+ })
|
|
|
+ },
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
//用户状态
|
|
|
userState: function (area_id) {
|
|
|
var that = this;
|
|
|
-
|
|
|
- app.request("/user/status","GET").then(res => {
|
|
|
+
|
|
|
+ app.request("/user/status", "GET").then(res => {
|
|
|
console.log(res, 'zhuangtai')
|
|
|
if (res.status == 200) {
|
|
|
my.setStorageSync({ 'key': 'userState', data: res.data });
|
|
@@ -207,11 +316,11 @@ Page({
|
|
|
})
|
|
|
that.chushi()
|
|
|
}
|
|
|
- /**
|
|
|
- * 未支付直接调转支付
|
|
|
- * mead
|
|
|
- */
|
|
|
- if(res.data.is_pay_order){
|
|
|
+ /**
|
|
|
+ * 未支付直接调转支付
|
|
|
+ * mead
|
|
|
+ */
|
|
|
+ if (res.data.is_pay_order) {
|
|
|
my.navigateTo({
|
|
|
url: '/pages/pay/pay?order=' + res.data.is_pay_order,
|
|
|
})
|
|
@@ -233,7 +342,7 @@ Page({
|
|
|
title: '提示',
|
|
|
content: '当前车子还未投放请换辆车子骑行吧~',
|
|
|
success: function (res) {
|
|
|
- wx.reLaunch({
|
|
|
+ my.reLaunch({
|
|
|
url: '/pages/index/index',
|
|
|
})
|
|
|
}
|
|
@@ -244,7 +353,7 @@ Page({
|
|
|
title: '提示',
|
|
|
content: '当前车子电量过低请换辆车子骑行吧~',
|
|
|
success: function (res) {
|
|
|
- wx.reLaunch({
|
|
|
+ my.reLaunch({
|
|
|
url: '/pages/index/index',
|
|
|
})
|
|
|
}
|
|
@@ -255,7 +364,7 @@ Page({
|
|
|
title: '提示',
|
|
|
content: '当前车子出现故障请换辆车子骑行吧~',
|
|
|
success: function (res) {
|
|
|
- wx.reLaunch({
|
|
|
+ my.reLaunch({
|
|
|
url: '/pages/index/index',
|
|
|
})
|
|
|
}
|
|
@@ -266,7 +375,7 @@ Page({
|
|
|
title: '提示',
|
|
|
content: '当前车子正在骑行请换辆车子骑行吧~',
|
|
|
success: function (res) {
|
|
|
- wx.reLaunch({
|
|
|
+ my.reLaunch({
|
|
|
url: '/pages/index/index',
|
|
|
})
|
|
|
}
|
|
@@ -281,7 +390,6 @@ Page({
|
|
|
//骑行区禁停区车辆
|
|
|
home: function () {
|
|
|
//请求首页接口和一些设置。
|
|
|
- console.log('测试')
|
|
|
var that = this;
|
|
|
if (that.data.longitude != '' && that.data.latitude != '') {
|
|
|
//116.411027
|
|
@@ -299,6 +407,8 @@ Page({
|
|
|
})
|
|
|
let area_id = res.data.id
|
|
|
that.ban_stop(area_id)
|
|
|
+ that.getNotice(area_id)
|
|
|
+ that.adsList(area_id)
|
|
|
console.log(data, '区域')
|
|
|
my.setStorageSync({ 'key': 'home', data: data });
|
|
|
|
|
@@ -328,6 +438,16 @@ Page({
|
|
|
that.setData({
|
|
|
polygons1: that.data.polygons1.concat(home)
|
|
|
})
|
|
|
+
|
|
|
+ let isCache = getCache('BAN_STOP:' + area_id)
|
|
|
+ if (isCache) {
|
|
|
+ that.setData({
|
|
|
+ markers: that.data.markers.concat(isCache.centres),
|
|
|
+ polygons: that.data.polygons1.concat(isCache.polygons),
|
|
|
+ })
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
var data1 = {
|
|
|
'area_id': area_id
|
|
|
}
|
|
@@ -383,12 +503,16 @@ Page({
|
|
|
that.setData({
|
|
|
steps: 3
|
|
|
})
|
|
|
+ my.setStorageSync({ 'key': 'nowBikeStatus', data: 0 })
|
|
|
+ // that.reloadMap()
|
|
|
} else if (bike_status == 0 && userStatus.is_ride_order != false) {
|
|
|
// 临时停车
|
|
|
that.setData({
|
|
|
parkStatus: 1,
|
|
|
steps: 3
|
|
|
})
|
|
|
+ my.setStorageSync({ 'key': 'nowBikeStatus', data: 1 })
|
|
|
+ // that.reloadMap()
|
|
|
that.stopDownTime()
|
|
|
}
|
|
|
app.request('/bike/' + that.data.code, '', 'GET').then(res => {
|
|
@@ -428,21 +552,51 @@ Page({
|
|
|
//获取当前位置
|
|
|
posiLoca: function () {
|
|
|
var that = this;
|
|
|
- locationTerval = setInterval(function () {
|
|
|
- my.getLocation({
|
|
|
- type: 'gcj02',
|
|
|
- success: (res) => {
|
|
|
- console.log('经纬度为:+++++++++++2323++++++++++' + res.latitude + '++++++++' + res.longitude)
|
|
|
- var latitude = res.latitude
|
|
|
- var longitude = res.longitude
|
|
|
- my.hideLoading()
|
|
|
- that.setData({
|
|
|
- longitude: longitude,
|
|
|
- latitude: latitude,
|
|
|
+ my.showLoading({
|
|
|
+ content: '正在定位...',
|
|
|
+ icon: 'none'
|
|
|
+ })
|
|
|
+ // locationTerval = setInterval(function () {
|
|
|
+ my.getLocation({
|
|
|
+ type: 'gcj02',
|
|
|
+ success: (res) => {
|
|
|
+ var latitude = res.latitude
|
|
|
+ var longitude = res.longitude
|
|
|
+ my.hideLoading()
|
|
|
+ that.setData({
|
|
|
+ longitude: longitude,
|
|
|
+ latitude: latitude,
|
|
|
+ })
|
|
|
+ that.home()
|
|
|
+ },
|
|
|
+ fail: function (err) {
|
|
|
+ my.hideLoading()
|
|
|
+ if (err.error == 11) {
|
|
|
+ my.showAuthGuide({
|
|
|
+ authType: 'LBS',
|
|
|
+ success: (res) => {
|
|
|
+
|
|
|
+ },
|
|
|
+ fail: (error) => {
|
|
|
+ my.alert({ content: '获取位置授权失败' });
|
|
|
+ },
|
|
|
})
|
|
|
- },
|
|
|
- })
|
|
|
- }, 5000)
|
|
|
+ }
|
|
|
+ my.getSetting({
|
|
|
+ success: function (res) {
|
|
|
+ // console.log(res)
|
|
|
+ var statu = res.authSetting;
|
|
|
+ if (statu['scope.userLocation'] == false) {
|
|
|
+ that.setData({
|
|
|
+ background: true,
|
|
|
+ location: true
|
|
|
+ })
|
|
|
+ }
|
|
|
+ }
|
|
|
+ })
|
|
|
+ }
|
|
|
+ })
|
|
|
+
|
|
|
},
|
|
|
//获取蓝牙秘钥
|
|
|
getSecretKey(box_no) {
|
|
@@ -581,6 +735,7 @@ Page({
|
|
|
|
|
|
//获取车辆信息
|
|
|
getBikeMessage: function () {
|
|
|
+ my.showLoading()
|
|
|
var that = this;
|
|
|
app.request('/bike/' + that.data.code, '', 'GET').then(res => {
|
|
|
console.log(res, '车辆信息--------------------')
|
|
@@ -593,66 +748,6 @@ Page({
|
|
|
steps: 1
|
|
|
}),
|
|
|
key = res.data.key
|
|
|
- // if (res.data.is_link == 0) {
|
|
|
- // my.alert({
|
|
|
- // title: '提示',
|
|
|
- // content: '当前车子已下线请换辆车子骑行吧~',
|
|
|
- // success: function (res) {
|
|
|
- // my.reLaunch({
|
|
|
- // url: '/pages/index/index',
|
|
|
- // })
|
|
|
- // }
|
|
|
- // })
|
|
|
- // return;
|
|
|
- // } else if (res.data.put_status == 0) {
|
|
|
- // my.alert({
|
|
|
- // title: '提示',
|
|
|
- // content: '当前车子还未投放请换辆车子骑行吧~',
|
|
|
- // success: function (res) {
|
|
|
- // my.reLaunch({
|
|
|
- // url: '/pages/index/index',
|
|
|
- // })
|
|
|
- // }
|
|
|
- // })
|
|
|
- // return;
|
|
|
- // } else if (res.data.is_low_battery_power == 0) {
|
|
|
- // my.alert({
|
|
|
- // title: '提示',
|
|
|
- // content: '当前车子电量过低请换辆车子骑行吧~',
|
|
|
- // success: function (res) {
|
|
|
- // my.reLaunch({
|
|
|
- // url: '/pages/index/index',
|
|
|
- // })
|
|
|
- // }
|
|
|
- // })
|
|
|
- // return;
|
|
|
- // } else if (res.data.is_trouble == 1) {
|
|
|
- // my.alert({
|
|
|
- // title: '提示',
|
|
|
- // content: '当前车子出现故障请换辆车子骑行吧~',
|
|
|
- // success: function (res) {
|
|
|
- // my.reLaunch({
|
|
|
- // url: '/pages/index/index',
|
|
|
- // })
|
|
|
- // }
|
|
|
- // })
|
|
|
- // return;
|
|
|
- // } else if (res.data.is_riding == 1) {
|
|
|
- // my.alert({
|
|
|
- // title: '提示',
|
|
|
- // content: '当前车子正在骑行请换辆车子骑行吧~',
|
|
|
- // success: function (res) {
|
|
|
- // my.reLaunch({
|
|
|
- // url: '/pages/index/index',
|
|
|
- // })
|
|
|
- // }
|
|
|
- // })
|
|
|
- // return;
|
|
|
- // } else {
|
|
|
- // let box_no = res.data.box_no
|
|
|
-
|
|
|
- // that.getSecretKey(box_no)
|
|
|
- // }
|
|
|
} else {
|
|
|
setTimeout(function () {
|
|
|
my.reLaunch({
|
|
@@ -669,115 +764,135 @@ Page({
|
|
|
let that = this
|
|
|
var userStatus = my.getStorageSync({ 'key': 'userState' }).data;
|
|
|
var setting = my.getStorageSync({ 'key': 'setting' }).data;
|
|
|
- console.log(userStatus,'旭颖')
|
|
|
- console.log(setting,'旭颖')
|
|
|
-
|
|
|
- //未绑定手机号
|
|
|
+ console.log(userStatus, '旭颖')
|
|
|
+ console.log(setting, '旭颖')
|
|
|
if (userStatus.is_bind_mobile == 0) {
|
|
|
my.navigateTo({
|
|
|
url: '/pages/authorization/authorization',
|
|
|
})
|
|
|
//未实名认证
|
|
|
- } else if (userStatus.is_card_certified == 0 && setting.is_card == 1) {
|
|
|
- my.navigateTo({
|
|
|
- url: '/pages/real_name/real_name',
|
|
|
- })
|
|
|
- } else if (userStatus.is_deposit == 0 && setting.is_deposit != 0 && userStatus.is_coupon_deposit_free == false) {
|
|
|
- my.navigateTo({
|
|
|
- url: '/pages/ride_zige/ride_zige',
|
|
|
- })
|
|
|
- } else if (userStatus.is_ride_order !== false) {
|
|
|
- console.log(userStatus, 'yyyyyyyyyyyyyyy')
|
|
|
- my.alert({
|
|
|
- title: '提示',
|
|
|
- content: '您有一个正在骑行中的订单',
|
|
|
- success: function (res) {
|
|
|
- my.reLaunch({
|
|
|
- url: '/pages/index/index',
|
|
|
- })
|
|
|
- }
|
|
|
- })
|
|
|
- } else if (userStatus.is_pay_order != false && userStatus.is_pay_order != undefined) {
|
|
|
- my.alert({
|
|
|
- title: '提示',
|
|
|
- content: '您有一个待支付订单,请先支付',
|
|
|
- success: function (res) {
|
|
|
- my.reLaunch({
|
|
|
- url: '/pages/index/index',
|
|
|
- })
|
|
|
- }
|
|
|
- })
|
|
|
- }
|
|
|
- else {
|
|
|
- that.setData({
|
|
|
- steps: 2
|
|
|
- })
|
|
|
}
|
|
|
+ else
|
|
|
+ if (userStatus.is_card_certified == 0 && setting.is_card == 1) {
|
|
|
+ my.navigateTo({
|
|
|
+ url: '/pages/real_name/real_name',
|
|
|
+ })
|
|
|
+ }//是否缴纳押金
|
|
|
+ else if (userStatus.is_deposit == 0 && setting.is_deposit != 0 && userStatus.is_coupon_deposit_free == false) {
|
|
|
+ my.navigateTo({
|
|
|
+ url: '/pages/ride_zige/ride_zige',
|
|
|
+ })
|
|
|
+ } else if (userStatus.is_ride_order != false) {
|
|
|
+ my.alert({
|
|
|
+ title: '提示',
|
|
|
+ content: '您有一个正在骑行中的订单',
|
|
|
+ success: function (res) {
|
|
|
+ my.reLaunch({
|
|
|
+ url: '/pages/index/index',
|
|
|
+ })
|
|
|
+ }
|
|
|
+ })
|
|
|
+ } else if (userStatus.is_pay_order != false && userStatus.is_pay_order != undefined) {
|
|
|
+ my.alert({
|
|
|
+ title: '提示',
|
|
|
+ content: '您有一个待支付订单,请先支付',
|
|
|
+ success: function (res) {
|
|
|
+ my.reLaunch({
|
|
|
+ url: '/pages/index/index',
|
|
|
+ })
|
|
|
+ }
|
|
|
+ })
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ that.setData({
|
|
|
+ steps: 2
|
|
|
+ })
|
|
|
+ // this.reloadMap()
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ },
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ reloadMap(classname = 'use-bike-bottom') {
|
|
|
+ let query = my.createSelectorQuery();
|
|
|
+ let th = this;
|
|
|
+ query.select('.' + classname).boundingClientRect(function (rect) {
|
|
|
+ if (rect != null && rect instanceof Object && rect.hasOwnProperty('height')) {
|
|
|
+ let height = rect.height || 300;
|
|
|
+ th.setData({ mapHeight: 'calc(100vh - ' + (height) + 'px)' });
|
|
|
+ } else {
|
|
|
+ let height = 300;
|
|
|
+ th.setData({ mapHeight: 'calc(100vh - ' + height + 'px)' });
|
|
|
+ }
|
|
|
+ }).exec();
|
|
|
},
|
|
|
//倒计时
|
|
|
|
|
|
//临时停车倒计时
|
|
|
stopDownTime() {
|
|
|
- let that = this
|
|
|
- let endTime = Date.parse(new Date()); //date日期类型
|
|
|
- let startTime
|
|
|
- if (!that.data.temporaryTime || that.data.temporaryTime == null) {
|
|
|
- startTime = endTime
|
|
|
- } else {
|
|
|
- let data1 = that.data.temporaryTime
|
|
|
- let data2 = data1.replace(/-/g, '/')
|
|
|
- let data3 = new Date(data2)
|
|
|
- startTime = data3.getTime()
|
|
|
- }
|
|
|
- let totleTime = 1800
|
|
|
- clearInterval(linshiStop)
|
|
|
- console.log(endTime, 'endTime')
|
|
|
- console.log(startTime, 'startTime')
|
|
|
- let date3 = endTime - startTime;
|
|
|
- console.log(date3, 'date3')
|
|
|
- //计算出相差天数
|
|
|
- var days = Math.floor(date3 / (24 * 3600 * 1000));
|
|
|
- //计算出小时数
|
|
|
- var leave1 = date3 % (24 * 3600 * 1000); //计算天数后剩余的毫秒数
|
|
|
- var hours = Math.floor(leave1 / (3600 * 1000));
|
|
|
- //计算相差分钟数
|
|
|
- var leave2 = leave1 % (3600 * 1000); //计算小时数后剩余的毫秒数
|
|
|
- var minutes = Math.floor(leave2 / (60 * 1000));
|
|
|
- //计算相差秒数
|
|
|
- var leave3 = leave2 % (60 * 1000); //计算分钟数后剩余的毫秒数
|
|
|
- var seconds = Math.round(leave3 / 1000);
|
|
|
- console.log(minutes, 'minutes')
|
|
|
+ // let that = this
|
|
|
+ // let endTime = Date.parse(new Date()); //date日期类型
|
|
|
+ // let startTime
|
|
|
+ // if (!that.data.temporaryTime || that.data.temporaryTime == null) {
|
|
|
+ // startTime = endTime
|
|
|
+ // } else {
|
|
|
+ // let data1 = that.data.temporaryTime
|
|
|
+ // let data2 = data1.replace(/-/g, '/')
|
|
|
+ // let data3 = new Date(data2)
|
|
|
+ // startTime = data3.getTime()
|
|
|
+ // }
|
|
|
+ // let totleTime = 1800
|
|
|
+ // clearInterval(linshiStop)
|
|
|
+ // console.log(endTime, 'endTime')
|
|
|
+ // console.log(startTime, 'startTime')
|
|
|
+ // let date3 = endTime - startTime;
|
|
|
+ // console.log(date3, 'date3')
|
|
|
+ // //计算出相差天数
|
|
|
+ // var days = Math.floor(date3 / (24 * 3600 * 1000));
|
|
|
+ // //计算出小时数
|
|
|
+ // var leave1 = date3 % (24 * 3600 * 1000); //计算天数后剩余的毫秒数
|
|
|
+ // var hours = Math.floor(leave1 / (3600 * 1000));
|
|
|
+ // //计算相差分钟数
|
|
|
+ // var leave2 = leave1 % (3600 * 1000); //计算小时数后剩余的毫秒数
|
|
|
+ // var minutes = Math.floor(leave2 / (60 * 1000));
|
|
|
+ // //计算相差秒数
|
|
|
+ // var leave3 = leave2 % (60 * 1000); //计算分钟数后剩余的毫秒数
|
|
|
+ // var seconds = Math.round(leave3 / 1000);
|
|
|
+ // console.log(minutes, 'minutes')
|
|
|
|
|
|
- let chaTime = totleTime - minutes * 60
|
|
|
- console.log(chaTime, 'chaTime')
|
|
|
- linshiStop = setInterval(function () {
|
|
|
- let test = 30 * 60 * 1000
|
|
|
- console.log(test, 'test')
|
|
|
- if (date3 > test) {
|
|
|
- that.setData({
|
|
|
- stopMiao: 0,
|
|
|
- stopmMinute: 0
|
|
|
- })
|
|
|
- clearInterval(linshiStop)
|
|
|
- } else if (chaTime <= 0) {
|
|
|
- that.setData({
|
|
|
- stopMiao: 0,
|
|
|
- stopmMinute: 0
|
|
|
- })
|
|
|
- clearInterval(linshiStop)
|
|
|
- } else {
|
|
|
- console.log(minutes, 'pppp')
|
|
|
- chaTime--
|
|
|
+ // let chaTime = totleTime - minutes * 60
|
|
|
+ // console.log(chaTime, 'chaTime')
|
|
|
+ // linshiStop = setInterval(function () {
|
|
|
+ // let test = 30 * 60 * 1000
|
|
|
+ // console.log(test, 'test')
|
|
|
+ // if (date3 > test) {
|
|
|
+ // that.setData({
|
|
|
+ // stopMiao: 0,
|
|
|
+ // stopmMinute: 0
|
|
|
+ // })
|
|
|
+ // clearInterval(linshiStop)
|
|
|
+ // } else if (chaTime <= 0) {
|
|
|
+ // that.setData({
|
|
|
+ // stopMiao: 0,
|
|
|
+ // stopmMinute: 0
|
|
|
+ // })
|
|
|
+ // clearInterval(linshiStop)
|
|
|
+ // } else {
|
|
|
+ // console.log(minutes, 'pppp')
|
|
|
+ // chaTime--
|
|
|
|
|
|
- let fen = parseInt(chaTime / 60);
|
|
|
- let miao = parseInt(chaTime % 60);
|
|
|
- that.setData({
|
|
|
- stopMiao: miao,
|
|
|
- stopmMinute: fen
|
|
|
- })
|
|
|
- }
|
|
|
+ // let fen = parseInt(chaTime / 60);
|
|
|
+ // let miao = parseInt(chaTime % 60);
|
|
|
+ // that.setData({
|
|
|
+ // stopMiao: miao,
|
|
|
+ // stopmMinute: fen
|
|
|
+ // })
|
|
|
+ // }
|
|
|
|
|
|
- }, 1000)
|
|
|
+ // }, 1000)
|
|
|
|
|
|
},
|
|
|
//开锁方法
|
|
@@ -793,7 +908,7 @@ Page({
|
|
|
lng: that.data.longitude,
|
|
|
area_id: my.getStorageSync({ 'key': 'home' }).data.id,
|
|
|
}
|
|
|
- app.request('/bike/open-lock', data, 'POST', app.globalData.req).then(res => {
|
|
|
+ app.request('/bike/open-lock', data, 'POST').then(res => {
|
|
|
console.log(res)
|
|
|
if (res.status == 200) {
|
|
|
that.setData({
|
|
@@ -804,6 +919,7 @@ Page({
|
|
|
//蓝牙开锁
|
|
|
operateType = 'open'
|
|
|
bluetoothOperate.start(operateType, machineNO, key, (flag) => {
|
|
|
+ bluetoothOperate.end((flag) => { });
|
|
|
});
|
|
|
my.hideLoading()
|
|
|
} else {
|
|
@@ -841,6 +957,7 @@ Page({
|
|
|
my.hideLoading()
|
|
|
operateType = 'open'
|
|
|
bluetoothOperate.start(operateType, machineNO, key, (flag) => {
|
|
|
+ bluetoothOperate.end((flag) => { });
|
|
|
});
|
|
|
my.showToast({
|
|
|
content: '开锁成功',
|
|
@@ -946,6 +1063,7 @@ Page({
|
|
|
//flag == true 操作成功
|
|
|
//flag == false 操作失败
|
|
|
//end
|
|
|
+ bluetoothOperate.end((flag) => { });
|
|
|
});
|
|
|
res.data.is_ok == true && my.showToast({
|
|
|
content: '找车成功',
|
|
@@ -992,6 +1110,7 @@ Page({
|
|
|
//flag == true 操作成功
|
|
|
//flag == false 操作失败
|
|
|
//end
|
|
|
+ bluetoothOperate.end((flag) => { });
|
|
|
});
|
|
|
my.showToast({
|
|
|
content: '停车成功',
|
|
@@ -1039,6 +1158,7 @@ Page({
|
|
|
//flag == true 操作成功
|
|
|
//flag == false 操作失败
|
|
|
//end
|
|
|
+ bluetoothOperate.end((flag) => { });
|
|
|
});
|
|
|
my.showToast({
|
|
|
content: '开车成功',
|
|
@@ -1102,78 +1222,59 @@ Page({
|
|
|
lat: that.data.latitude,
|
|
|
lng: that.data.longitude
|
|
|
}
|
|
|
- app.request('/bike/check-is-riding-area', data, 'POST').then(res => {
|
|
|
- console.log(res)
|
|
|
- if (res.status == 200) {
|
|
|
- clearInterval(linshiStop);
|
|
|
- my.setStorageSync({ 'key': 'stopMiao', data: 0 })
|
|
|
- my.setStorageSync({ 'key': 'stopmMinute', data: 30 })
|
|
|
- my.hideNavigationBarLoading(), my.hideLoading()
|
|
|
- that.closeLock(data)
|
|
|
- //订单结束关闭蓝牙
|
|
|
- bluetoothOperate.end((flag) => { });
|
|
|
- } else if (res.status == 450) {
|
|
|
- my.showToast({
|
|
|
- content: '运动中不能关锁,请稍后重试',
|
|
|
- icon: 'none',
|
|
|
- duration: 5000,
|
|
|
- mask: true
|
|
|
- })
|
|
|
- my.hideLoading()
|
|
|
- }
|
|
|
- }).catch(err => {
|
|
|
- my.hideLoading()
|
|
|
- console.log(err)
|
|
|
- })
|
|
|
- }, 1000),
|
|
|
- closeLock: function (data) {
|
|
|
- var that = this;
|
|
|
-
|
|
|
app.request('/bike/close-lock', data, 'POST').then(res => {
|
|
|
console.log(res)
|
|
|
+ my.hideLoading()
|
|
|
if (res.status == 200) {
|
|
|
- console.log('锁车成功')
|
|
|
- clearInterval(interval);
|
|
|
+ console.log(res, '结束用车')
|
|
|
clearInterval(linshiStop);
|
|
|
- //蓝牙锁车操作 确定结束用车
|
|
|
- operateType = 'close'
|
|
|
- bluetoothOperate.start(operateType, machineNO, key, (flag) => {
|
|
|
- //flag == true 操作成功
|
|
|
- //flag == false 操作失败
|
|
|
- //end
|
|
|
- });
|
|
|
+ clearInterval(interval);
|
|
|
my.setStorageSync({ 'key': 'stopMiao', data: 0 })
|
|
|
my.setStorageSync({ 'key': 'stopmMinute', data: 30 })
|
|
|
- my.hideLoading()
|
|
|
-
|
|
|
+ my.hideNavigationBarLoading(), my.hideLoading()
|
|
|
my.reLaunch({
|
|
|
url: '../pay/pay?order=' + res.data.no
|
|
|
})
|
|
|
+ //蓝牙锁车操作 确定结束用车
|
|
|
+ if (machineNO && key) {
|
|
|
+ operateType = 'close'
|
|
|
+ bluetoothOperate.start(operateType, machineNO, key, (flag) => {
|
|
|
+ //flag == true 操作成功
|
|
|
+ //flag == false 操作失败
|
|
|
+ //end
|
|
|
+ //订单结束关闭蓝牙
|
|
|
+ bluetoothOperate.end((flag) => { });
|
|
|
+ });
|
|
|
+ }
|
|
|
|
|
|
} else if (res.status == 450) {
|
|
|
- //运动中不能锁车请5s后重试
|
|
|
my.showToast({
|
|
|
content: '运动中不能关锁,请稍后重试',
|
|
|
icon: 'none',
|
|
|
duration: 5000,
|
|
|
mask: true
|
|
|
})
|
|
|
- my.hideLoading()
|
|
|
-
|
|
|
}
|
|
|
}).catch(err => {
|
|
|
- console.log(err)
|
|
|
+ my.showToast({
|
|
|
+ content: '关锁失败,请重试。',
|
|
|
+ icon: 'none',
|
|
|
+ duration: 5000,
|
|
|
+ })
|
|
|
+ wx.hideLoading()
|
|
|
})
|
|
|
+ }, 1000),
|
|
|
|
|
|
- },
|
|
|
//取消锁车
|
|
|
cancelEndBike: function () {
|
|
|
console.log(my.getStorageSync({ 'key': 'nowBikeStatus' }).data)
|
|
|
let that = this
|
|
|
that.setData({
|
|
|
chaButton: 0,
|
|
|
+ dispatch_money: 0,
|
|
|
parkStatus: my.getStorageSync({ 'key': 'nowBikeStatus' }).data
|
|
|
})
|
|
|
+ // that.reloadMap()
|
|
|
},
|
|
|
//计价规则
|
|
|
chargeRule: function () {
|
|
@@ -1206,6 +1307,7 @@ Page({
|
|
|
that.setData({
|
|
|
frame: false
|
|
|
})
|
|
|
+ // that.reloadMap()
|
|
|
},
|
|
|
//关闭弹框
|
|
|
frameShow: function () {
|
|
@@ -1213,9 +1315,14 @@ Page({
|
|
|
that.setData({
|
|
|
frame: true
|
|
|
})
|
|
|
+ that.reloadMap('frame')
|
|
|
},
|
|
|
//故障上报
|
|
|
guzhang: function () {
|
|
|
+ this.setData({
|
|
|
+ frame: false,
|
|
|
+ })
|
|
|
+ // this.reloadMap()
|
|
|
my.navigateTo({
|
|
|
url: '/pages/breakdown/breakdown',
|
|
|
})
|
|
@@ -1226,8 +1333,16 @@ Page({
|
|
|
url: '/pages/parking/parking',
|
|
|
})
|
|
|
},
|
|
|
+ onHide: function () {
|
|
|
+ console.log('onHide5555')
|
|
|
+ // clearInterval(testToken
|
|
|
+ clearInterval(mytime)
|
|
|
+ clearInterval(interval)
|
|
|
+ bluetoothOperate.end((flag) => { });
|
|
|
+ },
|
|
|
onUnload: function () {
|
|
|
clearInterval(locationTerval)
|
|
|
+ bluetoothOperate.end((flag) => { });
|
|
|
// 停止位置跟踪
|
|
|
// my.stopLocationUpdate({
|
|
|
// success: (res) => {
|
|
@@ -1237,5 +1352,11 @@ Page({
|
|
|
// console.log("onUnload stopLocationUpdate fail", err)
|
|
|
// }
|
|
|
// })
|
|
|
+ },
|
|
|
+ //返回首页
|
|
|
+ backHome() {
|
|
|
+ my.reLaunch({
|
|
|
+ url: '/pages/index/index',
|
|
|
+ })
|
|
|
}
|
|
|
})
|