deming/pageE/mine/MemberServe.vue

247 lines
6.2 KiB
Vue
Raw Normal View History

2020-06-04 00:21:34 +00:00
<template>
<view class="member">
2020-07-21 13:02:28 +00:00
<view>
2020-06-04 00:21:34 +00:00
<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>
2020-07-21 13:02:28 +00:00
</view>
2020-07-06 09:32:29 +00:00
<swiper :current="swiperCurrent" @animationfinish="animationfinish" :style="{ height: swiperHeight }">
2020-06-04 00:21:34 +00:00
<swiper-item class="swiper-item">
2020-07-06 09:32:29 +00:00
<view class="integral">
2020-06-04 00:21:34 +00:00
<view class="integral-top">
<view>
<view class="title">总积分</view>
2020-09-02 00:55:56 +00:00
<view class="value">{{ memberInfo.member_points || 0 }}</view>
2020-06-04 00:21:34 +00:00
</view>
<view>
<view class="title">经验值</view>
2020-09-02 00:55:56 +00:00
<view class="value">{{ memberInfo.member_exppoints || 0 }}</view>
2020-06-04 00:21:34 +00:00
</view>
2020-07-08 10:14:41 +00:00
<view @click="viewProgress">
2020-06-04 00:21:34 +00:00
<view class="title">预计进度</view>
2020-07-10 01:03:19 +00:00
<!-- <view class="value">{{ memberInfo.next_grade_exppoints_diff }}</view> -->
<view class="value">
<image src="/static/image/mine/32.png"></image>
</view>
2020-06-04 00:21:34 +00:00
</view>
</view>
2020-07-06 09:32:29 +00:00
<scroll-view scroll-y class="integral-botom" :style="{ height: richHeight }">
2020-09-01 10:07:52 +00:00
<view class="rich-container">
2020-09-02 00:55:16 +00:00
<view class="title">{{ points_rule.document_title }}</view>
2020-09-01 10:07:52 +00:00
<rich-text :nodes="pointsNodes"></rich-text>
</view>
<view class="rich-container">
2020-09-02 00:55:16 +00:00
<view class="title" >{{ member_rule.document_title }}</view>
2020-09-01 10:07:52 +00:00
<rich-text :nodes="nodes"></rich-text>
</view>
2020-07-06 09:32:29 +00:00
</scroll-view>
</view>
2020-06-04 00:21:34 +00:00
</swiper-item>
<swiper-item class="swiper-item">
2020-07-08 10:14:41 +00:00
<view class="coupon">
<CouponView></CouponView>
</view>
2020-06-04 00:21:34 +00:00
</swiper-item>
<swiper-item class="swiper-item">
<scroll-view scroll-y class="details">
2020-06-23 09:21:01 +00:00
<view v-for="(item, index) in pointslogList" :key="index" class="details-item">
2020-06-04 00:21:34 +00:00
<view class="item-left">
2020-07-17 09:34:42 +00:00
<view class="item-title u-line-1">{{ item.pl_desc }}</view>
2020-06-23 09:21:01 +00:00
<view class="item-date">{{ item.pl_addtime }}</view>
2020-06-04 00:21:34 +00:00
</view>
2020-07-17 09:34:42 +00:00
<view class="item-right" :class="[item.pl_points < 0 ? 'negative' : 'positive']">
{{ Number(item.pl_points) > 0 ? '+' + item.pl_points : item.pl_points }}
2020-06-04 00:21:34 +00:00
</view>
</view>
2020-07-06 09:32:29 +00:00
<u-empty text="暂无明细" mode="data" color="#000" v-if="!pointslogList.length"></u-empty>
2020-06-04 00:21:34 +00:00
</scroll-view>
</swiper-item>
</swiper>
</view>
</template>
<script>
2020-07-06 09:32:29 +00:00
import common from '@/static/js/common.js';
2020-07-08 10:14:41 +00:00
import CouponView from "./MemberServeCoupon";
2020-06-04 00:21:34 +00:00
export default {
data() {
return {
list: [{
name: '积分数'
}, {
name: '兑换优惠券'
}, {
name: '积分明细'
}],
2020-07-06 09:32:29 +00:00
richHeight: '',
swiperHeight: '',
2020-07-21 13:02:28 +00:00
current: Number,
2020-06-04 00:21:34 +00:00
swiperCurrent: 0,
2020-07-06 09:32:29 +00:00
pointslogList: [],
memberInfo: {},
2020-09-01 10:07:52 +00:00
pointsNodes: '',
2020-07-06 09:32:29 +00:00
nodes: '',
2020-09-02 00:55:16 +00:00
points_rule: {},
member_rule: {}
2020-06-04 00:21:34 +00:00
}
},
2020-07-08 10:14:41 +00:00
components: {
CouponView
},
2020-07-17 09:34:42 +00:00
onLoad(option) {
2020-07-21 13:02:28 +00:00
this.setViewHeight();
2020-07-17 09:34:42 +00:00
if(option.current) this.current = option.current;
2020-07-21 13:02:28 +00:00
else this.current = 0;
2020-07-17 09:34:42 +00:00
},
watch: {
current(value) {
this.swiperCurrent = value;
2020-07-21 13:02:28 +00:00
if(value == 2) {
this.getPointslogList();
} else if(value == 0) {
this.getMemberPointsStat();
}
2020-07-17 09:34:42 +00:00
}
},
2020-06-04 00:21:34 +00:00
methods: {
tabsChange(index) {
this.swiperCurrent = index;
},
animationfinish(e) {
let current = e.detail.current;
this.swiperCurrent = current;
this.current = current;
2020-06-23 09:21:01 +00:00
},
2020-06-24 08:39:31 +00:00
getMemberPointsStat() {
this.$u.api.getMemberPointsStat().then((res)=>{
2020-08-09 06:23:59 +00:00
if(res.errCode == 0) {
2020-06-24 08:39:31 +00:00
this.memberInfo = res.data;
2020-09-02 00:55:16 +00:00
this.nodes = common.unescapeHTML(this.memberInfo.grade_rule.document_content);
2020-09-01 10:07:52 +00:00
this.pointsNodes = common.unescapeHTML(this.memberInfo.points_rule.document_content);
2020-09-02 00:55:16 +00:00
this.points_rule = this.memberInfo.points_rule;
this.member_rule = this.memberInfo.grade_rule;
2020-06-24 08:39:31 +00:00
}
})
},
2020-06-23 09:21:01 +00:00
getPointslogList() {
this.$u.api.getPointslogList().then((res)=>{
if (res.errCode == 0) {
this.pointslogList = res.data;
}
})
2020-07-06 09:32:29 +00:00
},
setViewHeight() {
const res = uni.getSystemInfoSync();
// console.log(res.windowHeight);
2020-08-09 10:39:35 +00:00
this.richHeight = res.windowHeight - (88 + 250) * (res.windowWidth / 750) + 'px';
2020-07-06 09:32:29 +00:00
// console.log(this.richHeight);
2020-08-09 10:39:35 +00:00
this.swiperHeight = res.windowHeight - (res.windowWidth / 750) * 88 + 'px';
2020-07-06 09:32:29 +00:00
},
2020-07-08 10:14:41 +00:00
viewProgress() {
this.$u.route({
url: '/pageE/mine/MineProgress'
})
},
2020-06-04 00:21:34 +00:00
},
}
</script>
<style lang="scss" scpoed>
.member {
min-height: calc(100vh - var(--window-top));
background-color: #ECECEC;
display: flex;
flex-direction: column;
2020-07-06 09:32:29 +00:00
// > uni-swiper {
// flex: 1;
// height: calc()
// }
2020-06-04 00:21:34 +00:00
.swiper-item {
padding-top: 10rpx;
.integral {
height: 100%;
position: relative;
2020-07-06 09:32:29 +00:00
overflow: hidden;
2020-06-04 00:21:34 +00:00
.integral-top {
padding: 79rpx 88rpx;
width: 750rpx;
2020-07-06 09:32:29 +00:00
height: 270rpx;
2020-06-04 00:21:34 +00:00
background: linear-gradient(0deg,rgba(246,211,119,1) 1%,rgba(240,154,105,1) 100%);
display: flex;
justify-content: space-between;
> view {
flex: 1;
text-align: center;
.title {
font-size: 28rpx;
color: rgba(255,255,255, 0.6);
margin-bottom: 29rpx;
}
.value {
font-size: 48rpx;
font-weight: 500;
color: rgba(255,255,255,1);
2020-07-10 01:03:19 +00:00
> image {
width: 52rpx;
height: 35rpx;
}
2020-06-04 00:21:34 +00:00
}
}
}
.integral-botom {
2020-07-06 09:32:29 +00:00
box-sizing: border-box;
padding: 30rpx;
2020-06-04 00:21:34 +00:00
position: absolute;
2020-07-06 09:32:29 +00:00
width: 100%;
2020-06-04 00:21:34 +00:00
background: rgba(255,255,255,1);
border-radius: 20rpx 20rpx 0rpx 0rpx;
2020-07-06 09:32:29 +00:00
top: 250rpx;
2020-06-04 00:21:34 +00:00
z-index: 9;
2020-09-01 10:07:52 +00:00
.rich-container {
2020-09-02 00:55:16 +00:00
&:not(:last-child) {
margin-bottom: 56rpx;
}
2020-09-01 10:07:52 +00:00
.title {
text-align: center;
font-size: 32rpx;
color: #333333;
2020-09-02 00:55:16 +00:00
margin-bottom: 26rpx;
2020-09-01 10:07:52 +00:00
// font-weight: bold;
}
}
2020-06-04 00:21:34 +00:00
}
}
.coupon {
2020-06-09 09:33:12 +00:00
height: 100%;
2020-06-04 00:21:34 +00:00
}
.details {
2020-06-09 09:33:12 +00:00
height: 100%;
2020-06-04 00:21:34 +00:00
.details-item {
background-color: #ffffff;
padding: 23rpx 30rpx;
margin-bottom: 2rpx;
display: flex;
align-items: center;
justify-content: space-between;
.item-left {
.item-title {
2020-07-17 09:34:42 +00:00
width: 450rpx;
2020-06-04 00:21:34 +00:00
font-size: 32rpx;
color: rgba(51,51,51,1);
margin-bottom: 23rpx;
}
.item-date {
font-size: 24rpx;
color: rgba(153,153,153,1);
}
}
.item-right {
font-size: 32rpx;
}
.positive {
color: rgba(56,199,70,1);
}
.negative {
color: rgba(255,49,49,1);
}
}
}
}
}
</style>