2020-08-13 08:12:57 +00:00
|
|
|
|
<template>
|
|
|
|
|
<view class="memberVip">
|
|
|
|
|
<view class="bg">
|
|
|
|
|
<view class="header">
|
|
|
|
|
<view class="picTxt acea-row row-middle">
|
|
|
|
|
<view class="pictrue">
|
|
|
|
|
<image :src="userInfo.avatar"></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="text acea-row row-middle">
|
|
|
|
|
<view class="name line1">{{userInfo.nickname}}</view>
|
|
|
|
|
<view class="vip" v-if='userInfo.vip'>
|
|
|
|
|
<image :src="userInfo.vipIcon"></image>{{userInfo.vipName}}
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="experience">
|
|
|
|
|
<view class="title">当前经验值</view>
|
|
|
|
|
<view class="num">{{levelInfo}}</view>
|
|
|
|
|
<view class="axis">
|
|
|
|
|
<view class="bar">
|
|
|
|
|
<view class="barCon">
|
|
|
|
|
<view class="solidBar" :style="'width: ' + widthLen +'%;'"></view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="acea-row row-around row-middle">
|
|
|
|
|
<view class="spotw acea-row row-center" v-for="(item,index) in levelList" :key='index'>
|
|
|
|
|
<view class="spot" :class="current >item.experience?'past':'' + ' ' + current==item.experience?'on':''"></view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="numList acea-row row-around row-middle">
|
2020-08-17 07:28:28 +00:00
|
|
|
|
<view class="item" :class="current >=item.experience?'past':''" v-for="(item,index) in levelList" :key="index">{{item.experience}}</view>
|
2020-08-13 08:12:57 +00:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="vipList acea-row">
|
|
|
|
|
<view class="item">
|
|
|
|
|
<view class="pictrue">
|
|
|
|
|
<image src="./../static/vip01.png"></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="name">会员折扣</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="item">
|
|
|
|
|
<view class="pictrue">
|
|
|
|
|
<image src="./../static/vip02.png"></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="name">专属徽章</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="item">
|
|
|
|
|
<view class="pictrue">
|
|
|
|
|
<image src="./../static/vip03.png"></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="name">会员升级</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="item">
|
|
|
|
|
<view class="pictrue">
|
|
|
|
|
<image src="./../static/vip04.png"></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="name">经验积累</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="item">
|
|
|
|
|
<view class="pictrue">
|
|
|
|
|
<image src="./../static/vip05.png"></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="name">更多特权</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="module">
|
|
|
|
|
<view class="public_title acea-row row-middle">
|
|
|
|
|
<view class="icons"></view>获取经验
|
|
|
|
|
</view>
|
|
|
|
|
<view class="gainList">
|
|
|
|
|
<view class="item acea-row row-between-wrapper">
|
|
|
|
|
<view class="picTxt acea-row row-middle">
|
|
|
|
|
<view class="pictrue"><text class="iconfont icon-qiandao2"></text></view>
|
|
|
|
|
<view class="text">
|
|
|
|
|
<view class="name line1">签到</view>
|
|
|
|
|
<view class="info line1">每日签到可获得经验值</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<navigator url='/pages/users/user_sgin/index' class="button" hover-class="none">去获取</navigator>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="item acea-row row-between-wrapper">
|
|
|
|
|
<view class="picTxt acea-row row-middle">
|
|
|
|
|
<view class="pictrue on"><text class="iconfont icon-shangpin"></text></view>
|
|
|
|
|
<view class="text">
|
|
|
|
|
<view class="name line1">购买商品</view>
|
|
|
|
|
<view class="info line1">购买商品可获得对应是经验值</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<navigator url="/pages/goods_cate/goods_cate" class="button" hover-class="none" open-type='switchTab'>去获取</navigator>
|
|
|
|
|
</view>
|
2021-03-19 10:26:43 +00:00
|
|
|
|
<!-- <view class="item acea-row row-between-wrapper">
|
2020-08-13 08:12:57 +00:00
|
|
|
|
<view class="picTxt acea-row row-middle">
|
|
|
|
|
<view class="pictrue on2"><text class="iconfont icon-yaoqing"></text></view>
|
|
|
|
|
<view class="text">
|
|
|
|
|
<view class="name line1">邀请好友</view>
|
|
|
|
|
<view class="info line1">邀请好友注册商城可获得经验值</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<navigator url="/pages/users/user_spread_code/index" class="button" hover-class="none">去获取</navigator>
|
2021-03-19 10:26:43 +00:00
|
|
|
|
</view> -->
|
2020-08-13 08:12:57 +00:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="detailed" v-if="expList.length">
|
|
|
|
|
<view class="public_title acea-row row-middle">
|
|
|
|
|
<view class="icons"></view>经验值明细
|
|
|
|
|
</view>
|
|
|
|
|
<view class="list">
|
2020-08-17 07:28:28 +00:00
|
|
|
|
<view class="item acea-row row-between-wrapper" v-for="(item,index) in expList" :key="index">
|
2020-08-13 08:12:57 +00:00
|
|
|
|
<view class="text">
|
|
|
|
|
<view class="name">{{item.title}}</view>
|
|
|
|
|
<view class="data">{{item.add_time}}</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="num" v-if="item.pm">+{{item.number}}</view>
|
|
|
|
|
<view class="num on" v-else>-{{item.number}}</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class='loadingicon acea-row row-center-wrapper' v-if="expList.length">
|
|
|
|
|
<text class='loading iconfont icon-jiazai' :hidden='loading==false'></text>{{loadTitle}}
|
|
|
|
|
</view>
|
|
|
|
|
<home></home>
|
|
|
|
|
</view>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
import home from '@/components/home';
|
|
|
|
|
import {
|
|
|
|
|
getUserInfo,
|
|
|
|
|
getlevelInfo,
|
|
|
|
|
getlevelExpList
|
|
|
|
|
} from '@/api/user.js';
|
|
|
|
|
export default {
|
|
|
|
|
components: {
|
|
|
|
|
home
|
|
|
|
|
},
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
userInfo: '',
|
|
|
|
|
levelInfo: '',
|
|
|
|
|
levelList: [],
|
|
|
|
|
current: 0,
|
|
|
|
|
widthLen: 0,
|
|
|
|
|
loading: false,
|
|
|
|
|
loadend: false,
|
|
|
|
|
loadTitle: '加载更多', //提示语
|
|
|
|
|
page: 1,
|
|
|
|
|
limit: 20,
|
|
|
|
|
expList: []
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
onShow() {
|
|
|
|
|
this.getUserInfo();
|
|
|
|
|
this.getInfo();
|
|
|
|
|
this.getlevelList();
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
/**
|
|
|
|
|
* 获取个人用户信息
|
|
|
|
|
*/
|
|
|
|
|
getUserInfo: function() {
|
|
|
|
|
let that = this;
|
|
|
|
|
getUserInfo().then(res => {
|
2021-03-19 10:26:43 +00:00
|
|
|
|
that.$store.commit("SETUID", res.data.uid);
|
|
|
|
|
that.$store.commit("UPDATE_USERINFO", res.data);
|
2020-08-13 08:12:57 +00:00
|
|
|
|
that.userInfo = res.data;
|
|
|
|
|
that.levelInfo = res.data.experience;
|
|
|
|
|
}).catch(function(res) {
|
|
|
|
|
return that.$util.Tips({
|
2020-11-05 08:21:06 +00:00
|
|
|
|
title: res
|
2020-08-13 08:12:57 +00:00
|
|
|
|
});
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
getInfo: function() {
|
|
|
|
|
let that = this;
|
|
|
|
|
getlevelInfo().then(res => {
|
|
|
|
|
let levelList = res.data.list;
|
|
|
|
|
let list = []
|
|
|
|
|
that.levelList = levelList;
|
|
|
|
|
levelList.forEach((item, index) => {
|
|
|
|
|
if (item.experience <= that.levelInfo) {
|
|
|
|
|
list.push(item.experience)
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
let maxn = Math.max.apply(null, list);
|
|
|
|
|
that.current = maxn;
|
|
|
|
|
// 解决len取的值没有时;
|
|
|
|
|
let levelListLen = levelList[list.length] ? levelList[list.length] : levelList[list.length - 1];
|
|
|
|
|
// 解决除数不能为0
|
|
|
|
|
let divisor = levelListLen.experience - maxn ? levelListLen.experience - maxn : 1;
|
|
|
|
|
// 每小格所占的百分比
|
|
|
|
|
let per = (that.levelInfo - maxn) / divisor / levelList.length;
|
|
|
|
|
|
|
|
|
|
that.widthLen = ((list.length - 0.5) / (levelList.length)) * 100 + per * 100
|
|
|
|
|
|
|
|
|
|
}).catch(function(res) {
|
|
|
|
|
return that.$util.Tips({
|
2020-11-05 08:21:06 +00:00
|
|
|
|
title: res
|
2020-08-13 08:12:57 +00:00
|
|
|
|
});
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
getlevelList: function() {
|
|
|
|
|
let that = this
|
|
|
|
|
if (this.loadend) return false;
|
|
|
|
|
if (this.loading) return false;
|
|
|
|
|
getlevelExpList({
|
|
|
|
|
page: that.page,
|
|
|
|
|
limit: that.limit
|
|
|
|
|
}).then(res => {
|
|
|
|
|
let list = res.data.list,
|
|
|
|
|
loadend = list.length < that.limit;
|
|
|
|
|
let expList = that.$util.SplitArray(list, that.expList);
|
|
|
|
|
that.$set(that, 'expList', expList);
|
|
|
|
|
that.loadend = loadend;
|
|
|
|
|
that.loadTitle = loadend ? '我也是有底线的' : '加载更多';
|
|
|
|
|
that.page = that.page + 1;
|
|
|
|
|
that.loading = false;
|
|
|
|
|
}).catch(err => {
|
|
|
|
|
that.loading = false;
|
|
|
|
|
that.loadTitle = '加载更多';
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
onReachBottom: function() {
|
|
|
|
|
this.getlevelList();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
|
.memberVip {
|
|
|
|
|
.bg {
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
|
|
|
|
.header {
|
|
|
|
|
background-image: url('
|
|
|
|
|
background-repeat: no-repeat;
|
|
|
|
|
background-size: 100% 100%;
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 380rpx;
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
|
|
|
|
.picTxt {
|
|
|
|
|
padding: 28rpx 39rpx;
|
|
|
|
|
|
|
|
|
|
.pictrue {
|
|
|
|
|
width: 70rpx;
|
|
|
|
|
height: 70rpx;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
|
|
|
|
|
image {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.text {
|
|
|
|
|
color: #FAE2C1;
|
|
|
|
|
margin-left: 23rpx;
|
|
|
|
|
|
|
|
|
|
.name {
|
|
|
|
|
max-width: 385rpx;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.vip {
|
|
|
|
|
padding: 2rpx 8rpx;
|
|
|
|
|
border: 1px solid rgba(250, 226, 193, 1);
|
|
|
|
|
border-radius: 20rpx;
|
|
|
|
|
font-size: 18rpx;
|
|
|
|
|
margin-left: 15rpx;
|
|
|
|
|
|
|
|
|
|
image {
|
|
|
|
|
width: 20rpx;
|
|
|
|
|
height: 20rpx;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
margin-right: 8rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.experience {
|
|
|
|
|
background-image: url('
|
|
|
|
|
background-repeat: no-repeat;
|
|
|
|
|
background-size: 100% 100%;
|
|
|
|
|
width: 690rpx;
|
|
|
|
|
height: 360rpx;
|
|
|
|
|
margin: -250rpx auto 0 auto;
|
|
|
|
|
border-radius: 23rpx;
|
|
|
|
|
padding: 22rpx 27rpx;
|
|
|
|
|
box-sizing: border-box;
|
2020-12-23 07:56:45 +00:00
|
|
|
|
|
2020-08-13 08:12:57 +00:00
|
|
|
|
.title {
|
|
|
|
|
font-size: 24rpx;
|
|
|
|
|
color: #AE8B4A;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.num {
|
|
|
|
|
font-size: 60rpx;
|
|
|
|
|
color: #775C29;
|
|
|
|
|
margin-top: 6rpx;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.axis {
|
|
|
|
|
margin: 10rpx 0 15rpx 0;
|
2020-12-23 07:56:45 +00:00
|
|
|
|
overflow: hidden;
|
2020-08-13 08:12:57 +00:00
|
|
|
|
.bar {
|
|
|
|
|
width: 630rpx;
|
|
|
|
|
.spotw{
|
|
|
|
|
width: 96rpx;
|
|
|
|
|
}
|
|
|
|
|
.barCon {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 3rpx;
|
|
|
|
|
background: #D7BD89;
|
|
|
|
|
border-radius: 2rpx;
|
|
|
|
|
|
|
|
|
|
.solidBar {
|
|
|
|
|
width: 0;
|
|
|
|
|
height: 100%;
|
|
|
|
|
background: #775C29;
|
|
|
|
|
border-radius: 2rpx;
|
|
|
|
|
transition: width 0.6s ease;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.spot {
|
|
|
|
|
width: 8rpx;
|
|
|
|
|
height: 8rpx;
|
|
|
|
|
background: #D7BD89;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
margin-top: -5rpx;
|
|
|
|
|
|
|
|
|
|
&.past {
|
|
|
|
|
background: #775C29;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
&.on {
|
|
|
|
|
background: #775C29;
|
|
|
|
|
box-shadow: 0rpx 0rpx 8rpx #000;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.numList {
|
|
|
|
|
font-size: 26rpx;
|
|
|
|
|
color: #D7BD89;
|
|
|
|
|
margin-top: 14rpx;
|
|
|
|
|
|
|
|
|
|
.item {
|
|
|
|
|
width: 96rpx;
|
|
|
|
|
text-align: center;
|
|
|
|
|
|
|
|
|
|
&.past {
|
|
|
|
|
color: #775C29;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.vipList {
|
|
|
|
|
.item {
|
|
|
|
|
width: 20%;
|
|
|
|
|
text-align: center;
|
|
|
|
|
|
|
|
|
|
.pictrue {
|
|
|
|
|
width: 70rpx;
|
|
|
|
|
height: 70rpx;
|
|
|
|
|
margin: 0 auto;
|
|
|
|
|
|
|
|
|
|
image {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.name {
|
|
|
|
|
font-size: 24rpx;
|
|
|
|
|
color: #403D4E;
|
|
|
|
|
margin-top: 18rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
.module {
|
|
|
|
|
padding: 40rpx 30rpx 0 30rpx;
|
|
|
|
|
|
|
|
|
|
.gainList {
|
|
|
|
|
margin-top: 10rpx;
|
|
|
|
|
|
|
|
|
|
.item {
|
|
|
|
|
height: 130rpx;
|
|
|
|
|
position: relative;
|
|
|
|
|
|
|
|
|
|
.picTxt {
|
|
|
|
|
.pictrue {
|
|
|
|
|
width: 70rpx;
|
|
|
|
|
height: 70rpx;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
background: linear-gradient(-45deg, rgba(249, 119, 107, 1) 0%, rgba(255, 147, 137, 1) 100%);
|
|
|
|
|
text-align: center;
|
|
|
|
|
line-height: 70rpx;
|
|
|
|
|
color: #fff;
|
|
|
|
|
|
|
|
|
|
&.on {
|
|
|
|
|
background: linear-gradient(-45deg, rgba(254, 160, 96, 1) 0%, rgba(255, 204, 170, 1) 100%);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
&.on2 {
|
|
|
|
|
background: linear-gradient(-45deg, rgba(157, 208, 116, 1) 0%, rgba(161, 214, 124, 1) 100%);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.text {
|
|
|
|
|
margin-left: 30rpx;
|
|
|
|
|
width: 400rpx;
|
|
|
|
|
|
|
|
|
|
.name {
|
|
|
|
|
font-size: 30rpx;
|
|
|
|
|
color: #282828;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.info {
|
|
|
|
|
font-size: 24rpx;
|
|
|
|
|
color: #999999;
|
|
|
|
|
margin-top: 6rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.button {
|
|
|
|
|
width: 140rpx;
|
|
|
|
|
height: 50rpx;
|
|
|
|
|
background: linear-gradient(-90deg, rgba(231, 182, 103, 1) 0%, rgba(255, 234, 181, 1) 100%);
|
|
|
|
|
border-radius: 25rpx;
|
|
|
|
|
text-align: center;
|
|
|
|
|
line-height: 50rpx;
|
|
|
|
|
font-size: 26rpx;
|
|
|
|
|
color: #8D5306;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
&~.item {
|
|
|
|
|
&::after {
|
|
|
|
|
position: absolute;
|
|
|
|
|
content: ' ';
|
|
|
|
|
width: 720rpx;
|
|
|
|
|
height: 1rpx;
|
|
|
|
|
background: rgba(245, 245, 245, 1);
|
|
|
|
|
top: 0;
|
|
|
|
|
left: 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.public_title {
|
|
|
|
|
color: #282828;
|
|
|
|
|
font-size: 30rpx;
|
|
|
|
|
|
|
|
|
|
.icons {
|
|
|
|
|
width: 6rpx;
|
|
|
|
|
height: 28rpx;
|
|
|
|
|
background: rgba(230, 192, 131, 1);
|
|
|
|
|
margin-right: 10rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.detailed {
|
|
|
|
|
padding: 30rpx 30rpx 0 30rpx;
|
|
|
|
|
margin-top: 15rpx;
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
|
|
|
|
|
.list {
|
|
|
|
|
margin-top: 15rpx;
|
|
|
|
|
|
|
|
|
|
.item {
|
|
|
|
|
height: 122rpx;
|
|
|
|
|
border-bottom: 1px solid #EEEEEE;
|
|
|
|
|
|
|
|
|
|
.text {
|
|
|
|
|
.name {
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
color: #282828;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.data {
|
|
|
|
|
color: #999;
|
|
|
|
|
font-size: 24rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.num {
|
|
|
|
|
font-size: 32rpx;
|
|
|
|
|
color: #16AC57;
|
|
|
|
|
}
|
|
|
|
|
.on{
|
|
|
|
|
color: #E93323;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</style>
|