You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
198 lines
3.8 KiB
198 lines
3.8 KiB
<template>
|
|
<uni-popup ref="popup" type="bottom">
|
|
<view class="wrap">
|
|
<view class="s-header center">
|
|
<text class="btn" @click="close">取消</text>
|
|
<text>请选择优惠券</text>
|
|
<text class="btn" @click="confirm">确定</text>
|
|
</view>
|
|
<scroll-view class="scroll-view" scroll-y="true">
|
|
<view class="coupon-item" v-for="(item,index) in list" :key="index" @click="checkCoupon(item)">
|
|
<view class="con">
|
|
<view class="left">
|
|
<text class="title clamp">{{item.title}}</text>
|
|
<text class="time">有效期至 {{ item.end_time | date('Y-m-d H:i') }}</text>
|
|
</view>
|
|
<view class="right">
|
|
<text class="price">{{item.coupon_money}}</text>
|
|
<text>满{{ item.total_money }}可用</text>
|
|
</view>
|
|
|
|
<view class="circle l"></view>
|
|
<view class="circle r"></view>
|
|
</view>
|
|
<view class="bot row">
|
|
<text class="tips">平台所有商品可用</text>
|
|
<text v-if="curCoupon._id === item._id" class="mix-icon icon-xuanzhong"></text>
|
|
</view>
|
|
</view>
|
|
</scroll-view>
|
|
</view>
|
|
</uni-popup>
|
|
</template>
|
|
|
|
<script>
|
|
/**
|
|
* 优惠券选择弹窗
|
|
* @prop {Array} list 用户可用优惠券列表
|
|
*/
|
|
export default {
|
|
data() {
|
|
return {
|
|
curCoupon: {}
|
|
}
|
|
},
|
|
props: {
|
|
list: {
|
|
type: Array,
|
|
default(){
|
|
return []
|
|
}
|
|
}
|
|
},
|
|
methods: {
|
|
//确定选择
|
|
confirm(){
|
|
this.$emit('confirm', this.curCoupon);
|
|
this.close();
|
|
},
|
|
//选择优惠券
|
|
checkCoupon(item){
|
|
if(this.curCoupon._id === item._id){
|
|
this.curCoupon = {};
|
|
}else{
|
|
this.curCoupon = item;
|
|
}
|
|
},
|
|
open(type){
|
|
this.$refs.popup.open();
|
|
},
|
|
close(){
|
|
this.$refs.popup.close();
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped lang="scss">
|
|
.wrap{
|
|
padding-bottom: 10rpx;
|
|
border-radius: 16rpx 16rpx 0 0;
|
|
background-color: #f7f7f7;
|
|
}
|
|
.s-header{
|
|
justify-content: space-between;
|
|
padding: 30rpx 0 14rpx;
|
|
font-size: 32rpx;
|
|
color: #333;
|
|
font-weight: 700;
|
|
|
|
.btn{
|
|
padding: 10rpx 36rpx;
|
|
font-size: 28rpx;
|
|
color: #666;
|
|
font-weight: normal;
|
|
|
|
&:last-child{
|
|
color: $base-color;
|
|
}
|
|
}
|
|
}
|
|
.scroll-view{
|
|
min-height: 50vh;
|
|
max-height: 70vh;
|
|
}
|
|
.coupon-item{
|
|
display: flex;
|
|
flex-direction: column;
|
|
margin: 20rpx 24rpx;
|
|
background: #fff;
|
|
|
|
.con{
|
|
display: flex;
|
|
align-items: center;
|
|
position: relative;
|
|
height: 140rpx;
|
|
padding: 0 30rpx;
|
|
|
|
&:after{
|
|
position: absolute;
|
|
left: 0;
|
|
bottom: 0;
|
|
content: '';
|
|
width: 100%;
|
|
height: 0;
|
|
border-bottom: 1px dashed #e5e5e5;
|
|
transform: scaleY(50%);
|
|
}
|
|
}
|
|
.left{
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
flex: 1;
|
|
overflow: hidden;
|
|
height: 100rpx;
|
|
}
|
|
.title{
|
|
font-size: 32rpx;
|
|
color: #333;
|
|
margin-bottom: 24rpx;
|
|
}
|
|
.time{
|
|
font-size: 24rpx;
|
|
color: #999;
|
|
}
|
|
.right{
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
align-items: center;
|
|
margin-left: 30rpx;
|
|
font-size: 24rpx;
|
|
color: #666;
|
|
height: 100rpx;
|
|
}
|
|
.price{
|
|
margin-bottom: 14rpx;
|
|
font-size: 50rpx;
|
|
color: $base-color;
|
|
font-weight: 700;
|
|
|
|
&:before{
|
|
content: '¥';
|
|
font-size: 34rpx;
|
|
}
|
|
}
|
|
.bot{
|
|
height: 72rpx;
|
|
padding: 0 28rpx 0 30rpx;
|
|
|
|
.tips{
|
|
flex: 1;
|
|
font-size: 24rpx;
|
|
color: #999;
|
|
}
|
|
.icon-xuanzhong{
|
|
font-size: 36rpx;
|
|
color: $base-color;
|
|
}
|
|
}
|
|
|
|
.circle{
|
|
position: absolute;
|
|
left: -6rpx;
|
|
bottom: -10rpx;
|
|
z-index: 10;
|
|
width: 20rpx;
|
|
height: 20rpx;
|
|
background: #f3f3f3;
|
|
border-radius: 100px;
|
|
|
|
&.r{
|
|
left: auto;
|
|
right: -6rpx;
|
|
}
|
|
}
|
|
}
|
|
</style>
|