update:vip完成
This commit is contained in:
@@ -102,6 +102,8 @@ const buildDefaultMyData = () => ({
|
||||
userId: user.value.id,
|
||||
name: user.value.nickName,
|
||||
avatar: user.value.avatar,
|
||||
vip: user.value.vip,
|
||||
sVip: user.value.sVip,
|
||||
totalScore: 0,
|
||||
mvpCount: 0,
|
||||
tenRings: 0,
|
||||
@@ -154,6 +156,15 @@ const getRankUnit = (index = selectedIndex.value) => {
|
||||
return "次";
|
||||
};
|
||||
|
||||
const isMember = (item = {}) => item.vip === true || item.sVip === true;
|
||||
|
||||
const getMemberNicknameClass = (item = {}) => [
|
||||
"rank-list-player-name",
|
||||
"member-nickname",
|
||||
item.vip === true && item.sVip !== true ? "member-nickname--vip" : "",
|
||||
item.sVip === true ? "member-nickname--svip" : "",
|
||||
];
|
||||
|
||||
// 统一设置页面当前的视觉滚动状态,避免吸顶和顶部背景不同步。
|
||||
const syncScrollVisualState = (scrollTop = 0) => {
|
||||
currentScrollTop.value = scrollTop;
|
||||
@@ -441,7 +452,13 @@ const measureTabsMetrics = () => {
|
||||
</view>
|
||||
<Avatar :src="item.avatar" />
|
||||
<view class="rank-item-content">
|
||||
<text class="truncate">{{ item.name }}</text>
|
||||
<view v-if="isMember(item)" :class="getMemberNicknameClass(item)">
|
||||
<text class="member-nickname__text">{{ item.name }}</text>
|
||||
<text v-if="item.sVip === true" class="member-nickname__shine">
|
||||
{{ item.name }}
|
||||
</text>
|
||||
</view>
|
||||
<text v-else class="rank-list-player-name truncate">{{ item.name }}</text>
|
||||
<text>{{ formatLevelText(item) }}</text>
|
||||
</view>
|
||||
<text class="rank-item-integral">
|
||||
@@ -479,7 +496,23 @@ const measureTabsMetrics = () => {
|
||||
<text>{{ getDisplayMyRank(currentMyData) }}</text>
|
||||
<Avatar :src="currentMyData.avatar || user.avatar" />
|
||||
<view class="rank-item-content">
|
||||
<text class="truncate">{{ currentMyData.name || user.nickName }}</text>
|
||||
<view
|
||||
v-if="isMember(currentMyData)"
|
||||
:class="getMemberNicknameClass(currentMyData)"
|
||||
>
|
||||
<text class="member-nickname__text">
|
||||
{{ currentMyData.name || user.nickName }}
|
||||
</text>
|
||||
<text
|
||||
v-if="currentMyData.sVip === true"
|
||||
class="member-nickname__shine"
|
||||
>
|
||||
{{ currentMyData.name || user.nickName }}
|
||||
</text>
|
||||
</view>
|
||||
<text v-else class="rank-list-player-name truncate">
|
||||
{{ currentMyData.name || user.nickName }}
|
||||
</text>
|
||||
<text>{{ formatLevelText(currentMyData) }}</text>
|
||||
</view>
|
||||
<text class="rank-item-integral">
|
||||
@@ -653,6 +686,18 @@ const measureTabsMetrics = () => {
|
||||
width: 120px;
|
||||
}
|
||||
|
||||
.rank-list-player-name {
|
||||
color: #fff;
|
||||
font-size: 14px;
|
||||
margin-bottom: 3px;
|
||||
width: 120px;
|
||||
}
|
||||
|
||||
.rank-list-player-name .member-nickname__text,
|
||||
.rank-list-player-name .member-nickname__shine {
|
||||
font-size: 14px;
|
||||
}
|
||||
|
||||
.rank-list-item > text:last-child {
|
||||
margin-right: 10px;
|
||||
width: 56px;
|
||||
|
||||
Reference in New Issue
Block a user