deming/pageE/tool/MineCoupon.vue

121 lines
2.8 KiB
Vue
Raw Normal View History

2020-07-08 10:14:41 +00:00
<template>
<view class="coupon">
<u-tabs-swiper ref="tabs" :list="list" :is-scroll="false" active-color="#FF780F" :current="current" font-size="32" :show-bar="false" @change="tabsChange" height="88" ></u-tabs-swiper>
<swiper :current="swiperCurrent" @animationfinish="animationfinish" :style="{ height: swiperHeight }">
<swiper-item class="swiper-item" v-for="(_, index) in list" :key="index">
<scroll-view scroll-y class="scroll-coupon">
2020-08-08 04:07:50 +00:00
<view v-if="couponList[index]">
<view class="coupon-item" v-for="(coupon, c_index) in couponList[index]" :key="c_index">
2020-08-09 10:39:35 +00:00
<Coupon :couponInfo="coupon" :status='index' @use="useCoupon($event)" :goodsClass="goodsClass"></Coupon>
2020-08-08 04:07:50 +00:00
</view>
2020-07-08 10:14:41 +00:00
</view>
2020-08-08 04:07:50 +00:00
<u-empty text="暂无优惠券" mode="coupon" v-if="!couponList[index] || !couponList[index].length"></u-empty>
2020-07-08 10:14:41 +00:00
</scroll-view>
</swiper-item>
</swiper>
</view>
</template>
<script>
2020-07-18 09:43:37 +00:00
import Coupon from "@/components/mine/coupon/mine"
2020-07-08 10:14:41 +00:00
export default {
data() {
return {
list: [{
name: '未使用'
}, {
name: '已使用'
}, {
name: '已过期'
}],
2020-07-17 09:34:42 +00:00
current: Number,
2020-07-08 10:14:41 +00:00
swiperCurrent: 0,
swiperHeight: '',
2020-07-18 09:43:37 +00:00
couponList: [],
goodsClass: [],
2020-07-08 10:14:41 +00:00
}
},
components: {
Coupon
},
onLoad() {
this.setViewHeight();
2020-07-18 09:43:37 +00:00
this.getGoodsClass();
2020-07-08 10:14:41 +00:00
},
2020-07-17 09:34:42 +00:00
onShow() {
this.current = 0;
},
watch: {
current(value) {
let status = value + 1;
this.getMemberCouponList(status);
}
},
2020-07-08 10:14:41 +00:00
methods: {
2020-07-18 09:43:37 +00:00
getGoodsClass() {
this.$u.api.getGoodsClass().then(res => {
this.goodsClass = res.data;
})
},
2020-07-17 09:34:42 +00:00
getMemberCouponList(current) {
this.$u.api.getMemberCouponList({
status: current
}).then(res => {
if(res.errCode == 0) {
2020-08-08 04:07:50 +00:00
this.couponList[this.current] = res.data;
2020-07-18 09:43:37 +00:00
} else {
2020-08-08 04:07:50 +00:00
this.couponList[this.current] = [];
2020-07-17 09:34:42 +00:00
}
2020-08-08 04:07:50 +00:00
this.$forceUpdate();
2020-07-17 09:34:42 +00:00
})
},
2020-08-09 10:39:35 +00:00
useCoupon(coupon) {
// console.log(coupon);
if(coupon.type == 1) {
this.$u.route({
type: 'switchTab',
url: 'pages/shop/index',
})
} else if(coupon.type == 2) {
this.$u.route('pageC/merchant/index', {
id: coupon.voucher_store_id,
});
}
2020-07-08 10:14:41 +00:00
},
setViewHeight() {
const res = uni.getSystemInfoSync();
2020-08-09 10:39:35 +00:00
this.swiperHeight = res.windowHeight - (100 * (res.windowWidth / 750)) + 'px';
2020-07-08 10:14:41 +00:00
},
tabsChange(index) {
this.swiperCurrent = index;
},
animationfinish(e) {
let current = e.detail.current;
this.swiperCurrent = current;
this.current = current;
},
},
};
</script>
<style lang="scss" scoped>
.coupon {
overflow: hidden;
.u-tabs {
border: {
top: 1rpx #ECECEC solid;
bottom: 10rpx #ECECEC solid;
};
}
.swiper-item {
box-sizing: border-box;
padding: 20rpx 30rpx;
.scroll-coupon {
height: 100%;
.coupon-item {
margin-bottom: 20rpx;
// position: relative;
// z-index: 9;
}
}
}
}
</style>