purchaseOrder.vue 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870
  1. <template>
  2. <view class="container-view">
  3. <view class="select-time-view">
  4. <view class="flex-row">选择取车时间</view>
  5. <view @tap="tapSelectTime" class="flex-row align-center">
  6. <text class="select-time-text">12-01 10:30</text>
  7. <img style="width: 28rpx;height: 28rpx;" src="https://qiniu.bms16.com/FpbKGisSPfL9r8a7QkZCYXolhu1Y" alt="">
  8. </view>
  9. </view>
  10. <view class="car-info-view">
  11. <view class="flex-row align-center">
  12. <img style="width: 160rpx;height: 160rpx;border-radius: 16rpx;" src="https://qiniu.bms16.com/FrwDlFZdSMiBgqnqDjB19PiDUmuu" alt="">
  13. <view class="flex-row car-info-grow">
  14. <view class="flex-row align-center">
  15. <view class="car-name">智能电动摩托车智驾</view>
  16. <img style="width: 28rpx;height: 28rpx;" src="https://qiniu.bms16.com/FpbKGisSPfL9r8a7QkZCYXolhu1Y" alt="">
  17. </view>
  18. <view class="car-information">月租 月租 共计60 天</view>
  19. <allPrice :amount="65"></allPrice>
  20. </view>
  21. </view>
  22. <view class="config-list-view">
  23. <view :class="service_list.length>4?'config-list-view-1 flex-row':'flex-row'">
  24. <view class="service_name-tab" v-for=" (item,indexs) in service_list" :key="indexs">
  25. {{item.service_name}}
  26. </view>
  27. </view>
  28. </view>
  29. </view>
  30. <view class="deposit-info">
  31. <view class="deposit-info-title flex-row flex-between">
  32. <text>车辆押金</text>
  33. <text>$100</text>
  34. </view>
  35. <view class="deposit-info-text">需要支付100元押金,诺无车损、违章及逾期,还车后可退</view>
  36. </view>
  37. <view class="method-info">
  38. <view class="flex-row flex-between" style="margin-bottom: 40rpx;">
  39. <view class="font_32">前往门店取还</view>
  40. <view class="font_32">门店距您 <text class="distance-num">100m</text></view>
  41. </view>
  42. <view @tap="bindToNav" class="shop-bg flex-row flex-between">
  43. <view class="shop-name-view">
  44. <!-- <view class="shop-name">{{shopInfo.shop_name}}</view>
  45. <view class="shop-address">{{shopInfo.address}}</view> -->
  46. <view class="shop-name">这里是一个门店的名称</view>
  47. <view class="shop-address">南山区西丽留仙洞留仙村路南山区西丽留仙…</view>
  48. </view>
  49. <view class="nav-btn flex-row">
  50. <img style="width: 48rpx;height: 48rpx;" src="https://zxappfile.bms16.com/zx_admin/cab_nav.png"
  51. alt="">
  52. <view style="margin-top: 12rpx;font-size: 24rpx;">导航</view>
  53. </view>
  54. </view>
  55. </view>
  56. <view style="height: 224rpx;"></view>
  57. <view v-if="!isShowDetail" class="payment-info">
  58. <view class="payment-bottom flex-row flex-between">
  59. <view class="bottom-left flex-row">
  60. <allPrice :amount="amount"></allPrice>
  61. <view @tap="bindDetail" class="all-money">明细<img
  62. src="https://qiniu.bms16.com/Fvl1d-AWRvwY_ehNrw7bMZOK6LBZ" /></view>
  63. </view>
  64. <view @tap="navToPage">{{is_freeze==0?'立即支付':'支付·授权免押'}}</view>
  65. </view>
  66. </view>
  67. <view v-else class="show-detail">
  68. <view class="detail-info">
  69. <view class="pay-money">
  70. <view class="flex-row flex-between" style="margin-bottom: 46rpx;">
  71. <view>价格明细</view>
  72. <view>
  73. <image style="width: 32rpx;height: 32rpx;" @tap="isShowDetail = false"
  74. src="https://qiniu.bms16.com/FtoTEHOJiUf_gjPCJGGHMsAtHI5M" />
  75. </view>
  76. </view>
  77. <view class="flex-row flex-between" style="margin-bottom: 44rpx;">
  78. <view>车辆租金</view>
  79. <view>
  80. <!-- ¥{{(leaseTime * price_list[0].hire_price) /100}} -->
  81. ¥{{(price/100)+'x'+count}}
  82. <text v-if="isSelectStatus==4">时</text>
  83. <text v-if="isSelectStatus==1">天</text>
  84. <text v-if="isSelectStatus==6">周</text>
  85. <text v-if="isSelectStatus==2">月</text>
  86. <text v-if="isSelectStatus==7">季</text>
  87. </view>
  88. </view>
  89. <view v-if="freeze_is_open==0||(freeze_is_open==1&&is_freeze==0)" class="flex-row flex-between"
  90. :style="insurance_setting!=null&&insurance_setting.price-0!=0?'margin-bottom: 44rpx;':''">
  91. <view>车辆押金</view>
  92. <view>¥{{modelInfo.deposit /100}}</view>
  93. </view>
  94. <view v-if="insurance_setting!=null&&insurance_setting.price-0!=0" class="flex-row flex-between"
  95. style="margin-bottom: 44rpx;">
  96. <view>骑行保障服务</view>
  97. <view v-if="isSelectStatus==4">{{'¥'+tools.toFix(insurance_setting.price / 100)+'x1天'}}</view>
  98. <view v-if="isSelectStatus==1">{{'¥'+tools.toFix(insurance_setting.price / 100)+'x'+count+'天'}}
  99. </view>
  100. <view v-if="isSelectStatus==6">
  101. {{'¥'+tools.toFix(insurance_setting.price / 100)+'x'+count*7+'天'}}
  102. </view>
  103. <view v-if="isSelectStatus==2">
  104. {{'¥'+tools.toFix(insurance_setting.price / 100)+'x'+count*30+'天'}}
  105. </view>
  106. <view v-if="isSelectStatus==7">
  107. {{'¥'+tools.toFix(insurance_setting.price / 100)+'x'+count*90+'天'}}
  108. </view>
  109. </view>
  110. <view class="detail-money flex-row" style="padding-bottom: 44rpx;">
  111. <view>支付金额</view>
  112. <allPrice :amount="amount"></allPrice>
  113. </view>
  114. </view>
  115. <view class="second">
  116. <view class="payment-bottom flex-row flex-between">
  117. <view class="bottom-left flex-row">
  118. <allPrice :amount="amount"></allPrice>
  119. <view @tap="isShowDetail = false" class="all-money">明细<img
  120. src="https://qiniu.bms16.com/FkzZI0r5jO-c2JRahNkZW2pHb9dR" /></view>
  121. </view>
  122. <view @tap="navToPage">{{is_freeze==0?'立即支付':'支付·授权免押'}}</view>
  123. </view>
  124. </view>
  125. </view>
  126. </view>
  127. <calendar ref="calendar" :showPopup.sync="isShowCalendar" @valuesUpdated="handleValuesUpdated"
  128. @close="() => isShowCalendar = false" />
  129. <view v-if="isShowReturnCar" class="return-box">
  130. <view class="return-item">
  131. <view class="return-title flex-row flex-between">
  132. <view>还车到门店</view>
  133. <view @tap="isShowReturnCar = false" class="close-view"><img style="width: 24rpx;height: 24rpx;" src="https://qiniu.bms16.com/FoWVlo-Nmx6wTDpsL2Rf9_BamU7L" alt=""></view>
  134. </view>
  135. <view class="return-text">系统会根据您的定位判断您是否已到还车位置,如您已经到达门店,请点击「我已到店」按钮,待门店确认还车后,即可还车成功。</view>
  136. <view class="return-btn flex-row">
  137. <view @tap="toRurnCarPage">导航到店</view>
  138. <view @tap="toNearbyStorePage">我已到店</view>
  139. </view>
  140. </view>
  141. </view>
  142. <view v-if="isShowCheckOrder" class="return-box">
  143. <view class="return-item">
  144. <view style="text-align: center;margin-bottom: 120rpx;">
  145. <img style="width: 88rpx;height: 88rpx;" src="https://qiniu.bms16.com/Fqb-i2uJWlZOg8EvUXHr_1qhlndf" alt="">
  146. <view class="check-order-text">租车订单已提交</view>
  147. <view>请于 <text class="get-car-time">3.5-20:00</text> 到 <text class="get-car-name">深圳南山深大店</text> 取车</view>
  148. </view>
  149. <view class="return-btn flex-row">
  150. <view @tap="toRurnCarPage">我知道了</view>
  151. <view @tap="toNearbyStorePage">订单详情</view>
  152. </view>
  153. </view>
  154. </view>
  155. </view>
  156. </template>
  157. <script module="tools" lang="wxs" src="@/pages/common/wxs/tools.wxs"></script>
  158. <script module="tools" lang="sjs" src="@/pages/common/wxs/tools.sjs"></script>
  159. <script>
  160. var config = require('../../common/config.js');
  161. var common = require('../../common/common.js');
  162. var http = require('../../common/http.js');
  163. var storage = require('../../common/storage.js');
  164. var user = require('../../common/user.js');
  165. import allPrice from '@/component/allPrice/allPrice';
  166. import calendar from '@/component/smartCalendar';
  167. import {
  168. MAX_LIMITS
  169. } from '@/common/constant.js';
  170. export default {
  171. components: {
  172. allPrice,
  173. calendar
  174. },
  175. data() {
  176. return {
  177. isShowReturnCar:false,
  178. isShowCheckOrder:false,
  179. takeCar: '',
  180. returnCar: '',
  181. leaseTime: '',
  182. // rentalUnit: '',
  183. startDate: '',
  184. desc_city: '',
  185. modelId: '',
  186. modelInfo: {},
  187. shopInfo: {},
  188. service_list: [],
  189. cancel_setting: [],
  190. return_type: 1,
  191. is_freeze: 0,//是否选择免押 1是 0否
  192. freeze_is_open: 0,
  193. distance: '',
  194. longitude: '',
  195. latitude: '',
  196. isSelectGuarantee: 0,
  197. isArgee: false,
  198. from: '',
  199. duration_unit: '',
  200. free_order_no: '', // 免押订单号
  201. contract_id: 0,
  202. contractInfo: [],
  203. insurance_setting: null,
  204. isAgree: false,
  205. amount: '',
  206. price_list: [],
  207. order_sn: '',
  208. out_request_no: '',
  209. isOpenNoDeposit: false, // 是否去开通免押
  210. noDepositStatusTimer: null,
  211. pay_type: 0,
  212. out_request_no: '',
  213. wallet_money: 0, // 用户钱包余额信息
  214. returnType: [], // 数组
  215. isShowDetail: false,
  216. isSelectStatus: 4,
  217. count: 1,
  218. isShowCalendar: false, //选择预约订单时间
  219. showInput: true,
  220. userInfo: {
  221. is_auth: 0,
  222. status: 0
  223. },
  224. };
  225. }
  226. /**
  227. * 生命周期函数--监听页面加载
  228. */
  229. ,
  230. onLoad: function(options) {
  231. //#ifdef MP-WEIXIN
  232. this.is_freeze = 0
  233. //#endif
  234. this.setData({
  235. takeCar: options.takeCar || '',
  236. returnCar: options.returnCar || '',
  237. leaseTime: options.leaseTime || '',
  238. isSelectStatus: options.duration_unit || ''
  239. })
  240. this.modelId = options.modelId || ''
  241. this.longitude = options.longitude || ''
  242. this.latitude = options.latitude || ''
  243. this.desc_city = options.desc_city || ''
  244. this.startDate = options.startDate || ''
  245. // if (this.rentalUnit == '小时') {
  246. // this.duration_unit = 4
  247. // } else if (this.rentalUnit == '天') {
  248. // this.duration_unit = 1
  249. // } else if (this.rentalUnit == '周') {
  250. // this.duration_unit = 6
  251. // }
  252. this.loadCarInfo()
  253. this.loadContractTitles();
  254. this.walletInfo()
  255. },
  256. /**
  257. * 生命周期函数--监听页面显示
  258. */
  259. onShow: function() {
  260. let pages = getCurrentPages();
  261. let currPage = pages[pages.length - 1];
  262. let isAgree = currPage.isAgree
  263. if (isAgree) {
  264. this.setData({
  265. isAgree: isAgree
  266. });
  267. }
  268. var userInfo = storage.getUserInfoData()
  269. if (userInfo) this.userInfo = userInfo.userInfo
  270. },
  271. computed: {
  272. serviceListLength() {
  273. return this.service_list.length;
  274. }
  275. },
  276. methods: {
  277. clickShowInsuranceDesc() {
  278. uni.navigateTo({
  279. url: '/pages/webContent/webContent?webContent=' + this.insurance_setting.illustrate +
  280. '&title=' + '保险须知',
  281. success: function(res) {},
  282. fail: function(res) {},
  283. complete: function(res) {},
  284. })
  285. },
  286. bindToNav() {
  287. const {
  288. address,
  289. latitude,
  290. longitude,
  291. shop_name
  292. } = this.shopInfo
  293. uni.openLocation({
  294. latitude: latitude - 0,
  295. longitude: longitude - 0,
  296. scale: 15,
  297. name: shop_name,
  298. address: address,
  299. success: function(res) {},
  300. })
  301. },
  302. loadCarInfo() {
  303. const me = this
  304. common.loading()
  305. http.postApi(config.API_DAYHIRE_CAR_MODEL_INFO, {
  306. model_id: me.modelId,
  307. longitude: me.longitude,
  308. latitude: me.latitude,
  309. }, (resp) => {
  310. if (resp.data.code === 200) {
  311. uni.hideLoading()
  312. me.freeze_is_open = resp.data.data.freeze_is_open //门店是1否0开启免押配置
  313. //#ifdef MP-ALIPAY
  314. me.is_freeze = resp.data.data.freeze_is_open==0?0:1
  315. //#endif
  316. me.modelInfo = resp.data.data.model_info
  317. me.shopInfo = resp.data.data.shop_info
  318. me.cancel_setting = resp.data.data.cancel_setting
  319. me.distance = common.formatDistance(me.shopInfo.distance - 0)
  320. me.modelInfo.endurance = common.formatDistance(me.modelInfo.endurance - 0)
  321. me.modelInfo.weight = common.formatWeight(me.modelInfo.weight - 0)
  322. me.service_list = resp.data.data.service_list
  323. me.insurance_setting = resp.data.data.insurance_setting
  324. me.returnType = resp.data.data.return_type
  325. me.return_type = resp.data.data.return_type[0]
  326. me.modelInfo.model_images = me.modelInfo.model_images.split(',')
  327. if (resp.data.data.price_list && Array.isArray(resp.data.data.price_list)) {
  328. me.price_list = resp.data.data.price_list
  329. resp.data.data.price_list.forEach(i => {
  330. if (i.hire_duration_unit == me.isSelectStatus) {
  331. me.setData({price:i.hire_price})
  332. // me.price = i.hire_price
  333. }
  334. })
  335. }
  336. me.bindDuration()
  337. } else {
  338. uni.hideLoading()
  339. common.simpleToast(resp.data.msg)
  340. }
  341. })
  342. },
  343. getServiceStyle(index) {
  344. if (index % 2 === 0) {
  345. return {
  346. borderRadius: '16rpx 0 0 16rpx'
  347. };
  348. } else {
  349. return {
  350. borderRadius: '0 16rpx 16rpx 0'
  351. };
  352. }
  353. },
  354. clickSelectMethod(e) {
  355. const status = e.currentTarget.dataset.status
  356. this.setData({
  357. return_type: status
  358. })
  359. },
  360. clickSelectDeposit(e) {
  361. const me = this
  362. const status = e.currentTarget.dataset.status
  363. me.setData({
  364. is_freeze: status
  365. })
  366. me.bindDuration()
  367. },
  368. clickSelectGuarantee(e) {
  369. const status = e.currentTarget.dataset.status
  370. this.setData({
  371. isSelectGuarantee: status
  372. })
  373. },
  374. navToPage(e) {
  375. const me = this
  376. if (this.userInfo.is_auth - 0 == 1 && this.userInfo.status - 0 != 2) {
  377. uni.showModal({
  378. title: '身份认证提示',
  379. content: '尚未完成身份认证,是否进行身份认证?',
  380. cancelText: '取消',
  381. confirmText: '确定',
  382. success: function(res) {
  383. if (res.confirm) {
  384. me.loadFaceToken()
  385. }
  386. },
  387. fail: function(res) {},
  388. complete: function(res) {},
  389. })
  390. return
  391. }
  392. // if (this.contractInfo.length > 0 && (!this.isAgree || this.contract_id == 0)) {
  393. // // if (有合同&&(没查看合同||没勾选同意)) {
  394. // common.simpleToast('请查阅合同')
  395. // return
  396. // }
  397. const isBuyModel= storage.getIsBuyModel()
  398. if(isBuyModel){//TODO
  399. common.simpleToast('您已有租车订单,请先完成订单')
  400. return
  401. }
  402. // if(storage.setIsBuyModel)
  403. //#ifdef MP-ALIPAY
  404. this.bindToPayAli()
  405. //#endif
  406. //#ifdef MP-WEIXIN
  407. this.bindToPayWx()
  408. //#endif
  409. },
  410. loadFaceToken() {
  411. const me = this
  412. http.postApi(config.API_USER_FACE_TOKEN, {}, (resp) => {
  413. if (resp.data.code === 200) {
  414. me.face_token = resp.data.data.token
  415. me.face_key = resp.data.data.key
  416. uni.navigateTo({
  417. url: '/pages/livenessView/livenessView?face_token=' + me.face_token +
  418. '&face_key=' + this.face_key,
  419. success: function(res) {},
  420. fail: function(res) {},
  421. complete: function(res) {},
  422. })
  423. } else {
  424. common.simpleToast(resp.data.msg)
  425. }
  426. })
  427. },
  428. bindToPayAli() {
  429. const me = this
  430. me.from = 'ali'
  431. const money = me.amount * 100
  432. // 默认钱包余额不够支付走支付宝(2)否则走钱包余额类型9
  433. me.pay_type = me.wallet_money < money ? '2' : '9'
  434. if (me.freeze_is_open == 1 && me.is_freeze == 1) { // 等于0表开启免押
  435. if (me.isOpenNoDeposit) {
  436. me.bindToPay()
  437. return
  438. }
  439. http.postApi(config.API_ALI_FREEZE, {
  440. model_id: me.modelInfo.model_id
  441. }, (resp) => {
  442. const params = resp.data.data.params
  443. my.tradePay({
  444. orderStr: params,
  445. success: (res) => {
  446. if (res.resultCode == 9000) {
  447. me.out_request_no = resp.data.data.request_no
  448. me.isOpenNoDeposit = true //开通成功后 不显示去开通免押金
  449. me.bindDuration()
  450. // me.amount = ((me.leaseTime * me.price_list[0].hire_price) + (me.insurance_setting!=null?(me.insurance_setting.price - 0):0)) / 100
  451. me.queryNoDepositStatus(me.out_request_no)
  452. } else {
  453. my.alert({
  454. content: '未成功开通免押金,需支付全部押金',
  455. });
  456. me.is_freeze = 0
  457. me.bindDuration()
  458. me.bindToPay()
  459. }
  460. },
  461. fail: (res) => {
  462. my.alert({
  463. content: '未成功开通免押金!',
  464. });
  465. }
  466. })
  467. })
  468. } else {
  469. me.bindToPay()
  470. }
  471. },
  472. bindToPayWx() {
  473. this.from = 'wx'
  474. this.free_order_no = ''
  475. const money = this.amount * 100
  476. // 默认钱包余额不够支付走微信(0)否则走钱包余额类型9
  477. this.pay_type = this.wallet_money < money ? '0' : '9'
  478. this.bindToPay()
  479. },
  480. bindToPay() {
  481. const me = this
  482. if (me.pay_type == '9' && me.wallet_money >= (me.amount * 100)) {
  483. uni.showModal({
  484. title: '支付提示',
  485. content: '确认使用钱包余额进行支付吗?',
  486. cancelText: '取消',
  487. confirmText: '确定',
  488. success: function(res) {
  489. if (res.confirm) {
  490. me.payMoney()
  491. } else if (res.cancel) {
  492. common.simpleToast('支付取消')
  493. return
  494. }
  495. },
  496. fail: function(res) {
  497. common.simpleToast(res.data.msg)
  498. },
  499. complete: function(res) {},
  500. })
  501. } else {
  502. me.payMoney()
  503. }
  504. },
  505. payMoney() {
  506. const me = this
  507. const begin_time = Math.floor(Date.parse(me.startDate + ':00') / 1000);
  508. http.postApi(config.API_DAYHIRE_HIRE_PREDETERMINE, {
  509. model_id: me.modelId,
  510. hire_duration: me.count, // 周期
  511. hire_duration_unit: me.isSelectStatus, // 周期单位
  512. begin_time: begin_time,
  513. from: me.from,
  514. return_type: me.return_type,
  515. free_order_no: me.free_order_no,
  516. pay_type: me.pay_type,
  517. city: me.desc_city,
  518. address: me.shopInfo.address,
  519. longitude: me.longitude,
  520. latitude: me.latitude,
  521. }, (resp) => {
  522. common.loading()
  523. if (resp.data.code === 200) {
  524. uni.hideLoading()
  525. me.order_sn = resp.data.data.order_sn;
  526. if (me.pay_type == '9') {
  527. common.simpleToast('支付成功')
  528. setTimeout(function() {
  529. uni.navigateTo({
  530. url: '/pages/orderStatus/orderStatus?order_sn=' + me.order_sn,
  531. success: function(res) {},
  532. fail: function(res) {},
  533. complete: function(res) {},
  534. })
  535. }, 500)
  536. } else {
  537. //#ifdef MP-ALIPAY
  538. my.tradePay({
  539. tradeNO: resp.data.data.trade_no,
  540. success: function(res) {
  541. if (res.resultCode == 9000) {
  542. common.simpleToast('支付成功');
  543. }
  544. setTimeout(function() {
  545. uni.navigateTo({
  546. url: '/pages/orderStatus/orderStatus?order_sn=' +
  547. me.order_sn + '&longitude=' + me
  548. .longitude + '&latitude=' + me
  549. .latitude,
  550. success: function(res) {},
  551. fail: function(res) {},
  552. complete: function(res) {}
  553. });
  554. }, 1000);
  555. },
  556. fail: function(res) {
  557. uni.navigateTo({
  558. url: '/pages/orderStatus/orderStatus?order_sn=' + me
  559. .order_sn + '&longitude=' + me.longitude +
  560. '&latitude=' + me.latitude,
  561. success: function(res) {},
  562. fail: function(res) {},
  563. complete: function(res) {}
  564. });
  565. },
  566. })
  567. //#endif
  568. //#ifdef MP-WEIXIN
  569. var payParams = JSON.parse(resp.data.data.payParams);
  570. user.wxPay(me.order_sn, payParams, function(isSuccess) {
  571. if (isSuccess) {
  572. common.simpleToast('支付成功')
  573. // // 跳转激活车辆
  574. // uni.navigateTo({
  575. // url: '/pages/inputLicensePlate/inputLicensePlate?order_sn=' + me.order_sn +'&order_model_id='+me.modelId,
  576. // success: function(res) {},
  577. // fail: function(res) {},
  578. // complete: function(res) {}
  579. // })
  580. setTimeout(function() {
  581. uni.navigateTo({
  582. url: '/pages/orderStatus/orderStatus?order_sn=' +
  583. me.order_sn + '&longitude=' + me
  584. .longitude +
  585. '&latitude=' + me.latitude,
  586. success: function(res) {},
  587. fail: function(res) {},
  588. complete: function(res) {}
  589. });
  590. }, 1000)
  591. } else {
  592. uni.navigateTo({
  593. url: '/pages/orderStatus/orderStatus?order_sn=' + me
  594. .order_sn +
  595. '&longitude=' + me.longitude + '&latitude=' + me
  596. .latitude,
  597. success: function(res) {},
  598. fail: function(res) {},
  599. complete: function(res) {}
  600. });
  601. }
  602. });
  603. //#endif
  604. }
  605. } else {
  606. uni.hideLoading()
  607. common.simpleToast(resp.data.msg)
  608. }
  609. })
  610. },
  611. queryNoDepositStatus(_out_request_no) {
  612. const me = this
  613. me.clearNoDepositStatusTimer();
  614. me.noDepositStatusTimer = setInterval(function() {
  615. http.postApi(
  616. config.API_ALI_FREEZE_STATUS, {
  617. model_id: me.modelInfo.model_id,
  618. out_request_no: _out_request_no
  619. },
  620. function(resp) {
  621. uni.hideLoading();
  622. if (resp.data.code === 200) {
  623. const {
  624. status
  625. } = resp.data.data
  626. if (status === 2) {
  627. common.simpleToast('开通免押金成功,正在前往租赁车辆~');
  628. me.clearNoDepositStatusTimer();
  629. setTimeout(function() {
  630. me.free_order_no = _out_request_no
  631. me.bindToPay()
  632. }, 1500);
  633. } else if (status === 1 || status === 0) {
  634. common.simpleToast('查询免押金开通状态中,请稍后~');
  635. }
  636. } else {
  637. common.simpleToast(resp.data.msg);
  638. me.clearNoDepositStatusTimer();
  639. }
  640. }
  641. );
  642. }, 1000)
  643. },
  644. // 清空查询免押金状态
  645. clearNoDepositStatusTimer: function() {
  646. if (this.noDepositStatusTimer == null) {
  647. return;
  648. }
  649. clearInterval(this.noDepositStatusTimer);
  650. this.noDepositStatusTimer = null;
  651. },
  652. bindContractInfo(e) {
  653. // if (!this.isAgree && this.contract_id == 0) {
  654. // common.simpleToast('请先点击阅读租赁合同');
  655. // return;
  656. // }
  657. const contract_id = e.currentTarget.dataset.contractid;
  658. if (this.contract_id == contract_id) {
  659. this.setData({
  660. contract_id: 0,
  661. });
  662. } else {
  663. this.setData({
  664. contract_id: contract_id
  665. });
  666. }
  667. },
  668. loadContractTitles() {
  669. const accountInfo = uni.getAccountInfoSync();
  670. const me = this;
  671. http.postApi(
  672. config.API_CONTRACT_TITLE, {
  673. appid: accountInfo.miniProgram.appId
  674. },
  675. function(resp) {
  676. if (resp.data.code === 200) {
  677. const contractInfo = resp.data.data.contractInfo;
  678. me.setData({
  679. contractInfo: contractInfo
  680. });
  681. }
  682. }
  683. );
  684. },
  685. bindContractTo(e) {
  686. const contract_id = e.currentTarget.dataset.contractid;
  687. this.setData({
  688. contract_id: contract_id
  689. });
  690. uni.navigateTo({
  691. url: '/pages/contract/contract?contract_id=' + contract_id,
  692. success: function(res) {},
  693. fail: function(res) {},
  694. complete: function(res) {}
  695. });
  696. },
  697. clickNotShow() {
  698. common.simpleToast('门店未开通,不可自选');
  699. },
  700. walletInfo() {
  701. const me = this
  702. http.postApi(config.API_DAYHIRE_USER_WALLET_INFO, {}, function(resp) {
  703. if (resp.data.code === 200) {
  704. me.wallet_money = resp.data.data.balance // 用户钱包余额信息,用于展示用户钱包余额信息。
  705. } else {
  706. common.simpleToast(resp.data.msg)
  707. }
  708. })
  709. },
  710. bindDetail() {
  711. this.isShowDetail = true
  712. },
  713. //计算价格
  714. bindDuration() {
  715. const me = this
  716. var _insurance_price //保险金
  717. const unit_price = (me.price / 100) * me.count //租金
  718. // insurance_setting 保险
  719. if (me.insurance_setting != null) { // 有保险的时候
  720. // isSelectDeposit==0为免押 isOpenNoDeposit为是否成功开通免押 total_money为总金额
  721. // unit_price 租金 insurance_setting.price 保险金 deposit 押金
  722. if (me.isSelectStatus == 4) { // 时
  723. _insurance_price = (me.insurance_setting.price - 0) * 1
  724. } else if (me.isSelectStatus == 6) { // 周
  725. _insurance_price = (me.insurance_setting.price - 0) * 7 * me.count
  726. } else if (me.isSelectStatus == 1) { //天
  727. _insurance_price = (me.insurance_setting.price - 0) * me.count
  728. } else if (me.isSelectStatus == 2) { //月
  729. _insurance_price = (me.insurance_setting.price - 0) * 30 * me.count
  730. } else if (me.isSelectStatus == 7) { //季
  731. _insurance_price = (me.insurance_setting.price - 0) * 90 * me.count
  732. }
  733. } else { // 无保险
  734. _insurance_price = 0
  735. }
  736. if (me.freeze_is_open == 1 &&( me.isOpenNoDeposit || me.is_freeze == 1)) {
  737. // 金额=(周期数*周期价格)+保险金
  738. me.amount = ((me.count * me.price - 0) + (_insurance_price - 0)) / 100
  739. } else {
  740. // 金额=(周期数*周期价格)+押金+保险金
  741. me.amount = ((me.count * me.price - 0) + (me.modelInfo.deposit - 0) + (_insurance_price - 0)) / 100
  742. }
  743. },
  744. bindChangeStatus(e) {
  745. const {
  746. status,
  747. unit,
  748. price
  749. } = e.currentTarget.dataset
  750. this.setData({
  751. isSelectStatus: unit,
  752. selectIndex: status,
  753. price: price,
  754. count: 1
  755. })
  756. this.bindDuration()
  757. },
  758. bindMinus() {
  759. if (this.count > 1) {
  760. this.setData({
  761. count: this.count - 1
  762. });
  763. }
  764. this.bindDuration()
  765. },
  766. blurHandle() {
  767. this.showInput = false
  768. this.$nextTick(() => {
  769. this.showInput = true
  770. })
  771. },
  772. bindInput(e) {
  773. // let count = Number(e.detail.value)
  774. // this.setData({
  775. // count: count,
  776. // })
  777. const num = e.detail.value
  778. this.bindTipCount(num)
  779. this.bindDuration()
  780. },
  781. bindBlur(e) {
  782. const count = e.detail.value
  783. this.bindTipCount(count)
  784. if (count < 1) {
  785. this.setData({
  786. count: 1
  787. })
  788. }
  789. this.bindDuration()
  790. },
  791. bindAdd() {
  792. // this.setData({
  793. // count: this.count + 1
  794. // });
  795. const num = this.count - 0 + 1
  796. this.bindTipCount(num)
  797. this.bindDuration()
  798. },
  799. bindTipCount(num) {
  800. const limit = MAX_LIMITS[this.isSelectStatus];
  801. if (limit && num > limit.max) {
  802. common.simpleToast(limit.message);
  803. this.setData({
  804. count: limit.max
  805. })
  806. this.blurHandle()
  807. } else {
  808. this.setData({
  809. count: num
  810. })
  811. }
  812. },
  813. handleValuesUpdated(e) {
  814. this.takeCar = e.takeCar
  815. this.returnCar = e.returnCar
  816. this.leaseTime = e.leaseTime
  817. this.startDate = e.startDate
  818. this.isShowCalendar = false;
  819. },
  820. tapSelectTime() {
  821. this.setData({
  822. isShowCalendar: true
  823. })
  824. this.$refs.calendar['leaseType'] = +this.selectType
  825. this.$nextTick(() => {
  826. this.$refs.calendar && this.$refs.calendar.setTakeCarData({
  827. takeCar: this.takeCar,
  828. dateText: this.startDate.replace('T', ' ')
  829. })
  830. })
  831. },
  832. }
  833. };
  834. </script>
  835. <style>
  836. @import './purchaseOrder.css';
  837. </style>