2020-08-13 08:12:57 +00:00
|
|
|
<template>
|
|
|
|
<view>
|
|
|
|
<view class="PromoterRank">
|
|
|
|
<view class="redBg bg-color">
|
|
|
|
<view class="header">
|
|
|
|
<view class="nav acea-row row-center-wrapper">
|
2023-09-04 16:11:57 +00:00
|
|
|
<view class="item" :class="active === index ? 'font-color' : ''" v-for="(item, index) in navList"
|
|
|
|
:key="index" @click="switchTap(index)">
|
2020-08-13 08:12:57 +00:00
|
|
|
{{ item }}
|
|
|
|
</view>
|
|
|
|
</view>
|
2023-09-04 16:11:57 +00:00
|
|
|
<!-- top3 排名 -->
|
2020-08-13 08:12:57 +00:00
|
|
|
<view class="rank acea-row row-bottom row-around">
|
2023-09-05 15:49:24 +00:00
|
|
|
<view class="item" v-show="Two.id">
|
2020-08-13 08:12:57 +00:00
|
|
|
<view class="pictrue">
|
|
|
|
<image :src="Two.avatar"></image>
|
|
|
|
</view>
|
|
|
|
<view class="name line1">{{Two.nickname}}</view>
|
2023-09-04 16:11:57 +00:00
|
|
|
<view class="num">{{ Two.brokerageUserCount }}人</view>
|
2020-08-13 08:12:57 +00:00
|
|
|
</view>
|
2023-09-05 15:49:24 +00:00
|
|
|
<view class="item" v-show="One.id">
|
2020-08-13 08:12:57 +00:00
|
|
|
<view class="pictrue">
|
|
|
|
<image :src="One.avatar"></image>
|
|
|
|
</view>
|
|
|
|
<view class="name line1">{{One.nickname}}</view>
|
2023-09-04 16:11:57 +00:00
|
|
|
<view class="num">{{ One.brokerageUserCount }}人</view>
|
2020-08-13 08:12:57 +00:00
|
|
|
</view>
|
2023-09-05 15:49:24 +00:00
|
|
|
<view class="item" v-show="Three.id">
|
2020-08-13 08:12:57 +00:00
|
|
|
<view class="pictrue">
|
|
|
|
<image :src="Three.avatar"></image>
|
|
|
|
</view>
|
|
|
|
<view class="name line1">{{Three.nickname}}</view>
|
2023-09-04 16:11:57 +00:00
|
|
|
<view class="num">{{ Three.brokerageUserCount }}人</view>
|
2020-08-13 08:12:57 +00:00
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
2023-09-04 16:11:57 +00:00
|
|
|
<!-- 其它排名 -->
|
2020-08-13 08:12:57 +00:00
|
|
|
<view class="list" v-if="rankList.length">
|
|
|
|
<view class="item acea-row row-between-wrapper" v-for="(item,index) in rankList" :key="index">
|
2023-09-04 16:11:57 +00:00
|
|
|
<view class="num">{{ index + 4 }}</view>
|
2020-08-13 08:12:57 +00:00
|
|
|
<view class="picTxt acea-row row-between-wrapper">
|
|
|
|
<view class="pictrue">
|
|
|
|
<image :src="item.avatar"></image>
|
|
|
|
</view>
|
|
|
|
<view class="text line1">{{item.nickname}}</view>
|
|
|
|
</view>
|
2023-09-04 16:11:57 +00:00
|
|
|
<view class="people font-color">{{ item.brokerageUserCount }}人</view>
|
2020-08-13 08:12:57 +00:00
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
</view>
|
|
|
|
<home></home>
|
|
|
|
</view>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2023-09-04 16:11:57 +00:00
|
|
|
import { toLogin } from '@/libs/login.js';
|
|
|
|
import { mapGetters } from "vuex";
|
2020-08-13 08:12:57 +00:00
|
|
|
import home from '@/components/home';
|
2023-09-05 13:36:10 +00:00
|
|
|
import * as BrokerageAPI from '@/api/trade/brokerage.js'
|
2023-09-04 16:11:57 +00:00
|
|
|
import dayjs from "@/plugin/dayjs/dayjs.min.js";
|
2023-09-05 13:36:10 +00:00
|
|
|
import * as DateUtil from '@/utils/date.js';
|
|
|
|
import * as Util from '@/utils/util.js';
|
2023-09-04 16:11:57 +00:00
|
|
|
export default {
|
2020-08-13 08:12:57 +00:00
|
|
|
components: {
|
|
|
|
home
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
navList: ["周榜", "月榜"],
|
|
|
|
active: 0,
|
|
|
|
page: 1,
|
|
|
|
limit: 10,
|
|
|
|
type: 'week',
|
|
|
|
loading: false,
|
|
|
|
loadend: false,
|
|
|
|
rankList: [],
|
2023-09-04 16:11:57 +00:00
|
|
|
times: [],
|
|
|
|
|
|
|
|
One: {}, // 排名第一
|
|
|
|
Two: {}, // 排名第二
|
|
|
|
Three: {}, // 排名第三
|
2020-08-13 08:12:57 +00:00
|
|
|
};
|
|
|
|
},
|
|
|
|
computed: mapGetters(['isLogin']),
|
2021-03-19 10:26:43 +00:00
|
|
|
watch:{
|
|
|
|
isLogin:{
|
2023-09-04 16:11:57 +00:00
|
|
|
handler:function(newV, oldV) {
|
|
|
|
if (newV) {
|
2021-03-19 10:26:43 +00:00
|
|
|
this.getRanklist();
|
|
|
|
}
|
|
|
|
},
|
2023-09-04 16:11:57 +00:00
|
|
|
deep: true
|
2021-03-19 10:26:43 +00:00
|
|
|
}
|
|
|
|
},
|
2020-08-13 08:12:57 +00:00
|
|
|
onLoad() {
|
2023-09-04 16:11:57 +00:00
|
|
|
if (!this.isLogin) {
|
|
|
|
toLogin();
|
|
|
|
return;
|
2020-08-13 08:12:57 +00:00
|
|
|
}
|
2023-09-04 16:11:57 +00:00
|
|
|
this.calculateTimes();
|
|
|
|
this.getRanklist();
|
|
|
|
},
|
2020-08-13 08:12:57 +00:00
|
|
|
methods: {
|
|
|
|
getRanklist: function() {
|
2023-09-04 16:11:57 +00:00
|
|
|
if (this.loadend || this.loading) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
this.loading = true;
|
2023-09-05 13:36:10 +00:00
|
|
|
BrokerageAPI.getBrokerageUserRankPageByUserCount({
|
2023-09-04 16:11:57 +00:00
|
|
|
pageNo: this.page,
|
|
|
|
pageSize: this.limit,
|
|
|
|
'times[0]': this.times[0],
|
|
|
|
'times[1]': this.times[1],
|
2020-08-13 08:12:57 +00:00
|
|
|
}).then(res => {
|
2023-09-04 16:11:57 +00:00
|
|
|
let list = res.data.list;
|
|
|
|
this.rankList.push.apply(this.rankList, list);
|
|
|
|
if (this.page === 1) {
|
|
|
|
this.One = this.rankList.shift() || {};
|
|
|
|
this.Two = this.rankList.shift() || {};
|
|
|
|
this.Three = this.rankList.shift() || {};
|
2020-08-13 08:12:57 +00:00
|
|
|
}
|
2023-09-04 16:11:57 +00:00
|
|
|
this.loadend = list.length < this.limit;
|
|
|
|
this.loading = false;
|
|
|
|
this.$set(this, 'rankList', this.rankList);
|
2020-08-13 08:12:57 +00:00
|
|
|
}).catch(err => {
|
2023-09-04 16:11:57 +00:00
|
|
|
this.loading = false;
|
2020-08-13 08:12:57 +00:00
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
switchTap: function(index) {
|
2023-09-04 16:11:57 +00:00
|
|
|
if (this.active === index) {
|
|
|
|
return;
|
|
|
|
}
|
2020-08-13 08:12:57 +00:00
|
|
|
this.active = index;
|
2023-09-04 16:11:57 +00:00
|
|
|
// week
|
2020-08-13 08:12:57 +00:00
|
|
|
this.type = index ? 'month' : 'week';
|
|
|
|
this.page = 1;
|
|
|
|
this.loadend = false;
|
|
|
|
this.$set(this, 'rankList', []);
|
|
|
|
this.Two = {};
|
|
|
|
this.One = {};
|
|
|
|
this.Three = {};
|
2023-09-04 16:11:57 +00:00
|
|
|
this.calculateTimes();
|
|
|
|
this.getRanklist();
|
2020-08-13 08:12:57 +00:00
|
|
|
},
|
2023-09-04 16:11:57 +00:00
|
|
|
calculateTimes: function() {
|
2023-09-05 13:36:10 +00:00
|
|
|
let times;
|
2023-09-04 16:11:57 +00:00
|
|
|
if (this.type === 'week') {
|
2023-09-05 13:36:10 +00:00
|
|
|
times = DateUtil.getWeekTimes();
|
2023-09-04 16:11:57 +00:00
|
|
|
} else {
|
2023-09-05 13:36:10 +00:00
|
|
|
times = DateUtil.getMonthTimes();
|
2023-09-04 16:11:57 +00:00
|
|
|
}
|
2023-09-05 13:36:10 +00:00
|
|
|
this.times = [ this.formatDate(times[0]), this.formatDate(times[1]) ]
|
2023-09-04 16:11:57 +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.getRanklist();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<style scoped lang="scss">
|
|
|
|
.PromoterRank .redBg {
|
|
|
|
padding: 45rpx 0 30rpx 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header {
|
|
|
|
background: url("
|
|
|
|
width: 100%;
|
|
|
|
height: 460rpx;
|
|
|
|
background-size: 100% 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .nav {
|
|
|
|
width: 450rpx;
|
|
|
|
height: 66rpx;
|
|
|
|
border: 1px solid #fff;
|
|
|
|
border-radius: 33rpx;
|
|
|
|
font-size: 30rpx;
|
|
|
|
color: #fff;
|
|
|
|
margin: 0 auto;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .nav .item {
|
|
|
|
width: 223rpx;
|
|
|
|
height: 100%;
|
|
|
|
text-align: center;
|
|
|
|
line-height: 60rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .nav .item.font-color:nth-of-type(1) {
|
|
|
|
background-color: #fff;
|
|
|
|
border-radius: 33rpx 0 0 33rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .nav .item.font-color:nth-of-type(2) {
|
|
|
|
background-color: #fff;
|
|
|
|
border-radius: 0 33rpx 33rpx 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank {
|
|
|
|
padding: 0 20rpx;
|
|
|
|
margin-top: 30rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank .item .pictrue {
|
|
|
|
background: url("
|
|
|
|
background-size: 100% 100%;
|
|
|
|
width: 136rpx;
|
|
|
|
height: 177rpx;
|
|
|
|
position: relative;
|
|
|
|
margin: 0 auto;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank .item .pictrue image {
|
|
|
|
position: absolute;
|
|
|
|
width: 130rpx;
|
|
|
|
height: 130rpx;
|
|
|
|
display: block;
|
|
|
|
bottom: 2rpx;
|
|
|
|
border-radius: 50%;
|
|
|
|
left: 50%;
|
|
|
|
margin-left: -65rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank .item:nth-of-type(2) .pictrue {
|
|
|
|
background-image: url("
|
|
|
|
width: 156rpx;
|
|
|
|
height: 205rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank .item:nth-of-type(2) .pictrue image {
|
|
|
|
width: 150rpx;
|
|
|
|
height: 150rpx;
|
|
|
|
margin-left: -75rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank .item:nth-of-type(3) .pictrue {
|
|
|
|
background-image: url("
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank .item:nth-of-type(3) .pictrue image {
|
|
|
|
margin-left: -64rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank .item .name {
|
|
|
|
font-size: 30rpx;
|
|
|
|
color: #fff;
|
|
|
|
margin-top: 22rpx;
|
|
|
|
text-align: center;
|
|
|
|
width: 170rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .header .rank .item .num {
|
|
|
|
font-size: 30rpx;
|
|
|
|
color: #fff;
|
|
|
|
text-align: center;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .list {
|
|
|
|
width: 710rpx;
|
|
|
|
background-color: #fff;
|
|
|
|
border-radius: 20rpx;
|
|
|
|
margin: -60rpx auto 0 auto;
|
|
|
|
padding: 0 30rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .list .item {
|
|
|
|
border-bottom: 1px solid #f3f3f3;
|
|
|
|
height: 101rpx;
|
|
|
|
font-size: 28rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .list .item .num {
|
|
|
|
color: #666;
|
|
|
|
width: 70rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .list .item .picTxt {
|
|
|
|
width: 350rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .list .item .picTxt .pictrue {
|
|
|
|
width: 68rpx;
|
|
|
|
height: 68rpx;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .list .item .picTxt .pictrue image {
|
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
|
|
|
display: block;
|
|
|
|
border-radius: 50%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .list .item .picTxt .text {
|
|
|
|
width: 262rpx;
|
|
|
|
color: #333;
|
|
|
|
}
|
|
|
|
|
|
|
|
.PromoterRank .list .item .people {
|
|
|
|
width: 175rpx;
|
|
|
|
text-align: right;
|
|
|
|
}
|
|
|
|
</style>
|