orderStatus.vue 33 KB

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