update:vip完成
This commit is contained in:
@@ -92,6 +92,14 @@ const mvpTeam = computed(() => {
|
||||
return blueTeamPlayers.value.some((p) => p.id === mvpPlayer.value.id) ? 1 : 2;
|
||||
});
|
||||
|
||||
const isMember = (player = {}) => player.vip === true || player.sVip === true;
|
||||
|
||||
const getMemberNicknameClass = (player = {}) => [
|
||||
"member-nickname",
|
||||
player.vip === true && player.sVip !== true ? "member-nickname--vip" : "",
|
||||
player.sVip === true ? "member-nickname--svip" : "",
|
||||
];
|
||||
|
||||
/**
|
||||
* 激励语图片 URL(在 onLoad 中确定 ifWin 后赋值,避免 Math.random 放在 computed 里产生缓存不一致问题)
|
||||
*/
|
||||
@@ -128,6 +136,8 @@ const meleeRankList = computed(() => {
|
||||
id: p.id,
|
||||
avatar: p.avatar || "",
|
||||
name: p.name || "",
|
||||
vip: p.vip,
|
||||
sVip: p.sVip,
|
||||
// rank_lvl 字段可能缺失,缺失时显示空字符串,避免 getLvlName(undefined) 返回错误段位名
|
||||
lvlName: p.rank_lvl != null ? getLvlName(p.rank_lvl) : "",
|
||||
totalRing: resultItem.totalRing ?? 0,
|
||||
@@ -332,7 +342,20 @@ function goBack() {
|
||||
<view class="team-players team-players-blue">
|
||||
<view v-for="p in blueTeamPlayers" :key="p.id" class="player-item">
|
||||
<Avatar :src="p.avatar" :size="34" borderColor="#8FB4FD" />
|
||||
<text class="player-name player-name-blue">{{ p.name }}</text>
|
||||
<view
|
||||
v-if="isMember(p)"
|
||||
:class="[
|
||||
'player-name',
|
||||
'player-name-blue',
|
||||
...getMemberNicknameClass(p),
|
||||
]"
|
||||
>
|
||||
<text class="member-nickname__text">{{ p.name }}</text>
|
||||
<text v-if="p.sVip === true" class="member-nickname__shine">
|
||||
{{ p.name }}
|
||||
</text>
|
||||
</view>
|
||||
<text v-else class="player-name player-name-blue">{{ p.name }}</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
@@ -340,7 +363,20 @@ function goBack() {
|
||||
<view class="team-players team-players-red">
|
||||
<view v-for="p in redTeamPlayers" :key="p.id" class="player-item">
|
||||
<Avatar :src="p.avatar" :size="34" borderColor="#E67470" />
|
||||
<text class="player-name player-name-red">{{ p.name }}</text>
|
||||
<view
|
||||
v-if="isMember(p)"
|
||||
:class="[
|
||||
'player-name',
|
||||
'player-name-red',
|
||||
...getMemberNicknameClass(p),
|
||||
]"
|
||||
>
|
||||
<text class="member-nickname__text">{{ p.name }}</text>
|
||||
<text v-if="p.sVip === true" class="member-nickname__shine">
|
||||
{{ p.name }}
|
||||
</text>
|
||||
</view>
|
||||
<text v-else class="player-name player-name-red">{{ p.name }}</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
@@ -385,7 +421,16 @@ function goBack() {
|
||||
:size="53"
|
||||
:borderColor="mvpTeam === 1 ? '#5FADFF' : '#FF6060'"
|
||||
/>
|
||||
<text class="mvp-name">{{ mvpPlayer.name }}</text>
|
||||
<view
|
||||
v-if="isMember(mvpPlayer)"
|
||||
:class="['mvp-name', ...getMemberNicknameClass(mvpPlayer)]"
|
||||
>
|
||||
<text class="member-nickname__text">{{ mvpPlayer.name }}</text>
|
||||
<text v-if="mvpPlayer.sVip === true" class="member-nickname__shine">
|
||||
{{ mvpPlayer.name }}
|
||||
</text>
|
||||
</view>
|
||||
<text v-else class="mvp-name">{{ mvpPlayer.name }}</text>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
@@ -433,7 +478,16 @@ function goBack() {
|
||||
|
||||
<!-- 昵称 + 段位 -->
|
||||
<view class="rank-player-info">
|
||||
<text class="rank-player-name">{{ item.name }}</text>
|
||||
<view
|
||||
v-if="isMember(item)"
|
||||
:class="['rank-player-name', ...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-player-name">{{ item.name }}</text>
|
||||
<text class="rank-player-lvl">{{ item.lvlName }}</text>
|
||||
</view>
|
||||
|
||||
@@ -613,6 +667,12 @@ function goBack() {
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.player-name .member-nickname__text,
|
||||
.player-name .member-nickname__shine {
|
||||
font-size: 22rpx;
|
||||
font-weight: 400;
|
||||
}
|
||||
|
||||
/* ---- 得分行 ---- */
|
||||
.vs-scores-row {
|
||||
position: relative;
|
||||
@@ -752,6 +812,11 @@ function goBack() {
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.mvp-name .member-nickname__text,
|
||||
.mvp-name .member-nickname__shine {
|
||||
font-size: 24rpx;
|
||||
}
|
||||
|
||||
/* ============================
|
||||
查看完整成绩链接
|
||||
============================ */
|
||||
@@ -1072,6 +1137,12 @@ function goBack() {
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.rank-player-name .member-nickname__text,
|
||||
.rank-player-name .member-nickname__shine {
|
||||
font-size: 28rpx;
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
.rank-player-lvl {
|
||||
font-size: 22rpx;
|
||||
color: rgba(255, 255, 255, 0.5);
|
||||
|
||||
Reference in New Issue
Block a user