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.
783 lines
19 KiB
783 lines
19 KiB
3 months ago
|
<template>
|
||
|
<view :style="[newVipWrapStyle]" v-if="couponList.length || productList.length || newcomer_integral">
|
||
|
<view class="newVip2" :style="[newVip2Background,newVipBorderRadius]" v-if="dataConfig.styleConfig.tabVal">
|
||
|
<view class="header acea-row row-between row-middle">
|
||
|
<view class="title-box acea-row row-middle">
|
||
|
<image :src="`${imgHost}/statics/images/newVip1.png`" class="image"></image>
|
||
|
<view class="info">超值优惠 限时专享</view>
|
||
|
</view>
|
||
|
<view class="more" @click="goNewList">去逛逛<text class="iconfont icon-ic_rightarrow"></text></view>
|
||
|
</view>
|
||
|
<view class="wrapper">
|
||
|
<view class="coupon" v-if="couponList.length && dataConfig.checkboxInfo.type.includes(1)">
|
||
|
<view class="title">新人红包</view>
|
||
|
<view class="content">
|
||
|
<scroll-view scroll-x="true">
|
||
|
<view class="list acea-row">
|
||
|
<view v-for="item in couponList" class="item">
|
||
|
<view class="back" :style="[couponStyle]"></view>
|
||
|
<view class="money" :style="[moneyStyle]">
|
||
|
<view v-if="item.coupon_type == 1">¥<text class="number">{{ item.coupon_price }}</text></view>
|
||
|
<view v-else-if="item.coupon_type == 2"><text class="number">{{ parseFloat(item.coupon_price)/10 }}</text>折</view>
|
||
|
</view>
|
||
|
<view v-if="item.use_min_price" class="info" :style="[couponInfoStyle]">满{{ item.use_min_price }}可用</view>
|
||
|
<view v-else class="info" :style="[couponInfoStyle]">无门槛券</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="product" v-if="productList.length && dataConfig.checkboxInfo.type.includes(2)">
|
||
|
<view class="title">新人商品专区</view>
|
||
|
<view class="content">
|
||
|
<scroll-view scroll-x="true">
|
||
|
<view class="list acea-row">
|
||
|
<view class="item" v-for="(item,index) in productList" :key="item.id" @click="goDetail(item)">
|
||
|
<easy-loadimage mode="widthFix" :image-src="item.image" width="144rpx" height="144rpx" borderRadius="12rpx"></easy-loadimage>
|
||
|
<view class="money">¥<text class="number">{{ item.price }}</text></view>
|
||
|
<view class="name line1">{{ item.store_name }}</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="bonus acea-row row-middle" v-if="dataConfig.checkboxInfo.type.includes(0)">
|
||
|
<image :src="`${imgHost}/statics/images/newVip2.png`" class="image"></image>
|
||
|
<view class="text">
|
||
|
<view class="info acea-row row-middle">
|
||
|
新用户注册领积分
|
||
|
<view class="red" :style="[bonusRedStyle]">
|
||
|
<view class="inner acea-row row-middle">
|
||
|
<image :src="`${imgHost}/statics/images/newVip3.png`" class="image"></image>
|
||
|
+{{ newcomer_integral }}
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="">新用户注册后即可获得积分</view>
|
||
|
</view>
|
||
|
<view class="button" :style="[buttonStyle]" @click="goNewList">去看看</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="newVip" v-else>
|
||
|
<view class="header acea-row row-between row-middle">
|
||
|
<view class="title">新人专享福利</view>
|
||
|
<view class="more" @click="goNewList">更多优惠<text class="iconfont icon-ic_rightarrow"></text></view>
|
||
|
</view>
|
||
|
<view class="bonus" :style="[bonusStyle]" v-if="dataConfig.checkboxInfo.type.includes(0)">
|
||
|
<view class="inner acea-row row-middle">
|
||
|
<image :src="`${imgHost}/statics/images/newVip3.png`" class="image"></image>
|
||
|
新用户注册即可
|
||
|
<text class="red" :style="[bonusRedStyle]">赠送积分</text>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="coupon" v-if="dataConfig.checkboxInfo.type.includes(1) && couponList.length">
|
||
|
<view class="title">专属优惠券</view>
|
||
|
<view class="content acea-row" :style="[couponContentStyle]">
|
||
|
<scroll-view scroll-x="true">
|
||
|
<view class="list acea-row">
|
||
|
<view v-for="item in couponList" :key="item.id" class="item" :style="[couponStyle]">
|
||
|
<view class="item-top acea-row row-center row-middle">
|
||
|
<view class="money" :style="[moneyStyle]">
|
||
|
<view v-if="item.coupon_type == 1">¥<text class="number">{{ item.coupon_price }}</text></view>
|
||
|
<view v-else-if="item.coupon_type == 2"><text class="number">{{ parseFloat(item.coupon_price)/10 }}</text>折</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="item-bottom acea-row row-column row-center row-middle">
|
||
|
<view class="name" :style="[couponTypeStyle]">
|
||
|
<text v-if="item.coupon_type == 1">品类券</text>
|
||
|
<text v-else-if="item.coupon_type == 2">商品券</text>
|
||
|
<text v-else-if="item.coupon_type == 3">品牌券</text>
|
||
|
<text v-else>通用券</text>
|
||
|
</view>
|
||
|
<view v-if="item.use_min_price" class="info">满{{ item.use_min_price }}可用</view>
|
||
|
<view v-else class="info">无门槛券</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
<view class="station" :style="[stationStyle]">
|
||
|
<view class="money">¥<text class="number">{{ totalPrice }}</text></view>
|
||
|
<view class="info">新人专享优惠券</view>
|
||
|
<view class="button" :style="[buttonStyle]" @click="goUser">一键领取</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="product" v-if="productList.length && dataConfig.checkboxInfo.type.includes(2)">
|
||
|
<view class="title">新人商品专区</view>
|
||
|
<view class="content">
|
||
|
<scroll-view scroll-x="true">
|
||
|
<view class="list acea-row">
|
||
|
<view class="item" v-for="(item,index) in productList" :key="item.id" @click="goDetail(item)">
|
||
|
<easy-loadimage mode="widthFix" :image-src="item.image" width="158rpx" height="158rpx" borderRadius="12rpx"></easy-loadimage>
|
||
|
<view class="name line1">{{ item.store_name }}</view>
|
||
|
<view class="money" :style="[productMoneyStyle]">¥<text class="number">{{ item.price }}</text></view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import {
|
||
|
newcomerList
|
||
|
} from '@/api/api.js';
|
||
|
import {
|
||
|
mapGetters
|
||
|
} from 'vuex';
|
||
|
import {
|
||
|
HTTP_REQUEST_URL
|
||
|
} from '@/config/app';
|
||
|
export default {
|
||
|
computed: mapGetters(['isLogin']),
|
||
|
props: {
|
||
|
dataConfig: {
|
||
|
type: Object,
|
||
|
default: () => {}
|
||
|
},
|
||
|
isSortType: {
|
||
|
type: String | Number,
|
||
|
default: 0
|
||
|
}
|
||
|
},
|
||
|
data() {
|
||
|
return {
|
||
|
imgHost: HTTP_REQUEST_URL,
|
||
|
couponList: [],
|
||
|
productList: [],
|
||
|
newcomer_integral: '',
|
||
|
}
|
||
|
},
|
||
|
created() {
|
||
|
this.getList();
|
||
|
},
|
||
|
computed: {
|
||
|
totalPrice() {
|
||
|
return this.couponList.reduce((total, item) => {
|
||
|
return this.$util.$h.Add(total, item.coupon_price);
|
||
|
}, 0);
|
||
|
},
|
||
|
bonusStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneConfig.tabVal) {
|
||
|
styleObject['border-color'] = this.dataConfig.integralBgColor.color[0].item;
|
||
|
styleObject['background'] = this.dataConfig.integralBgColor.color[0].item;
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
bonusRedStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneConfig.tabVal) {
|
||
|
if (this.dataConfig.styleConfig.tabVal) {
|
||
|
styleObject['background'] = this.dataConfig.integralTxtColor.color[0].item;
|
||
|
styleObject['color'] = this.dataConfig.integralTxtColor.color[0].item;
|
||
|
} else {
|
||
|
styleObject['color'] = this.dataConfig.tipsColor.color[0].item;
|
||
|
}
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
moneyStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneCouponConfig.tabVal) {
|
||
|
styleObject['color'] = this.dataConfig.couponMoneyColor.color[0].item;
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
buttonStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneConfig.tabVal) {
|
||
|
if (this.dataConfig.styleConfig.tabVal) {
|
||
|
styleObject['background'] = `linear-gradient(90deg, ${this.dataConfig.bntColor.color[0].item} 0%, ${this.dataConfig.bntColor.color[1].item} 100%)`;
|
||
|
}
|
||
|
}
|
||
|
if (this.dataConfig.toneCouponConfig.tabVal) {
|
||
|
if (!this.dataConfig.styleConfig.tabVal) {
|
||
|
styleObject['color'] = this.dataConfig.bntTxtColor.color[0].item;
|
||
|
}
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
couponTypeStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneCouponConfig.tabVal) {
|
||
|
styleObject['color'] = this.dataConfig.couponTypeColor.color[0].item;
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
couponStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneCouponConfig.tabVal) {
|
||
|
if (this.dataConfig.styleConfig.tabVal) {
|
||
|
styleObject['margin-right'] = `${this.dataConfig.spacingConfig2.val * 2}rpx`;
|
||
|
styleObject['background'] = this.dataConfig.couponBgColor2.color[0].item;
|
||
|
} else {
|
||
|
styleObject['margin-right'] = `${this.dataConfig.spacingConfig.val * 2}rpx`;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
couponContentStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneCouponConfig.tabVal) {
|
||
|
styleObject['background'] = `linear-gradient(90deg, ${this.dataConfig.couponBgColor.color[0].item} 0%, ${this.dataConfig.couponBgColor.color[1].item} 100%)`;
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
stationStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneCouponConfig.tabVal) {
|
||
|
styleObject['background'] = `linear-gradient(90deg, ${this.dataConfig.vipBgColor.color[0].item} 0%, ${this.dataConfig.vipBgColor.color[1].item} 100%)`;
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
productMoneyStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneGoodsConfig.tabVal) {
|
||
|
styleObject['color'] = this.dataConfig.priceColor.color[0].item;
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
couponInfoStyle() {
|
||
|
let styleObject = {};
|
||
|
if (this.dataConfig.toneCouponConfig.tabVal) {
|
||
|
styleObject['background'] = `linear-gradient(90deg, ${this.dataConfig.bntBgColor.color[1].item} 0%, ${this.dataConfig.bntBgColor.color[0].item} 100%)`;
|
||
|
}
|
||
|
return styleObject;
|
||
|
},
|
||
|
// 组件背景
|
||
|
newVip2Background() {
|
||
|
return {
|
||
|
'background': `linear-gradient(90deg, ${this.dataConfig.moduleColor.color[0].item} 0%, ${this.dataConfig.moduleColor.color[1].item} 99%)`,
|
||
|
};
|
||
|
},
|
||
|
// 背景圆角
|
||
|
newVipBorderRadius() {
|
||
|
let borderRadius = `${this.dataConfig.fillet.val * 2}rpx`;
|
||
|
if (this.dataConfig.fillet.type) {
|
||
|
borderRadius =
|
||
|
`${this.dataConfig.fillet.valList[0].val * 2}rpx ${this.dataConfig.fillet.valList[1].val * 2}rpx ${this.dataConfig.fillet.valList[2].val * 2}rpx ${this.dataConfig.fillet.valList[3].val * 2}rpx`;
|
||
|
}
|
||
|
return {
|
||
|
'border-radius': borderRadius,
|
||
|
};
|
||
|
},
|
||
|
// 底部背景
|
||
|
newVipWrapStyle() {
|
||
|
return {
|
||
|
'padding': `${this.dataConfig.topConfig.val * 2}rpx ${this.dataConfig.prConfig.val * 2}rpx ${this.dataConfig.bottomConfig.val * 2}rpx`,
|
||
|
'margin-top': `${this.dataConfig.mbConfig.val * 2}rpx`,
|
||
|
'background': this.dataConfig.bottomBgColor.color[0].item,
|
||
|
};
|
||
|
},
|
||
|
},
|
||
|
watch: {
|
||
|
isLogin: {
|
||
|
handler: function(newV, oldV) {
|
||
|
if (newV) {
|
||
|
this.getList();
|
||
|
}
|
||
|
},
|
||
|
deep: true
|
||
|
}
|
||
|
},
|
||
|
methods: {
|
||
|
goDetail(item) {
|
||
|
uni.navigateTo({
|
||
|
url: `/pages/activity/goods_details/index?id=${item.id}&type=7`
|
||
|
});
|
||
|
},
|
||
|
goNewList() {
|
||
|
uni.navigateTo({
|
||
|
url: `/pages/activity/new_customer/index`
|
||
|
});
|
||
|
},
|
||
|
goUser() {
|
||
|
uni.switchTab({
|
||
|
url: `/pages/users/user_coupon/index`
|
||
|
});
|
||
|
},
|
||
|
getList() {
|
||
|
let limit = this.$config.LIMIT;
|
||
|
newcomerList({
|
||
|
page: 1,
|
||
|
limit: limit,
|
||
|
}).then(res => {
|
||
|
let newcomer_integral = res.data.newcomer_integral;
|
||
|
this.couponList = res.data.newcomer_coupon;
|
||
|
this.productList = res.data.newcomer_products;
|
||
|
if (Array.isArray(newcomer_integral)) {
|
||
|
this.newcomer_integral = 0;
|
||
|
} else {
|
||
|
this.newcomer_integral = newcomer_integral;
|
||
|
}
|
||
|
}).catch(err => {
|
||
|
return this.$util.Tips({
|
||
|
title: err.msg
|
||
|
});
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style lang="scss">
|
||
|
.newVip {
|
||
|
padding: 0 20rpx 40rpx;
|
||
|
border-radius: 16rpx;
|
||
|
background: #FFFFFF;
|
||
|
|
||
|
.header {
|
||
|
height: 96rpx;
|
||
|
|
||
|
.title {
|
||
|
font-weight: bold;
|
||
|
font-size: 32rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.more {
|
||
|
font-size: 24rpx;
|
||
|
color: #999999;
|
||
|
}
|
||
|
|
||
|
.iconfont {
|
||
|
font-size: 24rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.bonus {
|
||
|
border: 1rpx solid var(--view-theme);
|
||
|
border-radius: 17rpx;
|
||
|
background: var(--view-theme);
|
||
|
|
||
|
.inner {
|
||
|
height: 80rpx;
|
||
|
padding: 0 32rpx;
|
||
|
border-radius: 16rpx;
|
||
|
background: rgba(255, 255, 255, 0.8);
|
||
|
font-size: 26rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.image {
|
||
|
width: 48rpx;
|
||
|
height: 48rpx;
|
||
|
margin-right: 16rpx;
|
||
|
}
|
||
|
|
||
|
.red {
|
||
|
color: var(--view-theme);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.coupon {
|
||
|
.title {
|
||
|
padding: 28rpx 0 20rpx;
|
||
|
font-weight: bold;
|
||
|
font-size: 28rpx;
|
||
|
line-height: 40rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.content {
|
||
|
position: relative;
|
||
|
padding: 12rpx 190rpx 12rpx 12rpx;
|
||
|
border-radius: 24rpx;
|
||
|
background: linear-gradient(270deg, var(--view-theme) 0%, var(--view-gradient) 100%);
|
||
|
}
|
||
|
|
||
|
.list {
|
||
|
flex-wrap: nowrap;
|
||
|
}
|
||
|
|
||
|
.item {
|
||
|
flex-shrink: 0;
|
||
|
position: relative;
|
||
|
width: 144rpx;
|
||
|
height: 188rpx;
|
||
|
border-radius: 12rpx;
|
||
|
margin-top: 0;
|
||
|
margin-right: 8rpx;
|
||
|
background: radial-gradient(circle at left 94rpx, transparent 6rpx, #FFFFFF 0) top left,
|
||
|
radial-gradient(circle at right 94rpx, transparent 6rpx, #FFFFFF 0) top right;
|
||
|
background-repeat: no-repeat;
|
||
|
background-size: 72rpx 188rpx;
|
||
|
|
||
|
&::before {
|
||
|
content: "";
|
||
|
position: absolute;
|
||
|
top: 94rpx;
|
||
|
right: 10rpx;
|
||
|
left: 10rpx;
|
||
|
border-top: 1rpx dashed #D8D8D8;
|
||
|
}
|
||
|
|
||
|
.item-top,
|
||
|
.item-bottom {
|
||
|
height: 94rpx;
|
||
|
}
|
||
|
|
||
|
.money {
|
||
|
font-weight: 500;
|
||
|
font-size: 28rpx;
|
||
|
color: var(--view-theme);
|
||
|
}
|
||
|
|
||
|
.number {
|
||
|
font-family: SemiBold;
|
||
|
font-size: 40rpx;
|
||
|
}
|
||
|
|
||
|
.name {
|
||
|
font-weight: 500;
|
||
|
font-size: 22rpx;
|
||
|
line-height: 30rpx;
|
||
|
color: var(--view-theme);
|
||
|
}
|
||
|
|
||
|
.info {
|
||
|
margin-top: 4rpx;
|
||
|
font-size: 18rpx;
|
||
|
line-height: 26rpx;
|
||
|
color: #666666;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.station {
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
right: 0;
|
||
|
width: 190rpx;
|
||
|
height: 100%;
|
||
|
padding-top: 40rpx;
|
||
|
border-radius: 0 24rpx 24rpx 0;
|
||
|
background: linear-gradient(270deg, var(--view-theme) 0%, var(--view-gradient) 100%);
|
||
|
|
||
|
&::before {
|
||
|
content: "";
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
left: -20rpx;
|
||
|
width: 20rpx;
|
||
|
height: 210rpx;
|
||
|
background: linear-gradient(270deg, rgba(0, 0, 0, 0.2) 0%, rgba(255, 255, 255, 0) 100%);
|
||
|
}
|
||
|
|
||
|
.money {
|
||
|
text-align: center;
|
||
|
font-weight: 500;
|
||
|
font-size: 28rpx;
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
|
||
|
.number {
|
||
|
font-family: SemiBold;
|
||
|
font-size: 40rpx;
|
||
|
}
|
||
|
|
||
|
.info {
|
||
|
margin-top: 18rpx;
|
||
|
text-align: center;
|
||
|
font-size: 20rpx;
|
||
|
line-height: 28rpx;
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
|
||
|
.button {
|
||
|
width: 136rpx;
|
||
|
height: 52rpx;
|
||
|
border-radius: 26rpx;
|
||
|
margin: 12rpx auto 0;
|
||
|
background: #FFFFFF;
|
||
|
text-align: center;
|
||
|
font-weight: 500;
|
||
|
font-size: 22rpx;
|
||
|
line-height: 52rpx;
|
||
|
color: var(--view-theme);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.product {
|
||
|
.title {
|
||
|
padding: 28rpx 0 20rpx;
|
||
|
font-weight: bold;
|
||
|
font-size: 28rpx;
|
||
|
line-height: 40rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.list {
|
||
|
flex-wrap: nowrap;
|
||
|
}
|
||
|
|
||
|
.item {
|
||
|
width: 158rpx;
|
||
|
margin-top: 0;
|
||
|
margin-right: 12rpx;
|
||
|
}
|
||
|
|
||
|
.name {
|
||
|
margin-top: 12rpx;
|
||
|
text-align: center;
|
||
|
font-size: 24rpx;
|
||
|
line-height: 34rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.money {
|
||
|
margin-top: 8rpx;
|
||
|
text-align: center;
|
||
|
font-weight: 600;
|
||
|
font-size: 22rpx;
|
||
|
color: var(--view-theme);
|
||
|
}
|
||
|
|
||
|
.number {
|
||
|
font-family: SemiBold;
|
||
|
font-size: 32rpx;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.newVip2 {
|
||
|
padding: 0 24rpx 32rpx;
|
||
|
border-radius: 24rpx;
|
||
|
background: linear-gradient(270deg, #FF7931 0%, #E93323 100%);
|
||
|
|
||
|
.header {
|
||
|
height: 92rpx;
|
||
|
|
||
|
.info {
|
||
|
position: relative;
|
||
|
padding-left: 12rpx;
|
||
|
margin-left: 16rpx;
|
||
|
font-size: 24rpx;
|
||
|
color: #FFFFFF;
|
||
|
|
||
|
&::before {
|
||
|
content: "";
|
||
|
position: absolute;
|
||
|
top: 50%;
|
||
|
left: 0;
|
||
|
width: 1rpx;
|
||
|
height: 20rpx;
|
||
|
background-color: #FFFFFF;
|
||
|
transform: translateY(-50%);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.more {
|
||
|
font-size: 24rpx;
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
|
||
|
.iconfont {
|
||
|
font-size: 24rpx;
|
||
|
}
|
||
|
|
||
|
.image {
|
||
|
width: 156rpx;
|
||
|
height: 28rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.wrapper {
|
||
|
border-radius: 16rpx;
|
||
|
background: #FFFFFF;
|
||
|
}
|
||
|
|
||
|
.coupon {
|
||
|
padding-bottom: 20rpx;
|
||
|
.title {
|
||
|
padding: 24rpx 20rpx 20rpx;
|
||
|
font-weight: bold;
|
||
|
font-size: 28rpx;
|
||
|
line-height: 40rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.list {
|
||
|
flex-wrap: nowrap;
|
||
|
padding-left: 20rpx;
|
||
|
}
|
||
|
|
||
|
.item {
|
||
|
flex-shrink: 0;
|
||
|
position: relative;
|
||
|
width: 152rpx;
|
||
|
height: 168rpx;
|
||
|
margin-top: 0;
|
||
|
margin-right: 24rpx;
|
||
|
}
|
||
|
|
||
|
.back {
|
||
|
position: absolute;
|
||
|
bottom: 0;
|
||
|
left: 0;
|
||
|
width: 152rpx;
|
||
|
height: 148rpx;
|
||
|
border-radius: 20rpx;
|
||
|
background: var(--view-theme);
|
||
|
}
|
||
|
|
||
|
.money {
|
||
|
position: absolute;
|
||
|
bottom: 12rpx;
|
||
|
left: 6rpx;
|
||
|
width: 140rpx;
|
||
|
height: 156rpx;
|
||
|
padding-top: 36rpx;
|
||
|
border: 2rpx solid #FCEAE9;
|
||
|
border-radius: 20rpx;
|
||
|
background: #FFFFFF;
|
||
|
text-align: center;
|
||
|
font-weight: 500;
|
||
|
font-size: 28rpx;
|
||
|
color: var(--view-theme);
|
||
|
|
||
|
.number {
|
||
|
font-family: SemiBold;
|
||
|
font-size: 40rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.info {
|
||
|
position: absolute;
|
||
|
bottom: 0;
|
||
|
left: 0;
|
||
|
width: 152rpx;
|
||
|
height: 78rpx;
|
||
|
padding-top: 34rpx;
|
||
|
border-radius: 0 0 20rpx 20rpx;
|
||
|
background: linear-gradient(90deg, var(--view-theme) 0%, var(--view-gradient) 100%);
|
||
|
text-align: center;
|
||
|
font-size: 20rpx;
|
||
|
line-height: 28rpx;
|
||
|
color: #FFFFFF;
|
||
|
|
||
|
&::before {
|
||
|
content: "";
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
left: 0;
|
||
|
width: 152rpx;
|
||
|
height: 20rpx;
|
||
|
border: 8rpx solid #FCEAE9;
|
||
|
border-bottom-right-radius: 76rpx 20rpx;
|
||
|
border-bottom-left-radius: 76rpx 20rpx;
|
||
|
border-top-color: transparent;
|
||
|
box-sizing: border-box;
|
||
|
background: #FFFFFF;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.product {
|
||
|
padding-bottom: 20rpx;
|
||
|
.title {
|
||
|
padding: 20rpx 20rpx 20rpx;
|
||
|
font-weight: bold;
|
||
|
font-size: 28rpx;
|
||
|
line-height: 40rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.list {
|
||
|
padding: 0 20rpx;
|
||
|
}
|
||
|
|
||
|
.item {
|
||
|
width: 144rpx;
|
||
|
margin-top: 0;
|
||
|
margin-right: 15rpx;
|
||
|
}
|
||
|
|
||
|
.money {
|
||
|
margin-top: 18rpx;
|
||
|
text-align: center;
|
||
|
font-weight: 500;
|
||
|
font-size: 32rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.number {
|
||
|
font-family: SemiBold;
|
||
|
}
|
||
|
|
||
|
.name {
|
||
|
margin-top: 6rpx;
|
||
|
text-align: center;
|
||
|
font-size: 24rpx;
|
||
|
line-height: 34rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.bonus {
|
||
|
padding: 26rpx 26rpx 26rpx 20rpx;
|
||
|
border-radius: 16rpx;
|
||
|
margin-top: 20rpx;
|
||
|
background: #FFFFFF;
|
||
|
|
||
|
.image {
|
||
|
width: 88rpx;
|
||
|
height: 88rpx;
|
||
|
}
|
||
|
|
||
|
.text {
|
||
|
flex: 1;
|
||
|
padding-left: 20rpx;
|
||
|
font-size: 24rpx;
|
||
|
color: #999999;
|
||
|
}
|
||
|
|
||
|
.info {
|
||
|
margin-bottom: 10rpx;
|
||
|
font-weight: bold;
|
||
|
font-size: 30rpx;
|
||
|
line-height: 42rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.red {
|
||
|
border-radius: 16rpx;
|
||
|
margin-left: 8rpx;
|
||
|
background: var(--view-theme);
|
||
|
font-weight: 400;
|
||
|
font-size: 20rpx;
|
||
|
line-height: 32rpx;
|
||
|
color: var(--view-theme);
|
||
|
|
||
|
.image {
|
||
|
width: 24rpx;
|
||
|
height: 24rpx;
|
||
|
}
|
||
|
|
||
|
.inner {
|
||
|
height: 32rpx;
|
||
|
padding: 0 7rpx;
|
||
|
border-radius: 16rpx;
|
||
|
background: rgba(255, 255, 255, 0.9);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.button {
|
||
|
width: 114rpx;
|
||
|
height: 52rpx;
|
||
|
border-radius: 26rpx;
|
||
|
background: linear-gradient(90deg, var(--view-theme) 0%, var(--view-gradient) 100%);
|
||
|
text-align: center;
|
||
|
font-weight: 500;
|
||
|
font-size: 22rpx;
|
||
|
line-height: 52rpx;
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</style>
|