dl_uniapp/pages/mine/coupon/coupon-list.vue

227 lines
5.2 KiB
Vue
Raw Normal View History

2025-04-09 16:55:06 +08:00
<template>
<view class="container-box">
<navigation-bar-vue title="通告券" style="width: 100%;" background-color="#ffffff"
title-color="#000000"></navigation-bar-vue>
<view class="content">
<view class="content-body">
<image class="huojian" src="@/static/mine/coupon/huojian.png" mode="aspectFit"></image>
<view class="coupon-box">
<view class="left-top">
<view class="left-space"></view>
<image src="@/static/mine/auth/dian.png" mode="aspectFit"></image>
<view style="padding-bottom: 20rpx;">获取更多</view>
<view class="bg-img">加速特权</view>
</view>
<view class="content-img">
</view>
<view class="bottom-content">
2025-04-11 15:35:27 +08:00
<view class="top-text">剩余<text>{{ coupon }}</text></view>
2025-04-09 16:55:06 +08:00
<view class="button-dom" @click="goMyCoupon(0)">去获取</view>
</view>
</view>
</view>
<view class="item-field" style="align-items: center;">
<view class="my-suggest-dom" @click="viewRichText()">
<text>了解通告券</text>
<uni-icons type="right" color="#363636" size="14"></uni-icons>
</view>
<view class="my-suggest-dom" @click="goMyCoupon(1)">
<text>购买记录</text>
<uni-icons type="right" color="#363636" size="14"></uni-icons>
</view>
</view>
</view>
</view>
</template>
<script>
import navigationBarVue from '@/components/navigation/navigationBar.vue';
2025-04-24 18:47:30 +08:00
import {getMemberCoupon} from '@/api/business/member.js'
2025-04-09 16:55:06 +08:00
export default {
components: {
navigationBarVue
},
data() {
return {
globalConfig: getApp().globalData.config,
2025-04-11 15:35:27 +08:00
coupon:0
2025-04-09 16:55:06 +08:00
}
},
2025-04-11 15:35:27 +08:00
onLoad(options){
2025-04-24 18:47:30 +08:00
},
onShow(){
this.initMyCoupon()
2025-04-11 15:35:27 +08:00
},
2025-04-09 16:55:06 +08:00
methods: {
2025-04-24 18:47:30 +08:00
initMyCoupon(){
getMemberCoupon().then(res=>{
this.coupon = res.data
})
},
2025-04-09 16:55:06 +08:00
viewRichText() {
this.$tab.navigateTo(
`/pages/common/richview/index?title=${this.globalConfig.appInfo.agreements[5].title}&code=${this.globalConfig.appInfo.agreements[5].code}`
)
},
goMyCoupon(index) {
this.$tab.navigateTo(
2025-04-11 15:35:27 +08:00
`/pages/mine/coupon/my-coupon?index=${index}&coupon=`+this.coupon
2025-04-09 16:55:06 +08:00
)
}
}
}
</script>
<style lang="scss">
.container-box {
padding-top: calc(90rpx + var(--status-bar-height));
border-top: 1rpx solid #F4F4F4;
background-color: white;
width: 100%;
color: #363636;
font-size: 30rpx;
height: 100%;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: center;
position: relative;
.content {
border-top: 1rpx solid #F4F4F4;
height: calc(100vh - var(--status-bar-height) - var(--window-bottom) - 95rpx);
overflow-y: scroll;
width: 100%;
background-color: #F2F2F2;
border-radius: 20rpx;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: start;
position: relative;
.content-body {
width: 100%;
padding: 60rpx 30rpx 20rpx 30rpx;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: start;
position: relative;
.huojian {
width: 100rpx;
height: 180rpx;
z-index: 99;
position: absolute;
top: -10rpx;
left: 40rpx;
}
.coupon-box {
width: 100%;
background-image: url("/static/mine/coupon/bg.png");
background-repeat: no-repeat;
background-size: 100% 100%;
border-radius: 20rpx;
padding-bottom: 30rpx;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: start;
position: relative;
.left-top {
width: 100%;
padding: 30rpx 0;
display: flex;
align-items: center;
justify-content: start;
font-weight: bold;
font-size: 34rpx;
.bg-img {
padding-bottom: 20rpx;
background-image: url('/static/mine/auth/xiantiao.png');
background-repeat: no-repeat;
background-position: bottom right;
background-size: 100% 50%;
}
.left-space {
width: 200rpx;
}
image {
width: 30rpx;
height: 30rpx;
margin-bottom: 20rpx;
margin-right: 10rpx;
}
}
.content-img {
width: 100%;
height: 200rpx;
margin-bottom: 20rpx;
}
.bottom-content {
width: 90%;
margin: 0 auto;
border-top: 1rpx solid #FB2B43;
border-top-style: dashed;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: start;
.top-text {
width: 100%;
display: flex;
align-items: center;
justify-content: center;
padding: 30rpx 0;
text {
color: #FB2B43;
padding: 0 10rpx;
}
}
.button-dom {
width: 100%;
display: flex;
align-items: center;
justify-content: center;
padding: 20rpx 0;
background-image: linear-gradient(to right, #F9605A, #FB2B43);
color: white;
border-radius: 40rpx;
font-size: 33rpx;
}
}
}
}
.item-field {
width: 100%;
display: flex;
align-items: self-start;
justify-content: center;
.my-suggest-dom {
margin: 0 30rpx;
display: flex;
align-items: center;
justify-content: center;
font-size: 24rpx;
margin-top: 20rpx;
}
}
}
}
</style>