|
|
- <template>
- <view class="coupon-list">
- <view v-for="(item,index) in couponData" style="padding:20rpx;" :key="index">
- <view>
- <view class="card">
- <view class="card-left">
- <view class="">
- {{switchType(item.stockType)}}
- </view>
- </view>
- <view class="card-center">
- <view class="card-center-top"></view>
- <view class="card-center-bottom"></view>
- </view>
- <view class="card-right">
- <view class="card-content">
- <view class="card-info">{{item.stockName}}</view>
- <view class="card-type">可用于
- <text class="card-type-text">专业喂养</text>
- <text class="card-type-text">专业遛狗</text>
- <!-- <text class="card-type-text">{{ item.goodsName }}</text> -->
- </view>
- <view class="card-time">有效期至: {{item.availableEndTime.slice(0, 16)}}</view>
- </view>
- <!-- <view style="width: 22%;">
- <u-button @click="receiveCoupon(item.id)" shape="circle" size="mini" color="#ffaa48" text="立即领取"></u-button>
- </view> -->
- <view style="width: 132rpx;height: 52rpx;background-color: #FFAA48; display: flex;align-items: center;justify-content: center;border-radius: 56rpx;">
- <text @click="receiveCoupon(item.id)" style="font-size: 24rpx; font-weight: 500; color: #FFFFFF;">立即领取</text>
- </view>
- </view>
- </view>
- <view class="card-bottom">
- <view class="card-bottom-text">
- 优惠券不可兑换现金
- </view>
- <view class="card-bottom-text" @click="showRulePopup(item)">
- 查看详细规则>
- </view>
- </view>
- </view>
- </view>
-
- <!-- 优惠券详细规则弹窗 -->
- <uni-popup ref="rulePopup" type="center">
- <view class="rule-popup">
- <view class="rule-popup-title">优惠券详细规则</view>
- <view class="rule-popup-content">
- <view class="rule-item">
- <view class="rule-label">名称:</view>
- <view class="rule-value">{{currentCoupon.stockName}}</view>
- </view>
- <view class="rule-item">
- <view class="rule-label">折扣:</view>
- <view class="rule-value">{{getDiscountText(currentCoupon)}}</view>
- </view>
- <view class="rule-item">
- <view class="rule-label">使用规则:</view>
- <view class="rule-value">可用于专业喂养和专业遛狗服务</view>
- </view>
- <view class="rule-item">
- <view class="rule-label">有效日期:</view>
- <view class="rule-value">{{currentCoupon.availableEndTime ? currentCoupon.availableEndTime.slice(0, 16) : ''}}</view>
- </view>
- <view class="rule-item">
- <view class="rule-label">特别说明:</view>
- <view class="rule-value">单笔订单仅限使用1张优惠券;优惠券仅限用户本人使用,不可赠送、不可提现、不得找零。</view>
- </view>
- </view>
- <view class="rule-popup-close" @click="closeRulePopup">关闭</view>
- </view>
- </uni-popup>
- </view>
- </template>
- <script>
- import {
- getCouponList,
- receiveCoupon,
- } from "@/api/system/user"
- export default {
- data() {
- return {
- couponData: [],
- currentCoupon: {}, // 当前选中的优惠券
- }
- },
- onLoad() {
- // this.openIdStr = this.$globalData.openIdStr;
- this.getCouponListAuth()
- },
- methods: {
- getCouponListAuth() {
- getCouponList().then(res => {
- if (res.code == 200) {
- this.couponData = res.data
- console.log("this.couponData", this.couponData)
- } else {
- this.$modal.showToast('获取优惠券失败')
- }
- })
- },
- switchType(type) {
- if (type == 'PNORMAL') {
- return '满减券'
- }
- if (type == 'PDISCOUNT') {
- return '折扣券'
- }
- if (type == 'PTRAIL') {
- return '体验券'
- }
- return '优惠券'
- },
- receiveCoupon (id) {
- let data = {
- stockId: id
- }
- receiveCoupon(data).then(res => {
- console.log("this.receiveCoupon", res)
- if (res.code == 200) {
- this.$modal.showToast('优惠券领取成功')
- } else {
- this.$modal.showToast('领取优惠券失败')
- }
- })
- },
-
- // 显示优惠券规则弹窗
- showRulePopup(item) {
- this.currentCoupon = item || {};
- this.$refs.rulePopup.open();
- },
-
- // 关闭优惠券规则弹窗
- closeRulePopup() {
- this.$refs.rulePopup.close();
- },
-
- // 获取优惠券折扣文本
- getDiscountText(coupon) {
- if (!coupon || !coupon.stockType) return '';
-
- if (coupon.stockType === 'PNORMAL') {
- return '满100可减10元';
- } else if (coupon.stockType === 'PDISCOUNT') {
- return '打8折';
- } else if (coupon.stockType === 'PTRAIL') {
- return '免费体验一次';
- }
- return '';
- }
- }
- }
- </script>
-
- <style lang="scss">
- .coupon-list {
-
- /* 优惠券规则弹窗样式 */
- .rule-popup {
- width: 600rpx;
- background-color: #FFFFFF;
- border-radius: 16rpx;
- overflow: hidden;
- }
-
- .rule-popup-title {
- height: 100rpx;
- line-height: 100rpx;
- text-align: center;
- font-size: 32rpx;
- font-weight: 600;
- color: #FFFFFF;
- background-color: #FFAA48;
- }
-
- .rule-popup-content {
- padding: 30rpx;
- }
-
- .rule-item {
- display: flex;
- margin-bottom: 20rpx;
- }
-
- .rule-label {
- width: 140rpx;
- font-size: 28rpx;
- color: #666666;
- flex-shrink: 0;
- }
-
- .rule-value {
- flex: 1;
- font-size: 28rpx;
- color: #333333;
- line-height: 40rpx;
- }
-
- .rule-popup-close {
- height: 90rpx;
- line-height: 90rpx;
- text-align: center;
- font-size: 30rpx;
- color: #FFAA48;
- border-top: 1px solid #EEEEEE;
- }
- .card {
- display: flex;
- align-items: center;
- width: 100%;
- padding: 10px 0;
- background: #fff;
- border-radius: 8px 8px 0 0;
- }
-
- .card-bottom {
- display: flex;
- background-color: #FFF1E0;
- height: 50rpx;
- align-items: center;
- justify-content: space-between;
- padding: 0 20rpx 0 20rpx;
- border-radius: 0 0 8px 8px;
-
- .card-bottom-text {
- color: #AAAAAA;
- font-size: 24rpx;
- font-weight: 400;
- }
- }
-
- .card-left {
- width: 88px;
- text-align: center;
- color: #FF530A;
- font-size: 28rpx;
- font-weight: 900;
- }
-
- .card-center {
- display: flex;
- flex-direction: column;
- // align-items: center;
-
- .card-center-top {
- width: 40rpx;
- height: 20rpx;
- border-radius: 0 0 20rpx 20rpx;
- background-color: #F5F5F7;
- line-height: 20rpx;
- // border-bottom: 1px solid #FDA714;
- // border-left: 1px solid #FDA714;
- // border-right: 1px solid #FDA714;
- margin-top: -22rpx;
- margin-bottom: 20rpx;
- margin-left: -19rpx;
- }
-
- .card-center-bottom {
- border-right: 1px dashed #AAAAAA;
- width: 1px;
- height: 120rpx;
- }
- }
-
- .card-right {
- padding: 0px 12px;
- display: flex;
- flex: 1;
- /* flex-direction: column; */
- justify-content: space-between;
- align-items: center;
- height: 60px;
-
- .card-content {
- width: 77%;
- }
-
- .card-icon {
- position: relative;
- right: -10px;
- top: -10px;
- }
- }
-
- .card-info {
- margin: 0;
- font-size: 28rpx;
- line-height: 28rpx;
- color: #333333;
- font-weight: 500;
- }
-
- .card-type {
- font-size: 24rpx;
- font-weight: 400;
- line-height: 24rpx;
- font-weight: 400;
- color: #AAAAAA;
- margin-top: 10rpx;
-
- .card-type-text {
- color: #FFAA48;
- font-size: 24rpx;
- font-weight: 400;
- line-height: 24rpx;
- border: #FFAA48 1px solid;
- border-radius: 7rpx;
- margin-left: 8rpx;
- }
- }
-
- .card-time {
- font-size: 24rpx;
- font-weight: 400;
- line-height: 24rpx;
- font-weight: 400;
- color: #AAAAAA;
- margin-top: 10rpx;
- }
- }
- </style>
|