|
@@ -14,7 +14,7 @@
|
|
|
<image v-else class="bg-img" src="https://qiniu.bms16.com/FhRnr7rADHHsOFfpWO4duD15SgIt" mode="aspectFill">
|
|
|
</image>
|
|
|
</view>
|
|
|
-
|
|
|
+
|
|
|
<view class="p-bg">
|
|
|
<view class="store-info-view">
|
|
|
<view class="store-name">{{storeInfo.shop_name}}</view>
|
|
@@ -38,7 +38,7 @@
|
|
|
</view>
|
|
|
</view>
|
|
|
<view v-if="storeInfo.work_begin_time" class="grid_text_2">
|
|
|
- {{storeInfo.work_begin_time[0]}}:{{storeInfo.work_begin_time[1]}}-{{storeInfo.work_end_time[0]}}:{{storeInfo.work_end_time[1]}}
|
|
|
+ {{storeInfo.work_begin_time.split(':')[0]}}:{{storeInfo.work_begin_time.split(':')[1]}}-{{storeInfo.work_end_time.split(':')[0]}}:{{storeInfo.work_end_time.split(':')[1]}}
|
|
|
</view>
|
|
|
</view>
|
|
|
<view @tap="bindToNav" class="right_grid flex-between">
|
|
@@ -55,58 +55,67 @@
|
|
|
</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
<view class="tip-view">
|
|
|
<view class="tip-title-view flex-row align-center">
|
|
|
- <image style="width: 144rpx;height: 40rpx;" src="https://qiniu.bms16.com/FjUW1kuRvXWTEftyn9nH1AbGWuxK"
|
|
|
- mode='aspectFit'></image>
|
|
|
- <image style="width: 86rpx;height: 80rpx;" src="https://qiniu.bms16.com/FibAaPERzqi6m95EP2jREUKixjUi"
|
|
|
- mode='aspectFill'></image>
|
|
|
+ <image style="width: 144rpx;height: 40rpx;"
|
|
|
+ src="https://qiniu.bms16.com/FjUW1kuRvXWTEftyn9nH1AbGWuxK" mode='aspectFit'></image>
|
|
|
+ <image style="width: 86rpx;height: 80rpx;"
|
|
|
+ src="https://qiniu.bms16.com/FibAaPERzqi6m95EP2jREUKixjUi" mode='aspectFill'></image>
|
|
|
<view class="w-bg flex-row"></view>
|
|
|
</view>
|
|
|
<view class="step-view flex-row align-center">
|
|
|
<view class="icon-list-view">
|
|
|
- <image class="img1" src="https://qiniu.bms16.com/Fp0BE27Q0VTD8qUJRHUVhWO6VEbO" mode='aspectFit'></image>
|
|
|
+ <image class="img1" src="https://qiniu.bms16.com/Fp0BE27Q0VTD8qUJRHUVhWO6VEbO" mode='aspectFit'>
|
|
|
+ </image>
|
|
|
</view>
|
|
|
<view class="dashed-line"></view>
|
|
|
<view class="icon-list-view">
|
|
|
- <image class="img1" src="https://qiniu.bms16.com/FqDzYwAbnSEgf3yv9SAb92Vq4ZEB"
|
|
|
- mode='aspectFit'></image>
|
|
|
+ <image class="img1" src="https://qiniu.bms16.com/FqDzYwAbnSEgf3yv9SAb92Vq4ZEB" mode='aspectFit'>
|
|
|
+ </image>
|
|
|
</view>
|
|
|
<view class="dashed-line"></view>
|
|
|
<view class="icon-list-view">
|
|
|
- <image class="img1" src="https://qiniu.bms16.com/FlFMHzco6j9XOpMI21tSnR9500Un"
|
|
|
- mode='aspectFit'></image>
|
|
|
+ <image class="img1" src="https://qiniu.bms16.com/FlFMHzco6j9XOpMI21tSnR9500Un" mode='aspectFit'>
|
|
|
+ </image>
|
|
|
</view>
|
|
|
</view>
|
|
|
<view class="step-tip-view flex-row align-center">
|
|
|
<view class="step-tip-text">
|
|
|
- <image class="step-num-1" src="https://qiniu.bms16.com/Fm4gMRmW6UOwLcU-eW8LDLNfiUJe" mode='aspectFill'>
|
|
|
+ <image class="step-num-1" src="https://qiniu.bms16.com/Fm4gMRmW6UOwLcU-eW8LDLNfiUJe"
|
|
|
+ mode='aspectFill'>
|
|
|
</image>线上选择用车方案生成待支付订单
|
|
|
</view>
|
|
|
<view class="step-tip-text">
|
|
|
- <image class="step-num-2" src="https://qiniu.bms16.com/FvYN7SxOYIhXEqSAJZrQIBQuTx79" mode='aspectFill'>
|
|
|
+ <image class="step-num-2" src="https://qiniu.bms16.com/FvYN7SxOYIhXEqSAJZrQIBQuTx79"
|
|
|
+ mode='aspectFill'>
|
|
|
</image>导航到店向商家支付订单金额
|
|
|
</view>
|
|
|
<view class="step-tip-text">
|
|
|
- <image class="step-num-3" src="https://qiniu.bms16.com/FhZ7w0X8iVuxFPdetEF9C3YYkJ7Z" mode='aspectFill'>
|
|
|
+ <image class="step-num-3" src="https://qiniu.bms16.com/FhZ7w0X8iVuxFPdetEF9C3YYkJ7Z"
|
|
|
+ mode='aspectFill'>
|
|
|
</image>支付完成后直接现场取车
|
|
|
</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- <view class="unit-type-view">
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ <!-- <view class="unit-type-view">
|
|
|
<view @click="status = 0;modelListsFn()" class="unit-type " :class="{'unit-type-i' : status == 0}">短租
|
|
|
</view>
|
|
|
<view @click="status = 1;modelListsFn()" class="unit-type" :class="{'unit-type-i' : status == 1}">长租
|
|
|
</view>
|
|
|
<view @click="status = 2;modelListsFn()" class="unit-type " :class="{'unit-type-i' : status == 2}">出售
|
|
|
</view>
|
|
|
+ </view> -->
|
|
|
+
|
|
|
+ <view class="unit-type-view">
|
|
|
+ <view v-for="(item,index) of tagList" :key="index" @click="tagId = item;modelListsFn()"
|
|
|
+ class="unit-type " :class="{'unit-type-i' : item == tagId}">{{typeArrFn(item)}}
|
|
|
+ </view>
|
|
|
</view>
|
|
|
-
|
|
|
<view class="car-info-list-view">
|
|
|
<view v-for="(item,index) of modelListsFn()" :key="index" class="car-info-view align-center flex-row">
|
|
|
<!-- <img class="car-img" src="https://qiniu.bms16.com/FsxOysJT2V3KNYev2YWadvjyKn2j" alt=""> -->
|
|
@@ -116,9 +125,7 @@
|
|
|
<view class="car-model-info">续航{{item.endurance}}km|重量{{item.weight}}kg</view>
|
|
|
<view class="flex-row flex-between">
|
|
|
<view class="unit-type-price flex-row">
|
|
|
- <text v-if="status == 0" style="margin-right: 8rpx;">短租</text>
|
|
|
- <text v-if="status == 1" style="margin-right: 8rpx;">长租</text>
|
|
|
- <text v-if="status == 2" style="margin-right: 8rpx;">出售</text>
|
|
|
+ <text style="margin-right: 8rpx;">{{typeArrFn(tagId)}}</text>
|
|
|
<priceTool :price="Number(item.money)" :font_size="40" />
|
|
|
</view>
|
|
|
<view @click="srcFn(`/pages/carDetail/carDetail?model_id=${item.model_id}`)"
|
|
@@ -139,6 +146,11 @@
|
|
|
var http = require('../../common/http.js');
|
|
|
var storage = require('../../common/storage.js');
|
|
|
import priceTool from '@/component/priceTool/priceTool';
|
|
|
+ import {
|
|
|
+ MAX_LIMITS,
|
|
|
+ LEASE_TYPE_ARR
|
|
|
+ } from '@/common/constant.js';
|
|
|
+ import aaaa from './aaaa.vue';
|
|
|
// import UseGuidance from '@/component/useGuidance/useGuidance';
|
|
|
export default {
|
|
|
components: {
|
|
@@ -147,7 +159,9 @@
|
|
|
},
|
|
|
data() {
|
|
|
return {
|
|
|
- shop_id:0,
|
|
|
+ tagId: 0,
|
|
|
+ tagList: [],
|
|
|
+ shop_id: 0,
|
|
|
status: 0,
|
|
|
shop_image: [],
|
|
|
storeInfo: {
|
|
@@ -160,11 +174,11 @@
|
|
|
/**
|
|
|
* 生命周期函数--监听页面加载
|
|
|
*/
|
|
|
- onLoad: function(options) {
|
|
|
+ onLoad: function(options) {
|
|
|
console.log(options, 'options');
|
|
|
this.shop_id = options.admin_id || ''
|
|
|
this.locationFn()
|
|
|
-
|
|
|
+
|
|
|
},
|
|
|
/**
|
|
|
* 生命周期函数--监听页面显示
|
|
@@ -177,133 +191,128 @@
|
|
|
let obj = []
|
|
|
for (let index = 0; index < this.storeInfo.model_list.length; index++) {
|
|
|
let item = this.storeInfo.model_list[index];
|
|
|
- if(item.sell_price){
|
|
|
+ if (this.tagId == 100 && item.sell_price) {
|
|
|
obj.push({
|
|
|
...item,
|
|
|
- money:(item.sell_price / 100).toFixed(2)
|
|
|
+ money: (item.sell_price / 100).toFixed(2)
|
|
|
})
|
|
|
- }
|
|
|
- for (var i = 0; i < item.price_setting.length; i++) {
|
|
|
- var items = item.price_setting[i];
|
|
|
- let money = (items.hire_price / 100).toFixed(2)
|
|
|
- if (!item.sell_price && this.status == 0 && (items.hire_duration_unit == 1 || items.hire_duration_unit == 4 || items
|
|
|
- .hire_duration_unit == 5 || items.hire_duration_unit == 6)) {
|
|
|
- obj.push({
|
|
|
- ...item,
|
|
|
- money
|
|
|
- })
|
|
|
- break
|
|
|
- }
|
|
|
- if (!item.sell_price && this.status == 1 && (items.hire_duration_unit == 2 || items.hire_duration_unit == 3 || items
|
|
|
- .hire_duration_unit == 4)) {
|
|
|
- obj.push({
|
|
|
- ...item,
|
|
|
- money
|
|
|
- })
|
|
|
- break
|
|
|
+ } else if (this.tagId != 100) {
|
|
|
+ for (let i = 0; i < item.price_setting.length; i++) {
|
|
|
+ var items = item.price_setting[i];
|
|
|
+ let money = (items.hire_price / 100).toFixed(2)
|
|
|
+ if (items.hire_duration_unit == this.tagId) {
|
|
|
+ obj.push({
|
|
|
+ ...item,
|
|
|
+ money
|
|
|
+ })
|
|
|
+ }
|
|
|
}
|
|
|
+ }
|
|
|
}
|
|
|
- }
|
|
|
- return obj
|
|
|
- },
|
|
|
- locationFn() {
|
|
|
- let _this = this
|
|
|
- uni.getLocation({
|
|
|
- success(res) {
|
|
|
- _this.loadStoreDetail(_this.shop_id, res.longitude, res.latitude)
|
|
|
-
|
|
|
- }
|
|
|
- })
|
|
|
- },
|
|
|
- srcFn(url) {
|
|
|
- uni.navigateTo({
|
|
|
- url
|
|
|
- })
|
|
|
- },
|
|
|
- isWorkTimerFn() {
|
|
|
- this.storeInfo.work_end_time = ''
|
|
|
- this.storeInfo.work_end_time = ''
|
|
|
- },
|
|
|
- loadStoreDetail(shop_id, longitude, latitude) {
|
|
|
- const me = this
|
|
|
- console.log(shop_id)
|
|
|
- console.log(longitude)
|
|
|
- console.log(latitude)
|
|
|
- http.postApi(config.API_NEAR_SHOP_INFO, {
|
|
|
- shop_id,
|
|
|
- longitude,
|
|
|
- latitude,
|
|
|
- }, (resp) => {
|
|
|
- if (resp.data.code === 200) {
|
|
|
- me.setData({
|
|
|
- storeInfo: resp.data.data.info
|
|
|
- })
|
|
|
- this.storeInfo.distance = common.formatDistance(Number(this.storeInfo.distance))
|
|
|
- this.shop_image = JSON.parse(resp.data.data.info.shop_image) || []
|
|
|
- var cabinetInfo = resp.data.data.info
|
|
|
- this.storeInfo.work_begin_time = (cabinetInfo.work_begin_time == null ? '00:00:00' :
|
|
|
- cabinetInfo
|
|
|
- .work_begin_time).split(':')
|
|
|
- this.storeInfo.work_end_time = (cabinetInfo.work_end_time == null ? '00:00:00' :
|
|
|
- cabinetInfo
|
|
|
- .work_end_time).split(':')
|
|
|
- this.isWorkTimer = this.isWithinTimeRange(cabinetInfo.work_begin_time,
|
|
|
- cabinetInfo.work_end_time)
|
|
|
- } else {
|
|
|
- common.simpleToast(resp.data.msg)
|
|
|
- }
|
|
|
- })
|
|
|
- },
|
|
|
- isWithinTimeRange(startTime, endTime) {
|
|
|
- // 获取当前时间
|
|
|
- const now = new Date();
|
|
|
- const currentMinutes = now.getHours() * 60 + now.getMinutes();
|
|
|
+ return obj
|
|
|
+ },
|
|
|
|
|
|
- // 将传入的时间转换为分钟
|
|
|
- const [startHour, startMinute] = startTime.map(Number);
|
|
|
- const [endHour, endMinute] = endTime.map(Number);
|
|
|
+ typeArrFn(type) {
|
|
|
+ if (!type) return ''
|
|
|
+ const result = LEASE_TYPE_ARR.find(v => v.value == type);
|
|
|
+ return result.label
|
|
|
+ },
|
|
|
+ locationFn() {
|
|
|
+ let _this = this
|
|
|
+ uni.getLocation({
|
|
|
+ success(res) {
|
|
|
+ _this.loadStoreDetail(_this.shop_id, res.longitude, res.latitude)
|
|
|
|
|
|
- const startMinutes = startHour * 60 + startMinute;
|
|
|
- const endMinutes = endHour * 60 + endMinute;
|
|
|
+ }
|
|
|
+ })
|
|
|
+ },
|
|
|
+ srcFn(url) {
|
|
|
+ uni.navigateTo({
|
|
|
+ url
|
|
|
+ })
|
|
|
+ },
|
|
|
+ isWorkTimerFn() {
|
|
|
+ this.storeInfo.work_end_time = ''
|
|
|
+ this.storeInfo.work_end_time = ''
|
|
|
+ },
|
|
|
|
|
|
- // 判断当前时间是否在指定范围内
|
|
|
- return currentMinutes >= startMinutes && currentMinutes <= endMinutes;
|
|
|
- },
|
|
|
- tapPhone() {
|
|
|
- const me = this
|
|
|
- uni.showModal({
|
|
|
- content: `您是否要拨打电话${me.storeInfo.link_phone}?`,
|
|
|
- confirmText: '确定',
|
|
|
- success: (res) => {
|
|
|
- if (res.confirm) {
|
|
|
- me.clearTimer()
|
|
|
- uni.makePhoneCall({
|
|
|
- phoneNumber: me.storeInfo.link_phone,
|
|
|
- success() {},
|
|
|
- fail() {}
|
|
|
+ loadStoreDetail(shop_id, longitude, latitude) {
|
|
|
+ const me = this
|
|
|
+ http.postApi(config.API_NEAR_SHOP_INFO, {
|
|
|
+ shop_id,
|
|
|
+ longitude,
|
|
|
+ latitude,
|
|
|
+ }, (resp) => {
|
|
|
+ if (resp.data.code === 200) {
|
|
|
+ me.setData({
|
|
|
+ storeInfo: resp.data.data.info
|
|
|
})
|
|
|
+ let arr = []
|
|
|
+ resp.data.data.info.model_list.map(item => {
|
|
|
+ if (item.sell_price) {
|
|
|
+ arr.push(100)
|
|
|
+ }
|
|
|
+ item.price_setting.map(item => {
|
|
|
+ arr.push(item.hire_duration_unit)
|
|
|
+ })
|
|
|
+
|
|
|
+ })
|
|
|
+
|
|
|
+ this.tagList = Array.from(new Set(arr));
|
|
|
+ this.tagId = this.tagList[0] || 0
|
|
|
+ this.storeInfo.distance = common.formatDistance(Number(this.storeInfo.distance))
|
|
|
+
|
|
|
+ this.shop_image = resp.data.data.info.shop_image || []
|
|
|
+ var cabinetInfo = resp.data.data.info
|
|
|
+ this.storeInfo.work_begin_time = (cabinetInfo.work_begin_time == null ? '00:00:00' :
|
|
|
+ cabinetInfo
|
|
|
+ .work_begin_time)
|
|
|
+ this.storeInfo.work_end_time = (cabinetInfo.work_end_time == null ? '00:00:00' :
|
|
|
+ cabinetInfo
|
|
|
+ .work_end_time)
|
|
|
+ this.isWorkTimer = common.isWithinTimeRange(cabinetInfo.work_begin_time,
|
|
|
+ cabinetInfo.work_end_time)
|
|
|
+ } else {
|
|
|
+ common.simpleToast(resp.data.msg)
|
|
|
}
|
|
|
- },
|
|
|
- fail: (res) => {}
|
|
|
- })
|
|
|
- },
|
|
|
- bindToNav() {
|
|
|
- const {
|
|
|
- address,
|
|
|
- latitude,
|
|
|
- longitude,
|
|
|
- shop_name
|
|
|
- } = this.storeInfo
|
|
|
- uni.openLocation({
|
|
|
- latitude: latitude - 0,
|
|
|
- longitude: longitude - 0,
|
|
|
- scale: 15,
|
|
|
- name: shop_name,
|
|
|
- address: address,
|
|
|
- success: function(res) {},
|
|
|
- })
|
|
|
- },
|
|
|
- }
|
|
|
+ })
|
|
|
+ },
|
|
|
+
|
|
|
+ tapPhone() {
|
|
|
+ const me = this
|
|
|
+ uni.showModal({
|
|
|
+ content: `您是否要拨打电话${me.storeInfo.link_phone}?`,
|
|
|
+ confirmText: '确定',
|
|
|
+ success: (res) => {
|
|
|
+ if (res.confirm) {
|
|
|
+ me.clearTimer()
|
|
|
+ uni.makePhoneCall({
|
|
|
+ phoneNumber: me.storeInfo.link_phone,
|
|
|
+ success() {},
|
|
|
+ fail() {}
|
|
|
+ })
|
|
|
+ }
|
|
|
+ },
|
|
|
+ fail: (res) => {}
|
|
|
+ })
|
|
|
+ },
|
|
|
+ bindToNav() {
|
|
|
+ const {
|
|
|
+ address,
|
|
|
+ latitude,
|
|
|
+ longitude,
|
|
|
+ shop_name
|
|
|
+ } = this.storeInfo
|
|
|
+ uni.openLocation({
|
|
|
+ latitude: latitude - 0,
|
|
|
+ longitude: longitude - 0,
|
|
|
+ scale: 15,
|
|
|
+ name: shop_name,
|
|
|
+ address: address,
|
|
|
+ success: function(res) {},
|
|
|
+ })
|
|
|
+ },
|
|
|
+ }
|
|
|
|
|
|
};
|
|
|
</script>
|