orderStatus.vue 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891
  1. <template>
  2. <view class="container-view">
  3. <view class="time-info">
  4. <view>
  5. <view v-if="orderInfo.pay_status!=2">
  6. <view v-if="orderInfo.pay_status == 0">待支付</view>
  7. <view v-else-if="orderInfo.pay_status == 1">支付中</view>
  8. <view v-else-if="orderInfo.pay_status == 3">支付失败</view>
  9. <view v-else-if="orderInfo.pay_status == 4">支付取消</view>
  10. <view v-else-if="orderInfo.pay_status == 5">线下待审核</view>
  11. <view v-else-if="orderInfo.pay_status == 6">线下审核拒绝</view>
  12. </view>
  13. <view v-if="orderInfo.order_status == 1">
  14. <!-- {{('请于'+tools.formatTimeSecond(orderInfo.hire_begin_time)+'到门店取车')}} -->
  15. 待取车
  16. </view>
  17. <view v-else-if="orderInfo.order_status == 2">请上传车辆图片激活车辆</view>
  18. <view v-else-if="orderInfo.order_status == 3" class="blue-text">使用中...</view>
  19. <view v-else-if="orderInfo.order_status == 4" class="red-text">已逾期</view>
  20. <view v-else-if="orderInfo.order_status == 5">待门店确认</view>
  21. <view v-else-if="orderInfo.order_status == 6">还车中,等待门店取车</view>
  22. <view v-else-if="orderInfo.order_status == 7">已完成</view>
  23. <view v-else-if="orderInfo.order_status == 8||orderInfo.order_status == 9">已取消</view>
  24. </view>
  25. <view class="time-money">
  26. <view class="flex-row flex-between">
  27. <view class="money-item">
  28. <view :class="orderInfo.order_status == 4?'red-status':''">
  29. {{orderInfo.hire_duration_time.day > 0 ? orderInfo.hire_duration_time.day :'' }}<text
  30. v-if="orderInfo.hire_duration_time.day>0">日</text>{{orderInfo.hire_duration_time.hour > 0 ? orderInfo.hire_duration_time.hour :'' }}<text
  31. v-if="orderInfo.hire_duration_time.hour>0">小时</text>{{orderInfo.hire_duration_time.minute > 0 ? orderInfo.hire_duration_time.minute :'' }}<text
  32. v-if="orderInfo.hire_duration_time.minute>0">分</text>
  33. </view>
  34. <view
  35. v-if="(orderInfo.order_status == 2&&orderInfo.hire_type==2) || orderInfo.order_status == 3">
  36. 租期剩余</view>
  37. <view v-else-if="orderInfo.order_status == 4" class="red-status">逾期时长</view>
  38. <view v-else>
  39. 租借周期:{{orderInfo.hire_duration}}{{hireDurationUnitFn(orderInfo.hire_duration_unit)}}</view>
  40. </view>
  41. <view class="money-item">
  42. <view :class="orderInfo.order_status == 4?'red-status':''">
  43. {{orderInfo.order_status == 4?tools.toFix(over_fee/100):tools.toFix(orderInfo.hire_money / 100)}}<text>元</text>
  44. </view>
  45. <view v-if="orderInfo.order_status == 4" class="red-status">逾期金额</view>
  46. <view v-else>订单金额</view>
  47. </view>
  48. <view @tap="bindExpanded">
  49. <text>{{isExpanded?'收起':'展开'}}</text>
  50. <img
  51. :src="isExpanded?'https://qiniu.bms16.com/FvRah8ro91B_TUVEmInBq6n69W2f':'https://qiniu.bms16.com/FtbxPP0aXYG8hyJTEJfNTXa_Puuc'" />
  52. </view>
  53. </view>
  54. <view v-if="isExpanded" class="dashed-border"></view>
  55. <view v-if="isExpanded">
  56. <view class="big-text">订单信息</view>
  57. <view class="sn-content flex-row flex-between">
  58. <view class="sn-title">订单编号</view>
  59. <view class="sn-text">{{orderInfo.sub_sn}}</view>
  60. </view>
  61. <view class="sn-content flex-row flex-between">
  62. <view class="sn-title">下单时间</view>
  63. <view class="sn-text">{{tools.formatTime(orderInfo.ctime)}}</view>
  64. </view>
  65. <view v-if="orderInfo.pay_time" class="sn-content flex-row flex-between">
  66. <view class="sn-title">支付时间</view>
  67. <view class="sn-text">{{tools.formatTime(orderInfo.pay_time)}}</view>
  68. </view>
  69. <view class="sn-content flex-row flex-between">
  70. <view class="sn-title">支付方式</view>
  71. <view v-if="orderInfo.pay_type == 0" class="sn-text">微信支付</view>
  72. <view v-if="orderInfo.pay_type == 1" class="sn-text">线下支付</view>
  73. <view v-if="orderInfo.pay_type == 2" class="sn-text">支付宝支付</view>
  74. <view v-if="orderInfo.pay_type == 9" class="sn-text">钱包余额支付</view>
  75. </view>
  76. <view class="sn-content flex-row flex-between">
  77. <view class="sn-title">租车金额</view>
  78. <view class="sn-text">$ {{tools.toFix(orderInfo.hire_money/1000)}}</view>
  79. </view>
  80. <view class="sn-content flex-row flex-between">
  81. <view class="sn-title">租车押金</view>
  82. <view class="sn-text"><text class="grey-text">订单结束后随时退</text> $
  83. {{tools.toFix(orderInfo.deposit/1000)}}
  84. </view>
  85. </view>
  86. </view>
  87. </view>
  88. </view>
  89. <view class="car-info">
  90. <view class="flex-row flex-between" style="margin-bottom: 40rpx;">
  91. <text>自行去门店取还</text>
  92. <text class="distance-num">{{orderInfo.distance}}m</text>
  93. </view>
  94. <view class="flex-row store-img-view">
  95. <img src="https://qiniu.bms16.com/FrwDlFZdSMiBgqnqDjB19PiDUmuu" alt="">
  96. <view style="width: 100%;margin-left: 24rpx;">
  97. <view class="store-name">{{orderInfo.shop_name}}</view>
  98. <view class="store-name-address">{{orderInfo.address}}</view>
  99. <view class="flex-row flex-between align-center">
  100. <view class="flex-row time-style align-center">
  101. <img v-if="orderInfo.work_begin_time && orderInfo.work_end_time" style="width: 40rpx;height: 40rpx;"
  102. src="https://qiniu.bms16.com/Fp-G1pdXxnTV-G3qFbgS453AuqcU" alt="">
  103. <text v-if="orderInfo.work_begin_time && orderInfo.work_end_time">{{orderInfo.work_begin_time}}-{{orderInfo.work_end_time}}</text>
  104. </view>
  105. <img @click="navToCabinet" style="width: 112rpx;height: 64rpx;"
  106. src="https://qiniu.bms16.com/Fts38M35doVjK09GfOza5qD-wwkK" alt="">
  107. </view>
  108. </view>
  109. </view>
  110. </view>
  111. <view class="car-info">
  112. <view>车辆信息</view>
  113. <view class="car-top flex-row flex-between">
  114. <view class="top-flex">
  115. <view>{{orderInfo.model_name}}</view>
  116. <view>续航{{orderInfo.endurance /100}}km|重量{{orderInfo.weight}}kg</view>
  117. </view>
  118. <img v-if="orderInfo.model_images" :src="orderInfo.model_images" alt=""></img>
  119. <img v-else src="https://qiniu.bms16.com/FhEvnKUckAHPtWaC04mi2s53IEVj" alt="">
  120. </view>
  121. <!-- <view class="exchange-info">
  122. <view class="flex-row flex-between">
  123. <view class="exchange-info-title flex-row align-center">
  124. <img style="width: 40rpx;height: 40rpx;" src="https://qiniu.bms16.com/Fj_ifr41AqH2PijZBdOBa3SCxADg" alt="">
  125. <text style="margin-left: 16rpx;">换电信息</text>
  126. </view>
  127. <view @tap="navToExchange" class="flex-row" style="margin-bottom: 28rpx;">
  128. <view class="exchange-button">共3次</view>
  129. <image src="https://qiniu.bms16.com/FpIN7AVzFU75slFlX-SIdnSEmn1k" style="width: 28rpx;height: 28rpx;" />
  130. </view>
  131. </view>
  132. <view class="exchange-content">本单可享3次免费换电数,超出后需单独支付</view>
  133. <view class="exchange-content">自费换电:S1/次</view> -->
  134. <!-- <view class="exchange-content">本单您可享受{{orderInfo.gift_exchange_num}}次免费换电,
  135. 当前免费换电剩余{{(orderInfo.gift_exchange_num - orderInfo.used_exchange_num) > 0 ? (orderInfo.gift_exchange_num - orderInfo.used_exchange_num) : '0' }}次,超出后需要单独支付换电费用
  136. </view> -->
  137. <!-- </view> -->
  138. </view>
  139. <view v-if="orderInfo.hire_begin_time!=0&&orderInfo.hire_end_time!=0" class="return-info">
  140. <view class="return-top flex-row flex-between">
  141. <view>取还时间</view>
  142. <view>
  143. <!-- 共3天{{orderInfo.hire_return_time.day > 0 ? orderInfo.hire_return_time.day :'' }}<text
  144. v-if="orderInfo.hire_return_time.day>0">日</text>{{orderInfo.hire_return_time.hour > 0 ? orderInfo.hire_return_time.hour :'' }}<text
  145. v-if="orderInfo.hire_return_time.hour>0">小时</text>{{orderInfo.hire_return_time.minute > 0 ? orderInfo.hire_return_time.minute :'' }}<text
  146. v-if="orderInfo.hire_return_time.minute>0">分</text> -->
  147. 共{{hireDurationUnitsFn(orderInfo.total_hire_time,orderInfo.hire_duration_unit)}}
  148. </view>
  149. </view>
  150. <view class="return-bottom flex-row">
  151. <view>{{orderInfo.hire_begin_time}}</view>
  152. <img src="https://qiniu.bms16.com/FoXmBbj7YGWmjyeuVEY35nzieqnx" />
  153. <view>{{orderInfo.hire_end_time}}</view>
  154. <!-- <view>{{tools.formatTimeDate(orderInfo.hire_begin_time)}}</view>
  155. <img src="https://qiniu.bms16.com/FoXmBbj7YGWmjyeuVEY35nzieqnx" />
  156. <view>{{tools.formatTimeDate(orderInfo.hire_end_time)}}</view> -->
  157. </view>
  158. </view>
  159. <view v-if="orderInfo.order_status==2||orderInfo.order_status==3||orderInfo.order_status==4"
  160. class="overdue-info">
  161. <view>逾期规则</view>
  162. <view class="overdue-one">
  163. <view>1. 逾期后还可用车吗?</view>
  164. <view>如果逾期将触发智能锁车逻辑,可能导致您无法正常用车,请及时续费或联系商家处理。</view>
  165. </view>
  166. <view class="overdue-two">
  167. <view>2. 逾期费计算标准是什么?</view>
  168. <view>小时租逾期费=每小时费用*逾期小时;当日还/日/周/月/季租逾期费=每天费用*逾期天数;如果不满1小时按1小时算,不满1天按1天算,最终收取的逾期费以门店确认的费用为准</view>
  169. </view>
  170. <view class="overdue-thr">
  171. <view>3. 逾期后续租如何收费?</view>
  172. <view>逾期后及时续租不收取逾期费,逾期时长将从续租订单的用车时间中抵扣</view>
  173. </view>
  174. </view>
  175. <!-- 考虑为空的情况 -->
  176. <view class="payment-info flex-row flex-between">
  177. <view v-if="orderInfo.order_status == 1 || orderInfo.pay_status == 5" class="cancel" @tap="clickCancel">结束订单</view>
  178. <view v-if="orderInfo.order_status == 1" class="flex-row"> <!-- 待取车 -->
  179. <view @tap="callStorePhone" class="deposit-btn w_224">联系门店</view>
  180. <view @tap="navToScan" class="sesame-btn w_288">扫码绑定</view>
  181. </view>
  182. <view v-if="orderInfo.order_status == 2" class="flex-row"> <!-- 待取车 -->
  183. <view @tap="callStorePhone" class="deposit-btn w_224">联系门店</view>
  184. <view @tap="navToScan" class="sesame-btn w_288">去上传</view>
  185. </view>
  186. <view v-else-if="orderInfo.order_status == 3||orderInfo.order_status == 4" class="flex-row"> <!-- 使用中 -->
  187. <view @tap="callStorePhone" class="cancel">联系门店</view>
  188. <view @tap="tapReturnCar" class="deposit-btn w_254">到店还车</view>
  189. <view @tap="bindRenew" class="sesame-btn w_224">续租</view>
  190. </view>
  191. <view v-else-if="orderInfo.order_status == 5||orderInfo.order_status == 6" @tap="callStorePhone"
  192. class="pay-btn">
  193. 联系门店</view> <!-- 待门店确认||还车中,等待门店取车 -->
  194. <view v-else-if="orderInfo.order_status == 7" @tap="callStorePhone" class="pay-btn">联系门店</view>
  195. <!--车辆已归还 已完成 -->
  196. </view>
  197. <view v-if="isShowCancel" class="cancel-b">
  198. <view class="cancel-box">
  199. <view class="cancel-title flex-row flex-between">
  200. <view>选择取消原因</view>
  201. <view @tap="isShowCancel = false" style="font-size: 60rpx;">×</view>
  202. </view>
  203. <view @tap="bindCancel" data-status="1" class="cancel-item flex-row flex-between">
  204. <view>行程变更无需用车</view>
  205. <img
  206. :src="reason == 1?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
  207. </view>
  208. <view @tap="bindCancel" data-status="2" class="cancel-item flex-row flex-between">
  209. <view>修改订单信息</view>
  210. <img
  211. :src="reason == 2?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
  212. </view>
  213. <view @tap="bindCancel" data-status="3" class="cancel-item flex-row flex-between">
  214. <view>不想要了</view>
  215. <img
  216. :src="reason == 3?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
  217. </view>
  218. </view>
  219. </view>
  220. <returnCar :isShowReturnCar="isShowReturnCar" @closeShowReturnCarBtn="()=>isShowReturnCar=false"
  221. @navStoreBtn="navStoreBtn" @immediatelyReturnBtn="immediatelyReturnBtn" />
  222. <carPlan @payToOrder='payReturn' v-if="showCarPlan" @changeSelectType="changeSelectType" @closeShowMore="showCarPlan = false" :params="params" :selectType="selectType"/>
  223. <PayTypeModel @closeShow="()=>isShowToBuy=false" @payToOrder="payToOrder" :free_price="totalPrice"
  224. :isShowToBuy="isShowToBuy" />
  225. </view>
  226. </template>
  227. <script module="tools" lang="wxs" src="@/pages/common/wxs/tools.wxs"></script>
  228. <script module="tools" lang="sjs" src="@/pages/common/wxs/tools.sjs"></script>
  229. <script>
  230. var config_gyq = require('../../common/config_gyq.js');
  231. var config = require('../../common/config.js');
  232. var request = require('../../common/request');
  233. var common = require('../../common/common.js');
  234. var http = require('../../common/http.js');
  235. var storage = require('../../common/storage.js');
  236. var user = require('../../common/user.js');
  237. //
  238. import {getRemainingTime} from '@/utils/util';
  239. var appWhiteListFilter = require('../../common/appWhiteListFilter.js');
  240. import allPrice from '@/component/allPrice/allPrice';
  241. import ReturnCar from '@/component/returnCar/returnCar';
  242. import carPlan from '@/component/carPlan/carPlan';
  243. import PayTypeModel from '@/component/payTypeModel/payTypeModel';
  244. import dayjs from 'dayjs'
  245. import duration from 'dayjs/plugin/duration'
  246. dayjs.extend(duration);
  247. export default {
  248. components: {
  249. allPrice,
  250. ReturnCar,
  251. PayTypeModel,
  252. carPlan
  253. },
  254. data() {
  255. return {
  256. select_type:'',
  257. car_detail:{},
  258. showCarPlan:false,
  259. return_imgs: {},
  260. charge_standard: {},
  261. isShowCancel: false,
  262. order_sn: '',
  263. reason: 0,
  264. orderInfo: {},
  265. shop_image: [],
  266. isExpanded: false,
  267. isShowPrice: false,
  268. timer: '',
  269. isSelectStatus: 1,
  270. price_list: [], //车辆价格 hire_duration_unit 1 日 4 小时 6 周
  271. insurance_status: 0,
  272. over_fee: 0, //逾期金额
  273. plate_number: '',
  274. isScanCondeRentalCar: '',
  275. isShowReturnCar: false,
  276. isShowToBuy: false,
  277. totalPrice: 0, //逾期支付金额
  278. };
  279. },
  280. /**
  281. * 生命周期函数--监听页面加载
  282. */
  283. onLoad: function(options) {
  284. this.sub_sn = options.sub_sn || ''
  285. this.bindOrderInfo()
  286. },
  287. /**
  288. * 生命周期函数--监听页面显示
  289. */
  290. onShow: function() {},
  291. onUnload: function() {},
  292. computed: {},
  293. methods: {
  294. async loadCarInfo(model_id) {
  295. const me = this
  296. http.postApi(config.API_FLK_INDEX_CAR_MODEL_DETAIL, {
  297. model_id,
  298. }, (resp) => {
  299. if (resp.data.code === 200) {
  300. const pData={
  301. ...this.car_detail,
  302. price:this.price
  303. }
  304. me.setData({
  305. car_detail:resp.data.data,
  306. params:{
  307. order_sn:this.orderInfo.order_sn,
  308. ...resp.data.data,
  309. price:(resp.data.data.rental_setting[0].hire_price/100).toFixed(2)
  310. }
  311. })
  312. console.log('车辆信息')
  313. console.log(resp.data.data)
  314. } else {
  315. common.simpleToast(resp.data.msg);
  316. }
  317. })
  318. },
  319. changeSelectType(select_type,price){
  320. this.setData({
  321. selectType: select_type,
  322. price:(price/100).toFixed(2)
  323. })
  324. },
  325. async navToScan(){
  326. let car_sn = this.orderInfo.car_sn || ''
  327. if(!car_sn){
  328. let res = await uni.scanCode({
  329. onlyFromCamera: true,
  330. scanType: [],
  331. });
  332. if(res[0]) return
  333. car_sn = res[1].result
  334. }
  335. uni.navigateTo({
  336. url:`/pages/activation/activation?model_id=${this.orderInfo.model_id}&sub_sn=${this.sub_sn}&car_sn=${car_sn}`
  337. })
  338. // let {data} = await request.postApi(config.API_CAR_ASSIGNMENT,{sub_sn:this.sub_sn,car_sn:res[1].result})
  339. },
  340. navToCabinet() {
  341. const {
  342. latitude,
  343. longitude,
  344. cityname,
  345. address,
  346. shop_name
  347. } = this.orderInfo
  348. uni.openLocation({
  349. latitude: latitude - 0,
  350. longitude: longitude - 0,
  351. scale: 15,
  352. name: shop_name,
  353. address: address,
  354. success: function(res) {}
  355. });
  356. },
  357. hireDurationUnitFn(type) {
  358. if (type == 1) {
  359. return '天'
  360. } else if (type == 2) {
  361. return '月'
  362. } else if (type == 3) {
  363. return '年'
  364. } else if (type == 4) {
  365. return '小时'
  366. } else if (type == 5) {
  367. return '分钟'
  368. } else if (type == 6) {
  369. return '周'
  370. } else if (type == 7) {
  371. return '季'
  372. }
  373. },
  374. hireDurationUnitsFn(time,type) {
  375. if (type == 1) {
  376. return Math.ceil(time / 60 / 60 / 24) + '天'
  377. } else if (type == 2) {
  378. return Math.ceil(time / 60 / 60 / 24 / 30) + '月'
  379. } else if (type == 3) {
  380. return Math.ceil(time / 60 / 60 / 24 / 30 / 365) + '年'
  381. } else if (type == 4) {
  382. return Math.ceil(time / 60 / 60) + '小时'
  383. } else if (type == 5) {
  384. return Math.ceil(time / 60) + '分钟'
  385. } else if (type == 6) {
  386. return Math.ceil(time / 60 / 60 / 24 / 7) + '周'
  387. } else if (type == 7) {
  388. return Math.ceil(time / 60 / 60 / 24 / 30 / 3) + '季'
  389. }
  390. },
  391. async bindOrderInfo() {
  392. let res = await uni.getLocation()
  393. const me = this
  394. http.postApi(config.API_FLK_ORDER_INFO, {
  395. sub_sn: me.sub_sn,
  396. latitude: res[1].latitude,
  397. longitude: res[1].longitude,
  398. }, (resp) => {
  399. if (resp.data.code === 200) {
  400. me.orderInfo = resp.data.data.order_info
  401. //
  402. if(resp.data.data.order_info.model_id){
  403. me.loadCarInfo(resp.data.data.order_info.model_id)
  404. }
  405. let distance = common.getFlatternDistance(res[1].longitude, res[1].latitude, me
  406. .orderInfo.longitude, me.orderInfo.latitude)
  407. resp.data.data.order_info.distance = distance
  408. // 取还时间展示
  409. // me.orderInfo.hire_return_time = common.getTimeToDay(Math.ceil(me.orderInfo
  410. // .hire_end_time - me.orderInfo.hire_begin_time) / 60)
  411. me.orderInfo.hire_return_time = getRemainingTime(me.orderInfo.hire_begin_time,me.orderInfo.hire_end_time)
  412. me.orderInfo.hire_begin_time = dayjs(me.orderInfo.hire_begin_time * 1000).format('YY/MM/DD')
  413. me.orderInfo.hire_end_time = dayjs(me.orderInfo.hire_end_time * 1000).format('YY/MM/DD')
  414. // 剩余租期判断
  415. if ((me.orderInfo.hire_type == 2 && me.orderInfo.order_status == 2) || me
  416. .orderInfo.order_status == 3) {
  417. me.orderInfo.hire_duration_time = common.getTimeToDay(Math.ceil(me
  418. .orderInfo.hire_end_time - (Math.floor(new Date()) / 1000)) /
  419. 60)
  420. } else {
  421. if (me.orderInfo.order_status == 4) {
  422. me.orderInfo.hire_duration_time = common.getTimeToDay(Math.ceil(Math
  423. .floor(new Date()) / 1000 - me.orderInfo.hire_end_time) /
  424. 60)
  425. } else {
  426. me.orderInfo.hire_duration_time = me.orderInfo.hire_return_time
  427. }
  428. }
  429. } else {
  430. // 默认返回上一个页面再提示报错
  431. uni.navigateBack({
  432. delta: 1
  433. })
  434. common.simpleToast(resp.data.msg)
  435. }
  436. })
  437. },
  438. navStoreBtn() {
  439. const {
  440. latitude,
  441. longitude,
  442. address,
  443. shop_name
  444. } = this.orderInfo
  445. uni.openLocation({
  446. latitude: latitude - 0,
  447. longitude: longitude - 0,
  448. scale: 15,
  449. name: shop_name,
  450. address: address,
  451. success: function(res) {}
  452. });
  453. },
  454. tapReturnCar() {
  455. this.setData({
  456. isShowReturnCar: true
  457. })
  458. },
  459. immediatelyReturnBtn() {
  460. //到店还车 判断逾期状态 如果逾期要交逾期费用 跳转到上传车辆图片再支付逾期费用还车
  461. const isOverdue = this.orderInfo.order_status == 4
  462. const {
  463. car_sn,
  464. shop_id,
  465. overdue_money
  466. } = this.orderInfo
  467. const returnCarParams = {
  468. car_sn,
  469. shop_id,
  470. overdue_money,
  471. isReturnCar: true,
  472. }
  473. if (isOverdue) {
  474. this.setData({
  475. totalPrice: overdue_money,
  476. isShowToBuy: true
  477. })
  478. } else {
  479. //提交还车图片
  480. uni.navigateTo({
  481. url:`/pages/activation/activation?isReturnCar=true,model_id=${this.orderInfo.model_id}&sub_sn=${this.sub_sn}&car_sn=${this.orderInfo.car_sn}`
  482. });
  483. }
  484. },
  485. callStorePhone() {
  486. const phone = this.orderInfo.link_phone
  487. common.callPhone(phone)
  488. },
  489. async clickCancel() {
  490. const me = this
  491. let res = await uni.showModal({
  492. title: '取消订单',
  493. content: '您是否需要取消该订单',
  494. confirmText: '是',
  495. confirmColor: '#0074FF',
  496. cancelText: '否',
  497. cancelColor: '#191D23',
  498. });
  499. if (res[1].confirm) {
  500. let {data} = await request.postApi(config.API_FLK_ORDER_CANCEL_PAY,{sub_sn:this.sub_sn})
  501. if(data.code == 200){
  502. common.simpleToast(data.msg)
  503. this.bindOrderInfo()
  504. }else{
  505. common.simpleToast(data.msg)
  506. }
  507. }
  508. },
  509. bindCancel(e) {
  510. const me = this
  511. me.reason = e.currentTarget.dataset.status;
  512. me.cancel = true
  513. common.loading()
  514. setTimeout(function() {
  515. http.postApi(config.API_DAYHIRE_HIRE_CANCEL_ORDER, {
  516. order_sn: me.order_sn
  517. }, (resp) => {
  518. if (resp.data.code === 200) {
  519. uni.hideLoading()
  520. common.simpleToast('取消成功')
  521. setTimeout(() => {
  522. me.bindOrderInfo()
  523. }, 500);
  524. } else {
  525. common.simpleToast('订单取消失败')
  526. }
  527. me.reason = 0
  528. me.isShowCancel = false
  529. })
  530. }, 600);
  531. },
  532. bindToNav() {
  533. console.log(111);
  534. const {
  535. address,
  536. latitude,
  537. longitude,
  538. shop_name
  539. } = this.shopInfo
  540. uni.openLocation({
  541. latitude: latitude - 0,
  542. longitude: longitude - 0,
  543. scale: 15,
  544. name: shop_name,
  545. address: address,
  546. success: function(res) {},
  547. })
  548. },
  549. bindToHome() {
  550. uni.reLaunch({
  551. url: '/pages/index/index',
  552. success: function(res) {},
  553. fail: function(res) {},
  554. complete: function(res) {}
  555. });
  556. },
  557. callPhone() {
  558. const me = this
  559. const phone = me.shopInfo.link_phone
  560. uni.showModal({
  561. content: `您是否要拨打电话${phone}?`,
  562. confirmText: '确定',
  563. success: (res) => {
  564. if (res.confirm) {
  565. uni.makePhoneCall({
  566. phoneNumber: phone,
  567. success() {},
  568. fail() {}
  569. })
  570. }
  571. },
  572. fail: (res) => {}
  573. })
  574. },
  575. bindRenew() {
  576. this.showCarPlan = true
  577. // this.isReturnHome = false
  578. // let isRenew = true
  579. // uni.navigateTo({
  580. // url: '/pages/carIntroduce/carIntroduce?plate_number=' + this.orderInfo
  581. // .license_plate_number +
  582. // '&isRenew=' + isRenew +
  583. // '&order_sn=' + this.order_sn,
  584. // success: function(res) {},
  585. // fail: function(res) {},
  586. // complete: function(res) {}
  587. // });
  588. },
  589. bindBattery() {
  590. this.isReturnHome = false
  591. uni.navigateTo({
  592. url: '/pages/battery/battery?plate_number=' + this.orderInfo.license_plate_number,
  593. success: function(res) {},
  594. fail: function(res) {},
  595. complete: function(res) {}
  596. });
  597. },
  598. bindExpanded() {
  599. this.isExpanded = !this.isExpanded
  600. },
  601. navToInput() {
  602. this.isReturnHome = false
  603. uni.navigateTo({
  604. url: '/pages/inputLicensePlate/inputLicensePlate?order_sn=' + this.orderInfo
  605. .order_sn,
  606. success: function(res) {},
  607. fail: function(res) {},
  608. complete: function(res) {}
  609. });
  610. },
  611. // 激活车辆
  612. navToActive() {
  613. this.isReturnHome = false
  614. const me = this
  615. if (this.orderInfo.hire_type == 1) { // 预约
  616. if (me.isScanCondeRentalCar) {
  617. uni.scanCode({
  618. onlyFromCamera: true,
  619. success: function(res) {
  620. me.loadScanCode(res.result)
  621. },
  622. fail: function(res) {},
  623. complete: function(res) {},
  624. })
  625. } else {
  626. uni.navigateTo({
  627. url: '/pages/inputLicensePlate/inputLicensePlate?order_sn=' + this
  628. .order_sn + '&order_model_id=' + this.orderInfo.model_id,
  629. success: function(res) {},
  630. fail: function(res) {},
  631. complete: function(res) {}
  632. });
  633. }
  634. } else { // 非预约
  635. const isJumpReturn = false
  636. uni.navigateTo({
  637. url: '/pages/activation/activation?order_sn=' + this.order_sn +
  638. '&plate_number=' + this
  639. .orderInfo.license_plate_number + '&isJumpReturn=' + isJumpReturn,
  640. success: function(res) {},
  641. fail: function(res) {},
  642. complete: function(res) {}
  643. });
  644. }
  645. },
  646. loadScanCode(battery_sn) {
  647. const pData = {
  648. longitude: this.longitude,
  649. latitude: this.latitude,
  650. battery_sn: battery_sn
  651. }
  652. const me = this
  653. http.postApi(config.API_DAYHIRE_CAR_CAR_INFO, pData, (resp) => {
  654. uni.hideLoading()
  655. if (resp.data.code === 200) {
  656. const timestamp = Date.now(); // 获取当前时间戳(毫秒)
  657. const isOffline = (Math.floor(timestamp / 1000) - resp.data.data
  658. .last_comm_time) > 1800
  659. me.plate_number = resp.data.data.license_plate_number
  660. if (resp.data.data.last_comm_time === 0 || isOffline) {
  661. common.simpleToast('此车辆已离线,请选择其他车辆')
  662. } else {
  663. let carInfo = JSON.stringify(resp.data.data)
  664. const car_model = resp.data.data.model_info.car_model
  665. const model_images = resp.data.data.model_info.model_images.split(',')
  666. const return_imgs = resp.data.data.return_imgs
  667. var model_id = resp.data.data.model_info.model_id
  668. if (resp.data.data.has_owner) { //车辆正在被使用
  669. if (resp.data.data.is_mine) { //是本人在使用
  670. wx.showModal({
  671. title: '提示',
  672. content: '已有正在使用的车辆,是否跳转至车辆详情页?',
  673. cancelText: '取消',
  674. confirmText: '确定',
  675. success: function(res) {
  676. this.isReturnHome = false
  677. uni.navigateTo({
  678. url: '/pages/battery/battery?plate_number=' +
  679. this.plate_number
  680. });
  681. },
  682. fail: function(res) {},
  683. complete: function(res) {},
  684. })
  685. } else {
  686. common.simpleToast('此车辆正在被使用')
  687. }
  688. } else {
  689. if (me.order_sn && me.order_sn != '') {
  690. if (this.orderInfo.model_id != model_id) { // 预租车型与之前预约车型不一致
  691. common.simpleToast('与预约车型不符')
  692. } else {
  693. this.isReturnHome = false
  694. uni.navigateTo({
  695. url: '/pages/activation/activation?plate_number=' +
  696. this.plate_number + '&order_sn=' + this
  697. .order_sn +
  698. '&car_model=' + car_model + '&model_image=' +
  699. model_images[0] + '&return_imgs=' + JSON
  700. .stringify(
  701. return_imgs),
  702. fail() {}
  703. })
  704. }
  705. } else {
  706. this.isReturnHome = false
  707. uni.navigateTo({
  708. url: '/pages/carIntroduce/carIntroduce?carInfo=' +
  709. encodeURIComponent(carInfo) + '&plate_number=' +
  710. this.plate_number,
  711. fail() {}
  712. })
  713. }
  714. }
  715. }
  716. } else {
  717. common.simpleToast(resp.data.msg)
  718. }
  719. })
  720. },
  721. bindToPay() {
  722. const me = this
  723. //#ifdef MP-ALIPAY
  724. const _from = 'ali'
  725. const _pay_type = 2
  726. //#endif
  727. //#ifdef MP-WEIXIN
  728. const _from = 'wx'
  729. const _pay_type = 0
  730. //#endif
  731. http.postApi(config.API_DAYHIRE_HIRE_CONTINUE_PAY, {
  732. order_sn: me.order_sn,
  733. from: _from,
  734. pay_type: _pay_type
  735. }, (resp) => {
  736. common.loading()
  737. if (resp.data.code === 200) {
  738. uni.hideLoading()
  739. //#ifdef MP-ALIPAY
  740. my.tradePay({
  741. tradeNO: resp.data.data.trade_no,
  742. success: function(res) {
  743. if (res.resultCode == 9000) {
  744. common.simpleToast('支付成功');
  745. }
  746. setTimeout(function() {
  747. me.bindOrderInfo()
  748. }, 1000)
  749. },
  750. fail: function(res) {
  751. common.simpleToast('支付失败,请重试')
  752. },
  753. })
  754. //#endif
  755. //#ifdef MP-WEIXIN
  756. var payParams = JSON.parse(resp.data.data.payParams);
  757. user.wxPay(me.order_sn, payParams, function(isSuccess) {
  758. if (isSuccess) {
  759. common.simpleToast('支付成功')
  760. setTimeout(function() {
  761. me.bindOrderInfo()
  762. }, 1000)
  763. } else {
  764. common.simpleToast('支付失败,请重试')
  765. }
  766. });
  767. //#endif
  768. } else {
  769. uni.hideLoading()
  770. common.simpleToast(resp.data.msg)
  771. }
  772. })
  773. },
  774. // 计算拖车说明收费价格
  775. calculateFare(distance, charge_list) {
  776. let fare = 0
  777. if (distance <= charge_list.start_mil) {
  778. fare = charge_list.start_price / 100
  779. } else {
  780. // actual_start_mil:实际距离单位米
  781. // over_start_price:向上取整的公里数*超出首公里的费用
  782. var actual_start_mil = distance - charge_list.start_mil
  783. var over_start_price = (Math.ceil(actual_start_mil / charge_list.step_mil)) * charge_list
  784. .step_price
  785. fare = (charge_list.start_price + over_start_price) / 100
  786. }
  787. const fareArray = fare.toFixed(2).split('.'); //将价格拆分为整数部分和小数部分
  788. const price_list = {
  789. start_mil: (charge_list.start_mil / 1000).toFixed(2),
  790. start_price: (charge_list.start_price / 100).toFixed(2),
  791. step_mil: (charge_list.step_mil / 1000).toFixed(2),
  792. step_price: (charge_list.step_price / 100).toFixed(2),
  793. actual_start_mil: actual_start_mil ? (actual_start_mil / 1000).toFixed(2) : 0,
  794. over_start_price: over_start_price ? (over_start_price / 100).toFixed(2) : 0,
  795. fare: fare.toFixed(2), // 保留两位小数
  796. fareArray: fareArray //将价格拆分为整数部分和小数部分
  797. }
  798. return price_list
  799. },
  800. bindChangeStatus(e) {
  801. const {
  802. status,
  803. unit
  804. } = e.currentTarget.dataset
  805. this.setData({
  806. isSelectStatus: unit,
  807. selectIndex: status
  808. })
  809. // this.bindDuration()
  810. },
  811. //计算价格
  812. // bindDuration(){
  813. // const me = this
  814. // var _insurance_price //保险金
  815. // const unit_price=(me.price_list[0].hire_price/100) * me.leaseTime //租金
  816. // // insurance_setting 保险
  817. // if (me.insurance_setting!=null) { // 有保险的时候
  818. // // isSelectDeposit==0为免押 isOpenNoDeposit为是否成功开通免押 total_money为总金额
  819. // // unit_price 租金 insurance_setting.price 保险金 deposit 押金
  820. // if (me.duration_unit == 4) { // 时
  821. // _insurance_price = (me.insurance_setting.price - 0) * 1
  822. // } else if(me.duration_unit == 6) { // 周
  823. // _insurance_price = (me.insurance_setting.price - 0) * 7 * me.leaseTime
  824. // } else { //天
  825. // _insurance_price = (me.insurance_setting.price - 0) * me.leaseTime
  826. // }
  827. // } else { // 无保险
  828. // _insurance_price = 0
  829. // }
  830. // if (me.isOpenNoDeposit) {
  831. // // 金额=(周期数*周期价格)+保险金
  832. // me.amount = ((me.leaseTime * me.price_list[0].hire_price -0) + (_insurance_price - 0)) / 100
  833. // } else {
  834. // // 金额=(周期数*周期价格)+押金+保险金
  835. // me.amount = ((me.leaseTime * me.price_list[0].hire_price -0) + (me.modelInfo.deposit -0) + (_insurance_price - 0)) / 100
  836. // }
  837. // },
  838. loadEnd() {
  839. this.bindOrderInfo()
  840. },
  841. navToExchange() {
  842. console.log('跳转换电记录');
  843. uni.navigateTo({
  844. url: '/pages/exchangeRecord/exchangeRecord' +
  845. '?order_sn=' + this.orderInfo.order_sn
  846. })
  847. }
  848. }
  849. };
  850. </script>
  851. <style>
  852. @import './orderStatus.css';
  853. </style>