CarRental/page_user/carSelection.vue

828 lines
18 KiB
Vue
Raw Permalink Normal View History

2024-09-19 17:33:39 +08:00
<template>
<view class="page">
<u-navbar ref="navbar" title="租车" :border-bottom="false" :background="bgc" title-color='#000' title-size='36'
height='45'></u-navbar>
<view class="cont">
<u-mask :show="showchoose" :z-index='100' />
<view class="ips_box">
<view class="ipt">
<view class="left">
2024-09-25 18:03:49 +08:00
<view class="txt1">
2024-09-30 18:02:38 +08:00
{{addressInfo}}
2024-09-19 17:33:39 +08:00
</view>
<view class="txt">
2024-09-25 18:03:49 +08:00
|{{time}} 取车|
2024-09-19 17:33:39 +08:00
</view>
<view class="txt">
2024-09-25 18:03:49 +08:00
{{dataInfo.dictLabel}}
2024-09-19 17:33:39 +08:00
</view>
</view>
<view class="right" @click="showchoose=true">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uukFtL3r4DCAYPcUPsK0" mode=""></image>
</view>
</view>
</view>
<view class="choose_card" v-if="showchoose">
<view class="area_li">
2024-09-25 18:03:49 +08:00
<view class="city" @click="showCity()">
2024-09-19 17:33:39 +08:00
<view class="txt">
取车城市
</view>
2024-09-25 18:03:49 +08:00
<view class="words" style="white-space: nowrap;">
{{cityList[0].cityName}}
2024-09-30 18:02:38 +08:00
<image src="https://lxnapi.ccttiot.com/bike/img/static/uJkuBFsHACP6tnUo5nYm" mode="">
</image>
2024-09-19 17:33:39 +08:00
</view>
</view>
2024-09-25 18:03:49 +08:00
<view class="area" @click="getMapLocation()" style="white-space: nowrap;">
2024-09-19 17:33:39 +08:00
<view class="top">
<view class="txt">
2024-09-25 18:03:49 +08:00
取车地点
2024-09-19 17:33:39 +08:00
</view>
<view class="type">
距最近店铺727m
</view>
</view>
<view class="bot">
2024-09-25 18:03:49 +08:00
<view class="txt3">
{{addressInfo}}
</view>
2024-09-30 18:02:38 +08:00
<image src="https://lxnapi.ccttiot.com/bike/img/static/uJkuBFsHACP6tnUo5nYm" mode="">
</image>
2024-09-19 17:33:39 +08:00
</view>
</view>
2024-09-25 18:03:49 +08:00
<view class="dingw" style="white-space: nowrap;" @click="getaddress()">
2024-09-19 17:33:39 +08:00
当前位置
<image src="https://lxnapi.ccttiot.com/bike/img/static/unTHfCN5IgnVKDbadsFp" mode=""></image>
</view>
</view>
<view class="time_box">
<view class="time_li">
<view class="txt">
取车时间
</view>
2024-09-25 18:03:49 +08:00
<view class="words" @click="time1=true">
2024-09-30 18:02:38 +08:00
{{time}}
<image src="https://lxnapi.ccttiot.com/bike/img/static/uJkuBFsHACP6tnUo5nYm" mode="">
</image>
2024-09-19 17:33:39 +08:00
</view>
</view>
<view class="time_li">
<view class="txt">
选择租车周期
</view>
2024-09-30 18:02:38 +08:00
<view class="words" @click="showdata=true">
2024-09-25 18:03:49 +08:00
{{dataInfo.dictLabel}}
2024-09-30 18:02:38 +08:00
<image src="https://lxnapi.ccttiot.com/bike/img/static/uJkuBFsHACP6tnUo5nYm" mode="">
</image>
2024-09-19 17:33:39 +08:00
</view>
</view>
</view>
<view class="btn_li">
<view class="btns" @click="showchoose=false">
关闭
</view>
<view class="btn" @click="tosele()">
确定
</view>
</view>
</view>
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
<!-- <image class="kefu" src="https://lxnapi.ccttiot.com/bike/img/static/u8osHvZfHL7u3lbveVXx" mode=""></image> -->
2024-10-14 18:02:05 +08:00
<view class="car_card" v-for="(item,index) in shopList" :key="index"@click="toStore(item)">
2024-09-19 17:33:39 +08:00
<view class="card_top">
<view class="tit">
2024-10-14 18:02:05 +08:00
{{item.name}}
2024-09-19 17:33:39 +08:00
</view>
<view class="txt">
2024-10-14 18:02:05 +08:00
{{item.rentalCar}}辆可租 <view class="iconfont icon-xiangyou1"> </view>
2024-09-19 17:33:39 +08:00
</view>
</view>
<view class="type_box">
<view class="type">
2024-10-14 18:02:05 +08:00
{{item.distance}}m
2024-09-19 17:33:39 +08:00
</view>
<view class="address">
2024-10-14 18:02:05 +08:00
{{item.simpleAddress}}
2024-09-19 17:33:39 +08:00
</view>
</view>
<view class="car_info">
<view class="car_img">
2024-10-14 18:02:05 +08:00
<image :src="item.models[0].picture" mode=""></image>
2024-09-19 17:33:39 +08:00
</view>
<view class="info">
<view class="modle">
2024-10-14 18:02:05 +08:00
{{item.models[0].model}}
2024-09-19 17:33:39 +08:00
</view>
<view class="price">
2024-10-14 18:02:05 +08:00
日租 <span>{{item.models[0].price}}</span>
2024-09-19 17:33:39 +08:00
</view>
</view>
</view>
</view>
2024-09-25 18:03:49 +08:00
<u-picker mode="time" v-model="time1" :params="params" @confirm="confirm1" start-year="2024"
:default-time="pickertime" start="2024"></u-picker>
<!-- <u-mask :show="showdata" @click="closeData()" :z-index='100' /> -->
<view class="choosedata" v-if="showdata">
2024-09-19 17:33:39 +08:00
<view class="tit">
请选择租车周期
2024-09-30 18:02:38 +08:00
<image src="https://lxnapi.ccttiot.com/bike/img/static/uLzTHCbE6TTRPYj6rv8X" mode=""
@click="closeData()"></image>
2024-09-19 17:33:39 +08:00
</view>
2024-09-30 18:02:38 +08:00
<view class="li" v-for="(item,index) in dataList" :key="index" :class="index == dataIndex? 'act':''"
@click="chooseData(item,index)">
2024-09-25 18:03:49 +08:00
{{item.dictLabel}}
2024-09-19 17:33:39 +08:00
</view>
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
bgc: {
backgroundColor: '#fff'
},
sn: '',
showchoose: false,
CouponLists: [],
hight: 0,
2024-09-30 18:02:38 +08:00
showkf: false,
2024-09-25 18:03:49 +08:00
cityList: [],
dataList: [],
gps: {},
cityInfo: {},
cityIndex: -1,
addressInfo: '',
time1: false,
params: {
year: false,
month: true,
day: true,
hour: false,
minute: false,
second: false
},
startTime: '',
pickertime: '',
time: '',
2024-09-30 18:02:38 +08:00
showdata: false,
dataIndex: 0,
dataInfo: {},
shopList: []
2024-09-19 17:33:39 +08:00
}
},
2024-09-25 18:03:49 +08:00
onLoad() {
this.getcityList()
this.getdata()
},
2024-09-19 17:33:39 +08:00
onShow() {
2024-09-25 18:03:49 +08:00
let that = this
uni.getLocation({
type: 'gcj02',
success: function(lb) {
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
that.gps.latitude = lb.latitude;
that.gps.longitude = lb.longitude;
that.getCity()
that.getaddress()
that.getshopList()
},
fail: function(error) {
uni.showToast({
title: '未获取到定位信息,请点击设置勾选允许位置信息,即可使用全部功能',
icon: 'none',
duration: 2000
});
// that.getmarks()
// 在这里处理获取位置信息失败的情况
}
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
})
// 获取当前日期并设置startDate和pickertime
const now = new Date();
const month = now.getMonth() + 1; // 月份从0开始因此加1
const day = now.getDate();
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
// 格式化为 MM-DD 的字符串
this.startDate = `${month < 10 ? '0' : ''}${month}-${day < 10 ? '0' : ''}${day}`;
this.time = `${month < 10 ? '0' : ''}${month}${day < 10 ? '0' : ''}${day}`;
// 初始化pickertime为当天的默认日期
this.pickertime = this.startDate;
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
this.$nextTick(() => {
const query = uni.createSelectorQuery().in(this);
query.select('.ips_box').boundingClientRect(data => {
this.hight = data.height + 45
console.log('ips_box height:', this.hight);
}).exec();
});
},
methods: {
2024-10-14 18:02:05 +08:00
toStore(item) {
uni.navigateTo({
url: '/page_user/carStore?storeId=' + item.storeId
})
},
2024-09-30 18:02:38 +08:00
getshopList() {
let data = {
2024-09-25 18:03:49 +08:00
// phoneLon:this.gps.latitude,
2024-09-30 18:02:38 +08:00
phoneLon: 120.257144,
2024-09-25 18:03:49 +08:00
// phoneLat:this.gps.longitude,
2024-09-30 18:02:38 +08:00
phoneLat: 27.105719,
2024-10-14 18:02:05 +08:00
// isFreeCar: true
2024-09-25 18:03:49 +08:00
}
2024-09-30 18:02:38 +08:00
this.$u.post(`app/getStoreListByLocation`, data).then((res) => {
2024-09-25 18:03:49 +08:00
if (res.code == 200) {
this.shopList = res.data;
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
});
},
2024-09-30 18:02:38 +08:00
chooseData(item, index) {
this.dataInfo = item
this.dataIndex = index
2024-09-25 18:03:49 +08:00
},
2024-09-30 18:02:38 +08:00
closeData() {
this.showdata = false
2024-09-25 18:03:49 +08:00
},
confirm1(selectedDate) {
// 将用户选择的日期和当前日期进行比较
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
// 从回调中获取选择的月份和日期
const selectedMonth = parseInt(selectedDate.month, 10);
const selectedDay = parseInt(selectedDate.day, 10);
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
// 获取当前日期
const now = new Date();
const currentMonth = now.getMonth() + 1;
const currentDay = now.getDate();
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
// 比较选择的日期和当前日期
if (selectedMonth < currentMonth || (selectedMonth === currentMonth && selectedDay < currentDay)) {
// 如果选择的日期比当前日期早则重置为pickertime
const now = new Date();
const month = now.getMonth() + 1; // 月份从0开始因此加1
const day = now.getDate();
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
// 格式化为 MM-DD 的字符串
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
this.time = `${month < 10 ? '0' : ''}${month}${day < 10 ? '0' : ''}${day}`;
uni.showToast({
title: '选择的日期不能小于当前日期',
icon: 'none',
duration: 2000
});
} else {
// 否则,设置为用户选择的日期
this.time = `${selectedDate.month}${selectedDate.day}`;
}
},
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
getaddress() {
this.$u.get(`app/getAddress?lon=` + this.gps.longitude + '&lat=' + this.gps.latitude).then((res) => {
if (res.code == 200) {
this.addressInfo = res.data;
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
});
},
getCity() {
this.$u.get(`app/getCity?lon=` + this.gps.longitude + '&lat=' + this.gps.latitude).then((res) => {
if (res.code == 200) {
this.cityInfo = res.data;
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
// 假设 cityList 是一个包含城市信息的数组,并且 cityInfo 中有一个唯一标识字段,例如 cityName 或 cityId
const index = this.cityList.findIndex(city => city.cityName === this.cityInfo.cityName);
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
if (index !== -1) {
this.cityIndex = index
console.log('City found at index:', index);
// 可以在这里对找到的索引进行其他处理
} else {
console.log('City not found in the list');
}
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
}
});
},
showCity() {
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
},
getdata() {
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
this.$u.get("/app/getDictData?dictType=rl_rental_period").then((res) => {
if (res.code == 200) {
this.dataList = res.data
2024-09-30 18:02:38 +08:00
this.dataInfo = this.dataList[0]
2024-09-25 18:03:49 +08:00
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
}
});
},
getcityList() {
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
this.$u.get("app/city/list").then((res) => {
if (res.code == 200) {
this.cityList = res.data
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
}
});
},
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
tosele() {
uni.navigateTo({
url: '/page_user/carSelection'
})
},
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
}
}
</script>
<style lang="scss">
page {
background-color: #F7F7F7;
}
.page {
width: 100%;
.cont {
position: relative;
.choosedata {
padding: 46rpx 37rpx;
position: fixed;
bottom: 0;
width: 750rpx;
// height: 757rpx;
background: #FFFFFF;
border-radius: 20rpx 20rpx 0 0;
z-index: 101;
.tit {
margin-bottom: 54rpx;
position: relative;
width: 100%;
text-align: center;
font-weight: 600;
font-size: 40rpx;
color: #3D3D3D;
image {
position: absolute;
right: 36rpx;
width: 52rpx;
height: 52rpx;
}
}
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
.li {
margin-bottom: 24rpx;
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: center;
width: 676rpx;
height: 88rpx;
background: #F7F7F7;
border-radius: 14rpx 14rpx 14rpx 14rpx;
border: 2rpx solid #fff;
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
}
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
.act {
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
background: #DCEDFF;
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
border: 2rpx solid #4297F3;
}
}
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
.ips_box {
padding: 22rpx 38rpx;
width: 750rpx;
background: #FFFFFF;
border-radius: 0rpx 0rpx 0rpx 0rpx;
.ipt {
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: space-between;
padding: 20rpx 30rpx;
width: 100%;
background: #EFEFEF;
border-radius: 39rpx 39rpx 39rpx 39rpx;
.left {
display: flex;
flex-wrap: nowrap;
align-items: center;
.txt {
font-weight: 400;
font-size: 24rpx;
color: #6F6F6F;
}
2024-09-30 18:02:38 +08:00
.txt1 {
2024-09-25 18:03:49 +08:00
font-weight: 400;
font-size: 24rpx;
color: #6F6F6F;
width: 252rpx;
/* 设置宽度 */
white-space: nowrap;
/* 禁止文本换行 */
overflow: hidden;
/* 超出部分隐藏 */
text-overflow: ellipsis;
/* 超出部分显示省略号 */
}
2024-09-19 17:33:39 +08:00
}
.right {
width: 32rpx;
height: 32rpx;
image {
width: 32rpx;
height: 32rpx;
}
}
}
}
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
.car_card {
margin: 0 auto;
margin-top: 16rpx;
padding: 28rpx 34rpx;
width: 676rpx;
background: #FFFFFF;
border-radius: 20rpx 20rpx 20rpx 20rpx;
.car_info {
margin-top: 44rpx;
display: flex;
flex-wrap: nowrap;
.car_img {
image {
width: 166rpx;
height: 128rpx;
}
}
.info {
.modle {
font-weight: 600;
font-size: 28rpx;
color: #3D3D3D;
}
.price {
margin-top: 44rpx;
font-weight: 400;
font-size: 24rpx;
color: #FF1C1C;
span {
font-weight: 500;
font-size: 44rpx;
}
}
}
}
.card_top {
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: space-between;
.tit {
font-weight: 600;
font-size: 32rpx;
color: #3D3D3D;
}
.txt {
display: flex;
flex-wrap: nowrap;
align-items: center;
font-weight: 400;
font-size: 24rpx;
color: #3D3D3D;
}
}
.type_box {
margin-top: 8rpx;
display: flex;
flex-wrap: nowrap;
align-items: center;
.type {
padding: 2rpx 12rpx;
font-weight: 400;
font-size: 24rpx;
color: #0D75E5;
background: #DCEDFF;
border-radius: 4rpx 4rpx 4rpx 4rpx;
}
.address {
margin-left: 20rpx;
font-weight: 400;
font-size: 28rpx;
color: #808080;
}
}
}
.kefu {
position: fixed;
right: 0;
bottom: 500rpx;
width: 94rpx;
height: 94rpx;
}
.backimg {
// position: fixed;
width: 750rpx;
height: 464rpx;
z-index: -10;
background-image: url('https://lxnapi.ccttiot.com/bike/img/static/uNurSfSfybEGAJYfXD07');
background-size: cover;
/* 背景图片等比缩放以覆盖整个容器 */
background-position: center;
}
.choose_card {
position: absolute;
top: 0;
padding-bottom: 28rpx;
width: 750rpx;
// height: 511rpx;
background: #FFFFFF;
border-radius: 0rpx 0rpx 20rpx 20rpx;
z-index: 100;
.check {
margin-bottom: 40rpx;
display: flex;
flex-wrap: nowrap;
align-items: center;
width: 676rpx;
height: 96rpx;
background-image: url('https://lxnapi.ccttiot.com/bike/img/static/u5r7QJyFfPruTi4VsXzV');
background-size: cover;
/* 背景图片等比缩放以覆盖整个容器 */
background-position: center;
.txt1 {
width: 50%;
text-align: center;
font-weight: 600;
font-size: 40rpx;
color: #3D3D3D;
}
.txt2 {
width: 50%;
text-align: center;
font-weight: 600;
font-size: 36rpx;
color: #808080;
}
}
.btn_li {
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: center;
margin-top: 20rpx;
.btns {
display: flex;
align-items: center;
justify-content: center;
width: 238rpx;
height: 80rpx;
font-weight: 500;
font-size: 36rpx;
color: #6DB3FF;
border-radius: 16rpx 16rpx 16rpx 16rpx;
border: 2rpx solid #6DB3FF;
}
.btn {
display: flex;
align-items: center;
justify-content: center;
width: 406rpx;
height: 80rpx;
background: #6DB3FF;
border-radius: 16rpx 16rpx 16rpx 16rpx;
//
margin-left: 14rpx;
font-weight: 500;
font-size: 36rpx;
color: #FFFFFF;
border: 2rpx solid #fff;
}
}
.time_box {
margin: 0 auto;
padding: 22rpx 24rpx 28rpx 24rpx;
display: flex;
flex-wrap: nowrap;
width: 658rpx;
// height: 128rpx;
background: #EEEEEE;
border-radius: 20rpx 20rpx 20rpx 20rpx;
.time_li {
width: 50%;
.txt {
font-weight: 400;
font-size: 24rpx;
color: #808080;
}
.words {
margin-top: 6rpx;
font-weight: 600;
font-size: 32rpx;
color: #3D3D3D;
image {
width: 40rpx;
height: 22rpx;
}
}
}
}
.area_li {
display: flex;
flex-wrap: nowrap;
align-items: flex-start;
padding: 20rpx 46rpx 28rpx 46rpx;
.dingw {
display: flex;
align-items: center;
margin-left: 30rpx;
margin-top: 46rpx;
font-weight: 400;
font-size: 28rpx;
color: #808080;
image {
margin-left: 8rpx;
width: 30rpx;
height: 30rpx;
}
}
.city {
.txt {
font-weight: 400;
font-size: 24rpx;
color: #808080;
}
.words {
margin-top: 6rpx;
font-weight: 600;
font-size: 32rpx;
color: #3D3D3D;
image {
width: 40rpx;
height: 22rpx;
}
}
}
.area {
margin-left: 20rpx;
.top {
display: flex;
flex-wrap: nowrap;
align-items: center;
.txt {
font-weight: 400;
font-size: 24rpx;
color: #808080;
}
.type {
margin-left: 10rpx;
background: #FFE9D4;
border-radius: 4rpx 4rpx 4rpx 4rpx;
padding: 2rpx 6rpx;
font-weight: 400;
font-size: 22rpx;
color: #FF8C1E;
}
}
.bot {
2024-09-25 18:03:49 +08:00
display: flex;
flex-wrap: nowrap;
align-items: center;
2024-09-19 17:33:39 +08:00
margin-top: 6rpx;
2024-09-30 18:02:38 +08:00
2024-09-25 18:03:49 +08:00
.txt3 {
font-weight: 600;
font-size: 32rpx;
color: #3D3D3D;
width: 252rpx;
/* 设置宽度 */
white-space: nowrap;
/* 禁止文本换行 */
overflow: hidden;
/* 超出部分隐藏 */
text-overflow: ellipsis;
/* 超出部分显示省略号 */
}
2024-09-30 18:02:38 +08:00
2024-09-19 17:33:39 +08:00
image {
width: 40rpx;
height: 22rpx;
}
}
}
}
}
}
}
</style>