mall-uniapp/pages/users/user_vip/index.vue

510 lines
177 KiB
Vue
Raw Normal View History

2020-08-13 08:12:57 +00:00
<template>
<view class="memberVip">
2023-08-28 13:03:42 +00:00
<!-- 基本信息 -->
2020-08-13 08:12:57 +00:00
<view class="bg">
<view class="header">
<view class="picTxt acea-row row-middle">
<view class="pictrue">
2023-08-28 13:03:42 +00:00
<image :src="userInfo.avatar" />
2020-08-13 08:12:57 +00:00
</view>
<view class="text acea-row row-middle">
2023-08-28 13:03:42 +00:00
<view class="name line1">{{ userInfo.nickname }}</view>
<view class="vip" v-if='userInfo.level'>
<image :src="userInfo.level.icon" /> {{ userInfo.level.name }}
2020-08-13 08:12:57 +00:00
</view>
</view>
</view>
</view>
2023-08-28 13:03:42 +00:00
<!-- TODO -->
2020-08-13 08:12:57 +00:00
<view class="experience">
<view class="title">当前经验值</view>
2023-08-28 13:03:42 +00:00
<view class="num">{{ userInfo.experience }}</view>
2020-08-13 08:12:57 +00:00
<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"
2023-08-28 13:03:42 +00:00
:class="current > item.experience?'past':'' + ' ' + current === item.experience?'on':''">
</view>
2020-08-13 08:12:57 +00:00
</view>
</view>
</view>
<view class="numList acea-row row-around row-middle">
2023-08-28 13:03:42 +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>
2023-08-28 13:03:42 +00:00
<!-- 各种描述没有逻辑 -->
2020-08-13 08:12:57 +00:00
<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>
2023-08-28 13:03:42 +00:00
<!-- 引导攒经验 -->
2020-08-13 08:12:57 +00:00
<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>
2020-08-13 08:12:57 +00:00
</view>
</view>
</view>
</view>
2023-08-28 13:03:42 +00:00
<!-- 经验列表 -->
2020-08-13 08:12:57 +00:00
<view class="detailed" v-if="expList.length">
<view class="public_title acea-row row-middle">
2023-08-28 13:03:42 +00:00
<view class="icons" />经验值明细
2020-08-13 08:12:57 +00:00
</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">
2023-08-28 13:03:42 +00:00
<view class="name">{{ item.title }}</view>
<view class="data">{{ formatDate(item.createTime) }}</view>
2020-08-13 08:12:57 +00:00
</view>
2023-08-28 13:03:42 +00:00
<view class="num" v-if="item.experience > 0">+{{ item.experience }}</view>
<view class="num on" v-else>{{item.experience}}</view>
2020-08-13 08:12:57 +00:00
</view>
</view>
</view>
<view class='loadingicon acea-row row-center-wrapper' v-if="expList.length">
2023-08-28 13:03:42 +00:00
<text class='loading iconfont icon-jiazai' :hidden='!loading' />{{loadTitle}}
2020-08-13 08:12:57 +00:00
</view>
<home></home>
</view>
</template>
<script>
import home from '@/components/home';
2023-08-28 13:03:42 +00:00
import { mapGetters } from "vuex";
import * as LevelApi from '@/api/member/level';
import dayjs from '@/plugin/dayjs/dayjs.min.js';
export default {
2020-08-13 08:12:57 +00:00
components: {
home
},
computed: mapGetters(['userInfo']),
2020-08-13 08:12:57 +00:00
data() {
return {
levelInfo: '',
2023-08-28 13:03:42 +00:00
levelList: [], // 会员等级列表
current: 0, // 当前等级的经验
2020-08-13 08:12:57 +00:00
widthLen: 0,
2023-08-28 13:03:42 +00:00
2020-08-13 08:12:57 +00:00
loading: false,
loadend: false,
2023-08-28 13:03:42 +00:00
loadTitle: '加载更多', // 提示语
2020-08-13 08:12:57 +00:00
page: 1,
limit: 20,
expList: []
};
},
onLoad() {
2020-08-13 08:12:57 +00:00
this.getInfo();
this.getlevelList();
},
methods: {
2023-08-28 13:03:42 +00:00
/**
* 获得会员等级列表
*/
2020-08-13 08:12:57 +00:00
getInfo: function() {
2023-08-28 13:03:42 +00:00
LevelApi.getLevelList().then(res => {
let levelList = res.data;
2023-08-28 13:03:42 +00:00
this.levelList = levelList;
// 获得当前等级对应的经验
let list = []
levelList.map((item, index) => {
2023-08-28 13:03:42 +00:00
if (item.experience <= this.userInfo.experience) {
2020-08-13 08:12:57 +00:00
list.push(item.experience)
}
})
2023-08-28 13:03:42 +00:00
const maxn = Math.max.apply(null, list);
this.current = maxn;
2020-08-13 08:12:57 +00:00
// 解决len取的值没有时
2023-08-28 13:03:42 +00:00
const levelListLen = levelList[list.length] ? levelList[list.length] : levelList[list.length - 1];
2020-08-13 08:12:57 +00:00
// 解决除数不能为0
2023-08-28 13:03:42 +00:00
const divisor = levelListLen.experience - maxn ? levelListLen.experience - maxn : 1;
2020-08-13 08:12:57 +00:00
// 每小格所占的百分比
2023-08-28 13:03:42 +00:00
const per = (this.userInfo.experience - maxn) / divisor / levelList.length;
this.widthLen = ((list.length - 0.5) / (levelList.length)) * 100 + per * 100
}).catch(res => {
return this.$util.Tips({
title: res
2020-08-13 08:12:57 +00:00
});
})
},
2023-08-28 13:03:42 +00:00
/**
* 获得经验记录
*/
2020-08-13 08:12:57 +00:00
getlevelList: function() {
2023-08-28 13:03:42 +00:00
if (this.loadend || this.loading) {
return false;
}
LevelApi.getExperienceRecordPage({
pageNo: this.page,
pageSize: this.limit
2020-08-13 08:12:57 +00:00
}).then(res => {
2023-08-28 13:03:42 +00:00
const list = res.data.list;
const loadend = list.length < this.limit;
let expList = this.$util.SplitArray(list, this.expList);
this.$set(this, 'expList', expList);
this.loadend = loadend;
this.loadTitle = loadend ? '我也是有底线的' : '加载更多';
this.page = this.page + 1;
this.loading = false;
2020-08-13 08:12:57 +00:00
}).catch(err => {
2023-08-28 13:03:42 +00:00
this.loading = false;
this.loadTitle = '加载更多';
2020-08-13 08:12:57 +00:00
});
2023-08-28 13:03:42 +00:00
},
formatDate: function(date) {
return dayjs(date).format("YYYY-MM-DD HH:mm:ss");
}
2020-08-13 08:12:57 +00:00
},
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: 6rpx 18rpx;
2020-08-13 08:12:57 +00:00
border: 1px solid rgba(250, 226, 193, 1);
border-radius: 20rpx;
font-size: 18rpx;
margin-left: 15rpx;
display: flex;
align-items: center;
2020-08-13 08:12:57 +00:00
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-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;
overflow: hidden;
2020-08-13 08:12:57 +00:00
.bar {
width: 630rpx;
.spotw {
2020-08-13 08:12:57 +00:00
width: 96rpx;
}
2020-08-13 08:12:57 +00:00
.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;
2020-08-13 08:12:57 +00:00
.text {
.name {
font-size: 28rpx;
color: #282828;
}
.data {
color: #999;
font-size: 24rpx;
}
}
.num {
font-size: 32rpx;
color: $theme-color;
2020-08-13 08:12:57 +00:00
}
.on {
color: #16AC57;
2020-08-13 08:12:57 +00:00
}
}
}
}
}
</style>