battery.vue 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685
  1. <template>
  2. <view class="">
  3. <view v-if="!isNoneList" class="container-view">
  4. <view class="battery-info" style="height: 612rpx;">
  5. <view class="img_position"><img style="width: 520rpx;height: 544rpx;"
  6. src="https://qiniu.bms16.com/FsNL3g6p_ek2_pPdd35E8Or_S1ap" /></view>
  7. <view class="shadow" :style="{ '--progress': quantity*0.68 + '%' }">
  8. </view>
  9. <view class="quantity_box">
  10. <view class="num_quantity">{{Math.floor(quantity)}}</view>
  11. </view>
  12. </view>
  13. <view class="endurance-img-view" style="display: flex;justify-content: center;">
  14. <view class="endurance-img">
  15. <text>: {{Math.round(last_endurance/1000)}}km</text>
  16. </view>
  17. </view>
  18. <view class="flex-row" style="justify-content: center;">
  19. <view class="icon-box flex-row" style="justify-content: space-around;">
  20. <view v-if="orderInfo.order_info.battery_sn!=''" @tap="navToPage"
  21. data-url="/pages/exchangeCar/exchangeCar" data-index="1"
  22. class="flex-column my_function position">
  23. <view v-if="(orderInfo.order_info.gift_exchange_num - orderInfo.order_info.used_exchange_num)>0"
  24. class="red_tip">{{ $t('免费') }} <text
  25. style="font-size: 28rpx;margin: 0 2rpx;">{{orderInfo.order_info.gift_exchange_num - orderInfo.order_info.used_exchange_num}}</text>
  26. {{ $t('次') }}</view>
  27. <image class="my_icon" src="https://qiniu.bms16.com/FgR9qwTgatlAzamYdcFngFU4_ydj"></image>
  28. <view class="my_title">{{ $t('车辆换电') }}</view>
  29. </view>
  30. <view v-if="orderInfo.third_device_type == 'TBTKC'" @tap="clickCarCommand" data-command="FINDCAR" class="flex-column my_function">
  31. <image class="my_icon" src="https://zxappfile.bms16.com/zx_client/find_car.png"></image>
  32. <view class="my_title">{{ $t('响铃找车') }}</view>
  33. </view>
  34. <view v-if="orderInfo.third_device_type == 'TBTKC'" @tap="clickCarCommand" data-command="OPENSEATLOCK" class="flex-column my_function">
  35. <image class="my_icon" src="https://zxappfile.bms16.com/zx_client/seat_lock.png"></image>
  36. <view class="my_title">{{ $t('开座桶锁') }}</view>
  37. </view>
  38. <!-- <view @tap="clickCarCommand" data-command="helmet" class="flex-column my_function">
  39. <image class="my_icon_1" src="https://zxappfile.bms16.com/zx_client/helmet.png"></image>
  40. <view class="my_title">{{ $t('关闭头盔锁') }}</view>
  41. </view> -->
  42. <view
  43. @tap="clickCarCommand($event, true)"
  44. :data-command="protect_state ? 'SAFEOFF': 'SAFEON'"
  45. data-index="5"
  46. class="flex-column my_function"
  47. >
  48. <image class="my_icon" :src="protect_state ? lockIcon : onLockIcon"></image>
  49. <view class="my_title">{{ protect_state ? $t('解锁') : $t('上锁') }}</view>
  50. </view>
  51. <view @tap="navToPage" data-url="/pages/travelingTrack/travelingTrack" data-index="2"
  52. class="flex-column my_function">
  53. <image class="my_icon" src="https://qiniu.bms16.com/Fj61bkq6KYkfA9QdbLfpVUj3Nm5Q"></image>
  54. <view class="my_title">{{ $t('行驶轨迹') }}</view>
  55. </view>
  56. <view @tap="navToPage" data-url="/pages/carLocation/carLocation" data-index="3"
  57. class="flex-column my_function">
  58. <image class="my_icon" src="https://qiniu.bms16.com/Fg_eny6c-tiDVy1iTFyyWzmUj4ho"></image>
  59. <view class="my_title">{{ $t('车辆位置') }}</view>
  60. </view>
  61. <view v-if="orderInfo.drag_car_service" @tap="navToPage" data-url="/pages/towingCar/towingCar"
  62. data-index="4" class="flex-column my_function">
  63. <image class="my_icon" src="https://qiniu.bms16.com/FsG5bN2bg-MXLXZehQ33TsYPfrH8"></image>
  64. <view class="my_title">{{ $t('拖车服务') }}</view>
  65. </view>
  66. </view>
  67. </view>
  68. <view class="flex-row" style="justify-content: center;">
  69. <view class="battery-btn flex-row">
  70. <view v-if="orderInfo.is_on == 1" @tap="bindCarStatus" :data-car="orderInfo.is_on">
  71. <!-- <img class="img_car_on" src="https://qiniu.bms16.com/FtoO8li2ncvlGsjggXY7gMtaIAWt" /> -->
  72. {{ $t('关闭车辆') }}
  73. </view>
  74. <view v-else-if="orderInfo.is_on == 0||orderInfo.is_on == 2" @tap="bindCarStatus"
  75. :data-car="orderInfo.is_on">
  76. <!-- <img class="lock_img" src="https://qiniu.bms16.com/Fq7SWg4flipex4HXuDxsxL88AN5s" /> -->
  77. {{ $t('启动车辆') }}
  78. </view>
  79. <view @tap="bindReturnCar">{{ $t('我要还车') }}</view>
  80. </view>
  81. </view>
  82. <view class="">
  83. <view class="battery-second flex-row flex-between">
  84. <view>{{ $t('剩余租期') }}</view>
  85. <view @tap="navToPage" data-url="/pages/orderStatus/orderStatus" data-index="5">{{ $t('查看订单') }}</view>
  86. </view>
  87. </view>
  88. <view class="battery-bottom flex-row flex-between">
  89. <view v-if="orderInfo.time" class="bottom-time flex-row">
  90. {{orderInfo.time.day > 0 ? orderInfo.time.day :'' }}<text
  91. v-if="orderInfo.time.day>0">{{ $t('日') }}</text>{{orderInfo.time.hour > 0 ? orderInfo.time.hour :'' }}<text
  92. v-if="orderInfo.time.hour>0">{{ $t('小时') }}</text>{{orderInfo.time.minute > 0 ? orderInfo.time.minute :'' }}<text
  93. v-if="orderInfo.time.minute>0">{{ $t('分') }}</text>
  94. <view style="font-weight: 400;">{{ $t('到期后将无法用车') }}</view>
  95. </view>
  96. <view v-else class="bottom-time flex-row">
  97. {{ $t('已到期') }}
  98. <view>{{ $t('到期后将无法用车') }}</view>
  99. </view>
  100. <view @tap="bindRenewHire">{{ $t('续租') }}</view>
  101. </view>
  102. <view v-if="isShowReturnCar" class="return-box">
  103. <view class="return-item">
  104. <view class="return-title flex-row flex-between">
  105. <view>{{ $t('还车到门店') }}</view>
  106. <view @tap="isShowReturnCar = false" style="font-size: 60rpx;">×</view>
  107. </view>
  108. <view class="return-text">{{ $t('系统会根据您的定位判断您是否已到还车位置,如您已经到达门店,请点击「我已到店」按钮,待门店确认还车后,即可还车成功。') }}</view>
  109. <view class="return-btn flex-row">
  110. <view @tap="toRurnCarPage">{{ $t('我已到店') }}</view>
  111. <view @tap="toNearbyStorePage">{{ $t('附近可还门店') }}</view>
  112. </view>
  113. </view>
  114. </view>
  115. <view v-if="isShowRenewHire" class="renew-box">
  116. <scroll-view class="renew-item" scroll-y :show-scrollbar='true' :enhanced='true'>
  117. <view class="renew-title flex-row flex-between">
  118. <view>{{ $t('选择续租方案') }}</view>
  119. <view @tap="isShowRenewHire = false" style="font-size: 60rpx;">×</view>
  120. </view>
  121. <view class="plan-info">
  122. <view class="plan-type flex-row flex-between">
  123. <view @tap="bindChangeStatus" data-status="0"
  124. :class="isSelectStatus == 0?'ptyped-item':'ptype-item'">
  125. <view class="ptype-title">{{ $t('时租') }}</view>
  126. <view :class="isSelectStatus == 0?'ptyped-text':'ptype-text'">
  127. {{$t('¥')}}<text>8</text>
  128. </view>
  129. </view>
  130. <view @tap="bindChangeStatus" data-status="1"
  131. :class="isSelectStatus == 1?'ptyped-item':'ptype-item'">
  132. <view class="ptype-title">{{ $t('日租') }}</view>
  133. <view :class="isSelectStatus == 1?'ptyped-text':'ptype-text'">
  134. {{$t('¥')}}<text>48</text>
  135. </view>
  136. </view>
  137. <view @tap="bindChangeStatus" data-status="2"
  138. :class="isSelectStatus == 2?'ptyped-item':'ptype-item'">
  139. <view class="ptype-title">{{ $t('周租') }}</view>
  140. <view :class="isSelectStatus == 2?'ptyped-text':'ptype-text'">
  141. {{$t('¥')}}<text>208</text>
  142. </view>
  143. </view>
  144. </view>
  145. <view class="plan-time flex-row flex-between">
  146. <view>{{ $t('租车时长') }}/{{ $t('天') }}</view>
  147. <view class="quantity-count flex-row">
  148. <view class="count-btn fbtn" @tap.stop.prevent="bindMinus">-</view>
  149. <input @input="bindInput" @blur="bindBlur" type="number" :value="count" />
  150. <view class="count-btn sbtn" @tap.stop.prevent="bindAdd">+</view>
  151. </view>
  152. </view>
  153. <view class="coupon-info flex-row flex-between">
  154. <view>{{ $t('优惠券') }}</view>
  155. <view>
  156. 9.8 {{ $t('折') }}
  157. <img src="https://qiniu.bms16.com/Fjw9OKXT_2aZ1iPStF941RoawSy_" />
  158. </view>
  159. </view>
  160. </view>
  161. <view class="guarantee-info">
  162. <view class="guarantee-title flex-row flex-between">
  163. <view>{{ $t('骑行保障服务') }}</view>
  164. <view>{{ $t('保障须知') }}</view>
  165. </view>
  166. <view class="flex-row flex-between">
  167. <view @tap="clickSelectGuarantee" v-for="(item,index) in guaranteeList" :key="index"
  168. :data-status="index"
  169. :class="isSelectGuarantee==index?'selected-guarantee':'select-guarantee'">
  170. <view class="guarantee-top flex-row flex-column">
  171. <img :src="item.src" />
  172. {{item.title}}
  173. </view>
  174. <view class="guarantee-center">
  175. <view v-for="(items,indexs) in guaranteeType" :key="indexs"
  176. class="center-item flex-row flex-between">
  177. <view>{{items.title}}</view>
  178. <view>{{items.price}}</view>
  179. </view>
  180. <view style="color: #828DA2;text-align: center;font-size: 24rpx;">
  181. {{ $t('含行程延误保障') }}
  182. </view>
  183. <view class="guarantee-border"></view>
  184. <view class="guarantee-bottom flex-row flex-column">
  185. <view>1.3{{ $t('元') }}/{{ $t('天') }}</view>
  186. <view v-if="index==0" :class="isSelectGuarantee==0?'blue-t':'black-t'">{{ $t('商家赠送') }}
  187. </view>
  188. <view v-if="index!=0">
  189. <img
  190. :src="isSelectGuarantee==index?'https://qiniu.bms16.com/FjLudtM29xwqgJh5kUKR9kyhK0Lu':'https://qiniu.bms16.com/FuQZipm9g7wX6CyGQBCjK2RTXfbW'" />
  191. </view>
  192. </view>
  193. </view>
  194. </view>
  195. </view>
  196. </view>
  197. <view class="assort-info">
  198. <view>{{ $t('配套服务') }}</view>
  199. <view class="assort-text flex-row">
  200. <view>{{ $t('头盔') }}×1</view>
  201. <view>{{ $t('手机支架') }}×1</view>
  202. </view>
  203. </view>
  204. <view class="payment-info">
  205. <view class="payment-top flex-row">
  206. <img
  207. :src="isArgee?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/FkmDjxBNZhFGFU5inza2usdtDlX8'" />
  208. {{ $t('已阅读并同意') }}
  209. <text>{{ $t('《小众电动车租赁用户协议》') }}</text>
  210. </view>
  211. <view class="payment-bottom flex-row flex-between">
  212. <view class="bottom-left flex-row">
  213. <view>{{$(¥)}}92.23</view>
  214. <view>{{ $t('明细') }}<img src="https://qiniu.bms16.com/FmEDQp82D5k9lkHMEcCoCeLO8ZQL" /></view>
  215. </view>
  216. <view @tap="navToPage" data-url="/pages/orderStatus/orderStatus">{{ $t('支付') }}·{{ $t('授权免押') }}</view>
  217. </view>
  218. </view>
  219. </scroll-view>
  220. </view>
  221. </view>
  222. <view v-else class="no-car">{{ $t('暂无车辆') }}</view>
  223. </view>
  224. </template>
  225. <script module="tools" lang="wxs" src="@/pages/common/wxs/tools.wxs"></script>
  226. <script module="tools" lang="sjs" src="@/pages/common/wxs/tools.sjs"></script>
  227. <script>
  228. var config = require('../../common/config.js');
  229. var common = require('../../common/common.js');
  230. var http = require('../../common/http.js');
  231. var storage = require('../../common/storage.js');
  232. import lockIcon from '@/static/resource/images/lock_icon.png';
  233. import onLockIcon from '@/static/resource/images/onLock_icon.png';
  234. export default {
  235. components: {},
  236. data() {
  237. return {
  238. lockIcon,
  239. onLockIcon,
  240. isReturnIndex: true, //是否返回首页
  241. last_endurance: 0,
  242. isCustomJump: true,
  243. is_show: false,
  244. imageUrl: '',
  245. return_imgs: [],
  246. order_sn: '',
  247. plate_number: '',
  248. myLocation: {
  249. // longitude: '',
  250. // latitude: '',
  251. },
  252. orderInfo: [],
  253. model_info: {},
  254. quantity: 0,
  255. electricity: 20,
  256. isShowReturnCar: false,
  257. isShowRenewHire: false,
  258. isSelectStatus: 1,
  259. count: 1,
  260. isSelectGuarantee: 0,
  261. last_endurance: 0,
  262. isNoneList: false,
  263. protect_state: false, // 车辆状态(是否上锁)
  264. initialProtectState: '', // 初始状态
  265. initialIsOn: '',
  266. cycleTimer: null
  267. };
  268. },
  269. /**
  270. * 生命周期函数--监听页面加载
  271. */
  272. onLoad: function(options) {
  273. this.plate_number = options.plate_number || ''
  274. this.isReturnIndex = options.isReturnIndex ? false : true
  275. this.getWxLocation()
  276. if (this.plate_number == 'undefined') {
  277. this.setData({
  278. isNoneList: true
  279. })
  280. } else {
  281. this.setData({
  282. isNoneList: false
  283. })
  284. this.loadCarInfo(true)
  285. if (options.isActivePage) {
  286. // 如果是激活页面过来的。后端接口第一时间无法获取数据。需要再延迟获取一次
  287. const timer = setTimeout(() => {
  288. this.loadCarInfo(true)
  289. clearTimeout(timer)
  290. }, 8000)
  291. }
  292. }
  293. this.$_queryCarStatus()
  294. this.cycleTimer = setInterval(() => {
  295. this.$_queryCarStatus()
  296. }, 10000);
  297. },
  298. onUnload: function() {
  299. if (this.cycleTimer) {
  300. clearInterval(this.cycleTimer);
  301. this.cycleTimer = null;
  302. }
  303. if (this.isCustomJump && this.isReturnIndex) {
  304. uni.switchTab({
  305. url: '/pages/my/my'
  306. });
  307. } else if (this.isCustomJump && !this.isReturnIndex) {
  308. uni.switchTab({
  309. url: '/pages/index/index' // 首页
  310. });
  311. }
  312. },
  313. /**
  314. * 生命周期函数--监听页面显示
  315. */
  316. onShow: function() {
  317. this.isCustomJump = true
  318. },
  319. methods: {
  320. // 查询车辆关键参数
  321. $_queryCarStatus() {
  322. const myLocation = uni.getStorageSync('user_current_location')
  323. const data = {
  324. longitude: myLocation.longitude,
  325. latitude: myLocation.latitude,
  326. plate_number: this.plate_number
  327. }
  328. http.postApi(config.API_DAYHIRE_CAR_CAR_STATUS, data, res => {
  329. if (res.data.code !== 200) return
  330. const { is_on, last_comm_time, last_endurance, protect_state, quantity, third_device_type } = res.data.data
  331. this.orderInfo.is_on = is_on
  332. this.orderInfo.third_device_type = third_device_type
  333. this.setData({
  334. last_endurance,
  335. protect_state: protect_state == 1,
  336. quantity
  337. })
  338. })
  339. },
  340. handleCanvasToImage(imageUrl) {
  341. this.imageUrl = imageUrl
  342. },
  343. walletInfo() {
  344. http.postApi(config.API_DAYHIRE_USER_WALLET_INFO, {}, function(resp) {
  345. if (resp.data.code === 200) {
  346. } else {
  347. common.simpleToast(resp.data.msg)
  348. }
  349. })
  350. },
  351. getWxLocation() {
  352. const me = this;
  353. uni.getLocation({
  354. type: 'gcj02',
  355. isHighAccuracy: true,
  356. success: function(res) {
  357. me.myLocation = {
  358. longitude: res.longitude,
  359. latitude: res.latitude
  360. }
  361. uni.setStorageSync('user_current_location', me.myLocation)
  362. },
  363. fail: function(res) {
  364. common.simpleToast(this.$t('获取地址失败,请授权重新打开'))
  365. }
  366. })
  367. // this.loadCarInfo()
  368. },
  369. loadCarInfo(init = false) {
  370. const me = this
  371. const myLocation = uni.getStorageSync('user_current_location')
  372. const pData = {
  373. longitude: myLocation.longitude,
  374. latitude: myLocation.latitude,
  375. plate_number: me.plate_number
  376. }
  377. return new Promise(function(resolve, reject) {
  378. http.postApi(config.API_DAYHIRE_CAR_CAR_INFO, pData, function(resp) {
  379. if (resp.data.code === 200) {
  380. me.orderInfo = resp.data.data
  381. const _model_image = resp.data.data.model_info.model_images ? resp.data.data.model_info
  382. .model_images.split(",")[0] : ''
  383. me.setData({
  384. quantity: me.orderInfo.quantity,
  385. last_endurance: me.orderInfo.last_endurance,
  386. protect_state: me.orderInfo.protect_state == 1
  387. })
  388. if (init) {
  389. me.setData({
  390. initialProtectState: me.orderInfo.protect_state,
  391. initialIsOn: me.orderInfo.is_on
  392. })
  393. }
  394. resolve(me.orderInfo)
  395. me.model_info = me.orderInfo.model_info
  396. me.model_image = _model_image
  397. me.order_sn = me.orderInfo.order_sn
  398. me.return_imgs = me.orderInfo.return_imgs
  399. const datetime = Math.floor(new Date().getTime() / 1000); //获取当前时间
  400. var remain = Math.ceil(me.orderInfo.hire_expire_time - datetime) / 60
  401. const car_list = {
  402. plate_number: me.plate_number,
  403. order_status: me.orderInfo.order_info.order_status,
  404. battery_sn: me.orderInfo.order_info.battery_sn || '',
  405. remain: me.orderInfo.hire_expire_time - datetime > 0
  406. }
  407. uni.setStorageSync('user_car_list', car_list)
  408. // var remain = Math.ceil(me.orderInfo.hire_expire_time - datetime) / 60
  409. if (remain > 0) {
  410. var day = Math.floor(remain / (60 * 24))
  411. var hour = Math.floor((remain - day * (60 * 24)) / 60)
  412. var Minute = Math.floor(remain - (hour * 60) - day * (60 * 24))
  413. me.orderInfo.time = {
  414. day: day,
  415. hour: hour,
  416. minute: Minute,
  417. }
  418. } else {
  419. me.orderInfo.time = ''
  420. }
  421. } else {
  422. // 默认返回首页再提示报错
  423. me.isCustomJump = false
  424. uni.reLaunch({
  425. url: '/pages/index/index'
  426. })
  427. common.simpleToast(resp.data.msg)
  428. }
  429. })
  430. })
  431. },
  432. bindReturnCar() {
  433. this.setData({
  434. isShowReturnCar: true
  435. })
  436. },
  437. bindRenewHire() {
  438. let isRenew = true
  439. this.isCustomJump = false
  440. uni.navigateTo({
  441. url: '/pages/carIntroduce/carIntroduce?plate_number=' + this.plate_number + '&isRenew=' +
  442. isRenew +
  443. '&order_sn=' + this.order_sn,
  444. success: function(res) {},
  445. fail: function(res) {},
  446. complete: function(res) {}
  447. });
  448. },
  449. bindChangeStatus(e) {
  450. const status = e.currentTarget.dataset.status
  451. this.setData({
  452. isSelectStatus: status
  453. })
  454. },
  455. bindMinus() {
  456. if (this.count > 1) {
  457. this.setData({
  458. count: this.count - 1
  459. });
  460. }
  461. },
  462. bindInput(e) {
  463. let count = Number(e.detail.value)
  464. this.setData({
  465. count: count,
  466. })
  467. },
  468. bindBlur(e) {
  469. const count = e.detail.value
  470. if (count < 1) {
  471. this.setData({
  472. count: 1
  473. })
  474. }
  475. },
  476. bindAdd() {
  477. this.setData({
  478. count: this.count + 1
  479. });
  480. },
  481. clickSelectGuarantee(e) {
  482. const status = e.currentTarget.dataset.status
  483. this.setData({
  484. isSelectGuarantee: status
  485. })
  486. },
  487. clickCarCommand(e, isRefresh = false) {
  488. var command = e.currentTarget.dataset.command;
  489. const commandTips = {
  490. FINDCAR: {
  491. title: this.$t('响铃找车'),
  492. desc: this.$t('您确定开启响铃找车?'),
  493. success: this.$t('车辆已开始鸣笛')
  494. },
  495. OPENSEATLOCK: {
  496. title: this.$t('开座桶锁'),
  497. desc: this.$t('您确定打开座桶锁?'),
  498. success: this.$t('座桶锁已打开')
  499. },
  500. SAFEON: {
  501. title: this.$t('上锁'),
  502. desc: this.$t('您确定给车辆上锁?'),
  503. optTxt: '正在上锁...',
  504. success: this.$t('已上锁')
  505. },
  506. SAFEOFF: {
  507. title: this.$t('解锁'),
  508. desc: this.$t('您确定给车辆解锁?'),
  509. optTxt: '正在解锁...',
  510. success: this.$t('已解锁')
  511. }
  512. }
  513. const tipTitle = commandTips[command].title || ""
  514. const tipDesc = commandTips[command].desc || ""
  515. const tipSuccess = commandTips[command].success || ""
  516. const optTxt = commandTips[command].optTxt || ""
  517. const me = this
  518. uni.showModal({
  519. title: tipTitle,
  520. content: tipDesc,
  521. cancelText: this.$t('取消'),
  522. confirmText: this.$t('确定'),
  523. success: function(res) {
  524. if (res.confirm) {
  525. const pData = {
  526. plate_number: me.plate_number,
  527. cmd: command
  528. }
  529. http.postApi(config.API_CAR_SEND_COMMAND, pData, function(resp) {
  530. if (resp.data.code === 200) {
  531. if (isRefresh) {
  532. const TIME = 8000
  533. common.simpleToast(optTxt, TIME)
  534. const timer = setTimeout(() => {
  535. me.loadCarInfo()
  536. clearTimeout(timer)
  537. }, TIME)
  538. } else {
  539. common.simpleToast(tipSuccess, 4000)
  540. }
  541. } else {
  542. common.simpleToast(resp.data.msg)
  543. }
  544. })
  545. } else if (res.cancel) {
  546. // common.simpleToast(this.$t('已取消'))
  547. }
  548. },
  549. fail: function(res) {
  550. common.simpleToast(res.data.msg)
  551. },
  552. complete: function(res) {},
  553. })
  554. },
  555. navToPage(e) {
  556. var url = e.currentTarget.dataset.url;
  557. const index = e.currentTarget.dataset.index;
  558. if (index === '1') {
  559. const num = (this.orderInfo.order_info.gift_exchange_num - this.orderInfo.order_info
  560. .used_exchange_num) || 0
  561. const free_num = num > 0 ? num : 0
  562. url = url + '?free_num=' + free_num
  563. // 车辆换电
  564. } else if (index === '4') {
  565. // 拖车服务
  566. url = url + '?plate_number=' + this.plate_number + '&car_model=' + this.model_info.car_model +
  567. '&model_images=' + this.model_info.model_images
  568. } else if (index === '5') {
  569. // 查看订单
  570. const isJumpReturn = false
  571. url = url + '?order_sn=' + this.order_sn + '&isJumpReturn=' + isJumpReturn
  572. } else {
  573. // 其他都需要带车牌号
  574. url = url + '?plate_number=' + this.plate_number
  575. }
  576. if (!url) {
  577. return;
  578. }
  579. this.isCustomJump = false
  580. uni.navigateTo({
  581. url: url
  582. })
  583. },
  584. toNearbyStorePage() {
  585. this.isCustomJump = false
  586. uni.navigateTo({
  587. url: '/pages/carReturnStores/carReturnStores?plate_number=' + this.plate_number +
  588. '&car_model=' + this
  589. .model_info.car_model + '&model_image=' + this.model_image + '&return_imgs=' +
  590. encodeURIComponent(JSON.stringify(this.return_imgs))
  591. })
  592. },
  593. toRurnCarPage() {
  594. this.isCustomJump = false
  595. uni.navigateTo({
  596. url: '/pages/returnCar/returnCar?plate_number=' + this.plate_number + '&car_model=' + this
  597. .model_info.car_model + '&model_image=' + this.model_image + '&return_imgs=' +
  598. encodeURIComponent(JSON.stringify(this.return_imgs))
  599. });
  600. },
  601. bindCarStatus(e) {
  602. const is_on = e.currentTarget.dataset.car
  603. const me = this
  604. const CUR_IS_ON = (is_on - 0) == 1
  605. // is_on :0 2 :锁车 1 :启动
  606. uni.showModal({
  607. title: this.$t('车辆提示'),
  608. content: CUR_IS_ON ? '确认关闭车辆?' : '确认需要启动车辆?',
  609. cancelText: this.$t('取消'),
  610. confirmText: this.$t('确定'),
  611. success: function(res) {
  612. if (res.confirm) {
  613. const pData = {
  614. plate_number: me.plate_number,
  615. cmd: CUR_IS_ON ? 'LOCK' : 'UNLOCK', // 1 开启 0 关闭 2
  616. }
  617. http.postApi(config.API_DAYHIRE_CAR_LOCK, pData, function(resp) {
  618. if (resp.data.code === 200) {
  619. const text = CUR_IS_ON ? '正在关闭车辆...' : '正在启动车辆...';
  620. const resultText = CUR_IS_ON ? this.$t('车辆已关闭') : this.$t('车辆已启动');
  621. common.simpleToast(text, 4000)
  622. setTimeout(() => {
  623. me.loadCarInfo().then(res => {
  624. // console.log(me.initialIsOn, res.is_on)
  625. // const TEXT = me.initialIsOn === res.is_on ? this.$t('操作超时') : resultText
  626. // me.setData({
  627. // initialIsOn: res.is_on
  628. // })
  629. // common.simpleToast(TEXT, 4000)
  630. })
  631. }, 8000);
  632. } else {
  633. common.simpleToast(resp.data.msg)
  634. }
  635. })
  636. } else if (res.cancel) {
  637. common.simpleToast(this.$t('已取消'))
  638. }
  639. },
  640. fail: function(res) {
  641. common.simpleToast(res.data.msg)
  642. },
  643. complete: function(res) {},
  644. })
  645. }
  646. }
  647. };
  648. </script>
  649. <style>
  650. @import './battery.css';
  651. </style>