index.vue 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  1. <template>
  2. <view class="">
  3. <!-- <view style="height: 1000rpx;"></view> -->
  4. <view class="tabbar-wrap">
  5. <view class="tabbar">
  6. <view v-for="(item, index) in tabs" :key="index" class="tab-item" @tap="routerPush(item.url)">
  7. <image :src="curtTab === item.name ? item.activeIcon : item.icon" class="tab-icon"></image>
  8. <text :class="['base-text', curtTab === item.name && 'checked']">{{ item.label }}</text>
  9. </view>
  10. <view v-if="!isScanCondeRentalCar" class="center-entrance" @tap="navToInputPages">
  11. <image src="https://qiniu.bms16.com/Fm_kDVr1TIeIbbBW6-5bz0r-cECO"
  12. style="width: 122rpx; height: 122rpx;"></image>
  13. <!-- <img src="https://qiniu.bms16.com/FhCHLz8rQJ5mpJ6nUA4RbKiVkUOo" style="width: 120rpx; height: 24rpx;"/> -->
  14. </view>
  15. <view v-else class="center-entrance" @tap="navToInputPages">
  16. <!-- <img src="https://qiniu.bms16.com/FqcCjRjhzHFUkZj76SMHNXCZHwb3" style="width: 122rpx; height: 122rpx;margin-bottom: 14rpx;"/> -->
  17. <image src="https://qiniu.bms16.com/FqcCjRjhzHFUkZj76SMHNXCZHwb3"
  18. style="width: 122rpx; height: 122rpx;margin-bottom: 14rpx;"></image>
  19. <view class="scan-text">扫一扫</view>
  20. </view>
  21. </view>
  22. </view>
  23. </view>
  24. </template>
  25. <script>
  26. var app = getApp();
  27. const storage = require('@/common/storage.js');
  28. const http = require('@/common/http.js');
  29. const config = require('@/common/config.js');
  30. const common = require('@/common/common.js');
  31. const appWhiteListFilter = require('@/common/appWhiteListFilter.js');
  32. export default {
  33. props: {
  34. curtTab: {
  35. type: String,
  36. default: 'home'
  37. }
  38. },
  39. data() {
  40. return {
  41. selectedTab: uni.getStorageSync('selectedIndex') || 0,
  42. tabs: [{
  43. label: '设备',
  44. name: 'home',
  45. url: '/pages/index/index',
  46. icon: '/static/resource/images/home_i.png',
  47. activeIcon: '/static/resource/images/home_s.png',
  48. },
  49. {
  50. label: '服务',
  51. name: 'service',
  52. url: '/pages/service/service',
  53. icon: '/static/resource/images/service_i.png',
  54. activeIcon: '/static/resource/images/service_s.png',
  55. },
  56. {
  57. label: '活动',
  58. name: 'active',
  59. url: '/pages/activity/activity',
  60. icon: '/static/resource/images/active_i.png',
  61. activeIcon: '/static/resource/images/active_s.png',
  62. },
  63. {
  64. label: '我的',
  65. name: 'my',
  66. url: '/pages/my/my',
  67. icon: '/static/resource/images/my_i.png',
  68. activeIcon: '/static/resource/images/my_s.png',
  69. },
  70. ],
  71. userInfo: {
  72. is_auth: 0,
  73. status: 0
  74. },
  75. // accountInfo: uni.getAccountInfoSync(),
  76. plate_number: '',
  77. isScanCondeRentalCar: false,
  78. };
  79. },
  80. // created: function () {
  81. // if (appWhiteListFilter.isScanCondeRentalCar()) {
  82. // this.setData({
  83. // isScanCondeRentalCar: true
  84. // })
  85. // }
  86. // },
  87. mounted() {
  88. console.log(uni.getSystemInfoSync().safeArea)
  89. },
  90. methods: {
  91. routerPush(url) {
  92. // uni.setStorageSync('selectedIndex', data.index);
  93. uni.switchTab({
  94. url
  95. });
  96. // uni.navigateTo({ url })
  97. },
  98. async navToInputPages() {
  99. const me = this
  100. if (!this.loadIsLogin()) return
  101. uni.scanCode({
  102. success(res) {
  103. me.loadGeneralQRData(res.result)
  104. }
  105. })
  106. },
  107. loadGeneralQRData(options) {
  108. if (('q' in options) || ('result' in options) && (options.result.indexOf(
  109. "https://zx.uwenya.cc/xcx/s") != -
  110. 1)) {
  111. var url = ''
  112. if ('q' in options) {
  113. url = decodeURIComponent(options.q);
  114. }
  115. if ('result' in options) {
  116. url = options.result
  117. }
  118. var obj = this.getUrlParams(url)
  119. if (('t' in obj) && ('d' in obj)) {
  120. if (obj.t == 1 || obj.t == 2 || obj.t == 5 || obj.t == 4) {
  121. uni.navigateTo({
  122. url: '/pages/cabinetDetail/cabinetDetail?dev_id=' + obj.d + '&type=' +
  123. obj.t,
  124. })
  125. return 101
  126. }
  127. if (obj.t == 10) {
  128. this.navToInputPage(obj.d)
  129. return 106
  130. }
  131. }
  132. }
  133. },
  134. async navToInputPage(car_sn) {
  135. const me = this
  136. const {
  137. userInfo = ''
  138. } = storage.getUserInfoData()
  139. if (userInfo.status - 0 == 2) {
  140. const params = await this._getParams()
  141. // var plate_number = params.carList.length != 0 && params.carList[0].license_plate_number ? params
  142. // .carList[0].license_plate_number : me.plate_number
  143. if (params.carList.length == 0) {
  144. var location = uni.getStorageSync('user_current_location')
  145. me.loadScanCode(location, car_sn)
  146. } else {
  147. if (params.order_status) {
  148. uni.showModal({
  149. title: '提示',
  150. content: '已有正在进行的订单,是否跳转至订单页?',
  151. cancelText: '取消',
  152. confirmText: '确定',
  153. success: function(res) {
  154. if (res.confirm) {
  155. uni.navigateTo({
  156. url: '/pages/orderStatus/orderStatus'
  157. });
  158. }
  159. }
  160. })
  161. }
  162. }
  163. }
  164. },
  165. loadScanCode(location, battery_sn) {
  166. const pData = {
  167. longitude: location.longitude,
  168. latitude: location.latitude,
  169. battery_sn: battery_sn
  170. }
  171. const me = this
  172. http.postApi(config.API_FLK_CAR_DETAIL, pData, (resp) => {
  173. uni.hideLoading()
  174. if (resp.data.code === 200) {
  175. if (resp.data.data.online === 0 || isOffline) {
  176. common.simpleToast('此车辆已离线,请选择其他车辆')
  177. } else {
  178. if (resp.data.data.is_mine) {
  179. //直接切换当前扫码的车辆
  180. uni.setStorageSync('car_info', resp.data.data);
  181. me.$emit('changCar',resp.data.data)
  182. return
  183. } else {
  184. common.simpleToast('此车辆正在被使用!')
  185. return
  186. }
  187. }
  188. } else {
  189. common.simpleToast(resp.data.msg)
  190. }
  191. })
  192. },
  193. _getParams() {
  194. return new Promise((reslove, reject) => {
  195. http.postApi(config.API_FLK_CAR_DEVICE_LIST, {}, res => {
  196. const {
  197. data = []
  198. } = res.data.data
  199. const obj = {
  200. carList: data,
  201. order_status: data.length ? data[0].hire_order_status : 0,
  202. }
  203. reslove(obj)
  204. })
  205. })
  206. },
  207. getUrlParams(url) {
  208. // 通过 ? 分割获取后面的参数字符串
  209. let urlStr = url.split('?')[1]
  210. // 创建空对象存储参数
  211. let obj = {};
  212. // 再通过 & 将每一个参数单独分割出来
  213. let paramsArr = urlStr.split('&')
  214. for (let i = 0, len = paramsArr.length; i < len; i++) {
  215. // 再通过 = 将每一个参数分割为 key:value 的形式
  216. let arr = paramsArr[i].split('=')
  217. obj[arr[0]] = arr[1];
  218. }
  219. return obj
  220. },
  221. async loadIsLogin() {
  222. const user_token = storage.getUserToken()
  223. if (!user_token) {
  224. let res = await uni.showModal({
  225. title: '提示',
  226. content: '您还未登录,请先登录',
  227. showCancel: true,
  228. cancelText: '取消',
  229. confirmText: '确定',
  230. })
  231. if (res[1].confirm) {
  232. uni.navigateTo({
  233. url: '/pages/loginRegister/login',
  234. })
  235. }
  236. return false
  237. } else {
  238. return true
  239. }
  240. },
  241. }
  242. };
  243. </script>
  244. <style scoped>
  245. .tabbar-wrap {
  246. position: fixed;
  247. bottom: 0;
  248. left: 0;
  249. right: 0;
  250. /* border-bottom: env(safe-area-inset-bottom) solid #fff; */
  251. z-index: 9999;
  252. /* #ifdef APP */
  253. /* 兼容 iOS < 11.2 */
  254. padding-bottom: constant(safe-area-inset-bottom);
  255. /* 兼容 iOS >= 11.2 */
  256. padding-bottom: env(safe-area-inset-bottom);
  257. /* #endif */
  258. }
  259. .tabbar {
  260. height: 140rpx;
  261. width: 100%;
  262. /* background: url('https://qiniu.bms16.com/FiYy2ZOV_hGSJx32YAQSLZSbAOFq') no-repeat; */
  263. /* background: url('https://qiniu.bms16.com/Fk8jEU5-RbARagKDYZy0tKWErKNF') no-repeat; */
  264. background-size: 100%;
  265. display: flex;
  266. justify-content: space-between;
  267. align-items: center;
  268. position: relative;
  269. bottom: 0;
  270. background-color: #fff;
  271. padding: 0 50rpx;
  272. }
  273. .tab-item {}
  274. .tab-item:nth-child(2) {
  275. margin-right: 20%;
  276. }
  277. .tab-icon {
  278. width: 48rpx;
  279. height: 48rpx;
  280. display: block;
  281. margin: auto;
  282. }
  283. .center-entrance {
  284. position: absolute;
  285. left: 50%;
  286. transform: translateX(-50%);
  287. bottom: 34rpx;
  288. display: flex;
  289. flex-direction: column;
  290. border-radius: 50%;
  291. border: 10rpx solid #fff;
  292. }
  293. .scan-text {
  294. font-size: 10px;
  295. text-align: center;
  296. color: #828DA2;
  297. font-weight: 600;
  298. }
  299. .base-text {
  300. font-family: PingFangSC, PingFang SC;
  301. font-weight: 500;
  302. font-size: 22rpx;
  303. color: #9EA9BB;
  304. line-height: 20rpx;
  305. text-align: center;
  306. font-style: normal;
  307. }
  308. .checked {
  309. color: #060809;
  310. }
  311. </style>