<template> <!-- 优惠券 --> <view class="couponBox"> <view class="acea-row row-around navCoupon" :class="navShow ? 'headerfixed' : ''" :style="{ top: statusBarHeight+44 + 'px' }"> <template> <view v-for="(item,index) in navList" :key="index" :class="['acea-row', 'row-middle', type === item.type ? 'on' : '']"> <text @click="setType(item.type)">{{item.name}}</text> </view> </template> </view> <view v-if="couponsList.length" class="coupon coupon-list"> <view v-for="(item,index) in couponsList" :key="index" class="item"> <!-- :class="{gary:item.isUse}" --> <view class="left main_bg"> <view class="money"> <text>¥{{ item.money }}</text> <view class="pic-num" v-if="parseFloat(item.minPrice)>0"> 满{{ item.minPrice?Number(item.minPrice):'' }}可用</view> </view> </view> <view class="right"> <view class="name line2"> <text>{{item.category===1?'商家券':'商品券'}}</text> {{ item.name }} </view> <view class="time-wrap" style="justify-content: space-between;"> <block v-if="item.isFixedTime"> <view class="time"> {{ item.useStartTimeStr | dateFormat }}-{{ item.useEndTimeStr | dateFormat }} </view> </block> <block v-else> <view>{{'领取后'+ item.day+ '天内可用'}}</view> </block> <block v-if="item.isUse"> <view class='getgray iconfont icon-yilingqu1'></view> </block> <block v-else> <view class="button" @click="receiveCoupon(item)">领取</view> </block> </view> </view> </view> </view> <view class='loadingicon acea-row row-center-wrapper'> <text class='loading iconfont icon-jiazai' :hidden='loadingcoupon==false'></text>{{couponsList.length?loadTitle:''}} </view> <emptyPage v-if="couponsList.length == 0 && !loadingcoupon" title="暂无可用优惠券~" mTop="14%" :imgSrc="urlDomain+'crmebimage/presets/noCoupon.png'"></emptyPage> </view> </template> <script> import emptyPage from '@/components/emptyPage.vue' import { getCoupons, setCouponReceive, } from '@/api/api.js'; var statusBarHeight = uni.getSystemInfoSync().statusBarHeight; export default { components: { emptyPage }, props: { merId: { // 商户id type: Number, default: 0 }, }, data() { return { couponsList: [], navList: [{ type: 1, name: '商家券', count: 0 }, { type: 2, name: '商品券', count: 0 } ], urlDomain: this.$Cache.get("imgHost"), loadendcoupon: false, loadingcoupon: false, page: 1, limit: 10, type: 1, statusBarHeight: 0, navShow: false, loadTitle: '' } }, onShow() { // #ifdef MP || APP-PLUS this.statusBarHeight = statusBarHeight; // #endif // #ifdef H5 this.statusBarHeight = 20; // #endif }, mounted() { this.getCoupon() }, methods: { // 领取优惠券 receiveCoupon(item) { let that = this; if (that.isLogin === false) { toLogin(); } else { uni.showLoading({ title: '加载中...' }); setCouponReceive(item.id).then(res => { uni.showToast({ title: '领取成功', icon: 'none' }) uni.hideLoading(); item.isUse = !item.isUse }).catch(err => { uni.showToast({ title: err, icon: 'none' }) uni.hideLoading(); }) } }, setType: function(type) { if (this.type !== type) { this.type = type; this.couponsList = []; this.page = 1; this.loadendcoupon = false; this.getCoupon(); } }, // 获取商铺优惠券 getCoupon: function() { let that = this if (that.loadendcoupon) return false; if (that.loadingcoupon) return false; that.loadingcoupon = true; getCoupons({ page: that.page, limit: that.limit, category: this.type, merId: this.merId }).then(res => { let list = res.data.list, loadend = list.length < that.limit; let couponsList = that.$util.SplitArray(list, that.couponsList); that.$set(that, 'couponsList', couponsList); that.loadendcoupon = loadend; that.loadTitle = loadend ? '我也是有底线的' : '显示更多'; that.page = that.page + 1; that.loadingcoupon = false; that.isShow = true; }).catch(err => { that.loadingcoupon = false; that.loadTitle = '显示更多'; }); }, } } </script> <style lang="scss" scoped> .getgray { font-size: 134rpx !important; @include main_color(theme); position: absolute; right: -20rpx; bottom: -20rpx; opacity: .36; } .coupon-list { margin-top: 0; .right { position: relative; overflow: hidden; } } .couponBox { /deep/.empty-box { padding-top: 200rpx; margin-top: 0 !important; } } .navCoupon { width: 100%; height: 80rpx; color: #999999; background-color: #fff; } .navCoupon .acea-row { border-top: 5rpx solid transparent; border-bottom: 5rpx solid transparent; cursor: pointer; } .navCoupon .acea-row.on { @include tab_border_bottom(theme); @include main_color(theme); } .coupon { padding: 24rpx; background-color: #F5F5F5; .item { display: flex; margin-bottom: 16rpx; .left { display: flex; flex-direction: column; justify-content: center; align-items: center; width: 240rpx; font-weight: 500; font-size: 24rpx; line-height: 1; color: #FFFFFF; &.gary { background-image: url(''); } .money { text { margin-left: 10rpx; font-size: 60rpx; } } } .right { flex: 1; min-width: 0; padding: 0 20rpx; background-color: #FFFFFF; .name { border-bottom: 1rpx solid #F0F0F0; font-weight: 500; height: 115rpx; font-size: 30; line-height: 46rpx; color: #282828; padding: 15rpx 0; text { display: inline-block; // width: 84rpx; // height: 28rpx; padding: 0 10rpx; border-radius: 14rpx; margin-right: 15rpx; background-color: #FFF4F3; font-weight: 500; font-size: 20rpx; line-height: 26rpx; text-align: center; @include main_color(theme); @include coupons_border_color(theme); &.gary { border-color: #BBB; color: #bbb; background-color: #F5F5F5; } } } .time-wrap { display: flex; align-items: center; padding-top: 16rpx; padding-bottom: 16rpx; font-weight: 500; font-size: 20rpx; color: #999999; .time { flex: 1; min-width: 0; } .button { width: 136rpx; height: 44rpx; border-radius: 22rpx; @include main_bg_color(theme); font-weight: 500; font-size: 22rpx; line-height: 44rpx; text-align: center; color: #FFFFFF; &.gary { background-color: #999; } } } } } .disabled { .left { background-image: url(../../static/images/coupon2.png); } .right { .name { text { border-color: #C1C1C1; color: #C1C1C1; } } .time-wrap { .button { background-color: #CCCCCC; color: #FFFFFF; } } } } } </style>