2026-02-08 15:33:10 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<!-- 我的PK记录 -->
|
|
|
|
|
|
<div class="pk-record">
|
2026-02-26 13:15:19 +08:00
|
|
|
|
<div class="pk-layout">
|
|
|
|
|
|
<div class="left-panel">
|
2026-02-08 15:33:10 +08:00
|
|
|
|
<div class="demo-panel">
|
|
|
|
|
|
<!-- 选项卡 -->
|
|
|
|
|
|
<div class="tab-header">
|
|
|
|
|
|
<div
|
|
|
|
|
|
class="tab-item"
|
|
|
|
|
|
v-for="item in tabOptions"
|
|
|
|
|
|
:key="item.value"
|
|
|
|
|
|
@click="switchTab(item.value)"
|
|
|
|
|
|
:class="{ active: activeTab === item.value }"
|
|
|
|
|
|
>
|
|
|
|
|
|
<img class="tab-icon" :src="activeTab === item.value ? item.selectedIcon : item.icon" alt="" />
|
|
|
|
|
|
<span class="tab-label">{{ item.label }}</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 列表 -->
|
|
|
|
|
|
<div class="record-list" v-if="list.length > 0">
|
|
|
|
|
|
<div
|
|
|
|
|
|
v-for="(item, index) in list"
|
|
|
|
|
|
:key="index"
|
|
|
|
|
|
class="record-item"
|
|
|
|
|
|
:class="{ selected: selectedData === item }"
|
|
|
|
|
|
@click="selectRecord(item)"
|
|
|
|
|
|
>
|
|
|
|
|
|
<!-- 左侧信息 -->
|
|
|
|
|
|
<div class="record-info">
|
|
|
|
|
|
<img class="record-avatar" :src="item.anchorIconA" alt="" />
|
|
|
|
|
|
<div class="record-detail">
|
|
|
|
|
|
<div class="record-name">{{ item.anchorIdA }}</div>
|
|
|
|
|
|
<div class="record-time">PK时间: {{ formatTime(item.pkTime * 1000) }}</div>
|
|
|
|
|
|
<div class="record-coins" v-if="item.userACoins != null">
|
|
|
|
|
|
<img class="coin-icon" src="https://vv-1317974657.cos.ap-shanghai.myqcloud.com/util/gold.png" alt="" />
|
|
|
|
|
|
<span>实际金币数: {{ formatCoin(item.userACoins) }}</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- VS 图标 -->
|
|
|
|
|
|
<div class="vs-icon">
|
|
|
|
|
|
<img src="https://vv-1317974657.cos.ap-shanghai.myqcloud.com/util/session.png" alt="" />
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 右侧信息 -->
|
|
|
|
|
|
<div class="record-info right">
|
|
|
|
|
|
<div class="record-detail">
|
|
|
|
|
|
<div class="record-name">{{ item.anchorIdB }}</div>
|
|
|
|
|
|
<div class="record-time">PK时间: {{ formatTime(item.pkTime * 1000) }}</div>
|
|
|
|
|
|
<div class="record-coins" v-if="item.userBCoins != null">
|
|
|
|
|
|
<img class="coin-icon" src="https://vv-1317974657.cos.ap-shanghai.myqcloud.com/util/gold.png" alt="" />
|
|
|
|
|
|
<span>实际金币数: {{ formatCoin(item.userBCoins) }}</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<img class="record-avatar" :src="item.anchorIconB" alt="" />
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="empty-tip" v-else>您还没有PK记录!</div>
|
|
|
|
|
|
</div>
|
2026-02-26 13:15:19 +08:00
|
|
|
|
</div>
|
2026-02-08 15:33:10 +08:00
|
|
|
|
|
|
|
|
|
|
<!-- 右侧详情 -->
|
2026-02-26 13:15:19 +08:00
|
|
|
|
<div class="right-panel">
|
2026-02-08 15:33:10 +08:00
|
|
|
|
<div class="detail-panel" v-if="selectedData">
|
|
|
|
|
|
<!-- 双方头像 -->
|
|
|
|
|
|
<div class="detail-avatars">
|
|
|
|
|
|
<img class="detail-avatar" :src="selectedData.anchorIconA" alt="" />
|
|
|
|
|
|
<img class="detail-avatar" :src="selectedData.anchorIconB" alt="" />
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 总计 -->
|
|
|
|
|
|
<div class="detail-total">
|
|
|
|
|
|
<div class="total-card">
|
|
|
|
|
|
<span class="total-num">总共:{{ formatCoin(selectedData.userACoins) }}</span>
|
|
|
|
|
|
<img class="total-icon" src="https://vv-1317974657.cos.ap-shanghai.myqcloud.com/util/session.png" alt="" />
|
|
|
|
|
|
<span class="total-num">总共:{{ formatCoin(selectedData.userBCoins) }}</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 每局详情 -->
|
|
|
|
|
|
<div class="detail-rounds">
|
|
|
|
|
|
<div class="rounds-column left">
|
|
|
|
|
|
<div
|
|
|
|
|
|
v-for="(item, index) in roundDetails"
|
|
|
|
|
|
:key="'a-' + index"
|
|
|
|
|
|
class="round-item"
|
|
|
|
|
|
:class="item.anchorCoinA > item.anchorCoinB ? 'win' : 'lose'"
|
|
|
|
|
|
>
|
|
|
|
|
|
第{{ index + 1 }}回: {{ formatCoin(item.anchorCoinA) }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="rounds-column right">
|
|
|
|
|
|
<div
|
|
|
|
|
|
v-for="(item, index) in roundDetails"
|
|
|
|
|
|
:key="'b-' + index"
|
|
|
|
|
|
class="round-item"
|
|
|
|
|
|
:class="item.anchorCoinB > item.anchorCoinA ? 'win' : 'lose'"
|
|
|
|
|
|
>
|
|
|
|
|
|
第{{ index + 1 }}回: {{ formatCoin(item.anchorCoinB) }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="empty-detail" v-else>
|
|
|
|
|
|
<span>选择右侧的记录,可立即查看详细信息</span>
|
|
|
|
|
|
</div>
|
2026-02-26 13:15:19 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
2026-02-08 15:33:10 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script setup>
|
|
|
|
|
|
import { ref, onMounted } from 'vue'
|
|
|
|
|
|
import { getPkRecord, queryPkDetail } from '@/api/pk-mini'
|
|
|
|
|
|
import { getMainUserData } from '@/utils/pk-mini/storage'
|
|
|
|
|
|
import { TimestamptolocalTime } from '@/utils/pk-mini/timeConversion'
|
|
|
|
|
|
|
|
|
|
|
|
// 导入本地图片
|
|
|
|
|
|
import iconPublish from '@/assets/pk-mini/Publish.png'
|
|
|
|
|
|
import iconPublishSelected from '@/assets/pk-mini/PublishSelected.png'
|
|
|
|
|
|
import iconInvitation from '@/assets/pk-mini/Invitation.png'
|
|
|
|
|
|
import iconInvitationSelected from '@/assets/pk-mini/InvitationSelected.png'
|
|
|
|
|
|
|
|
|
|
|
|
// 获取用户 ID(兼容不同的字段名)
|
|
|
|
|
|
function getUserId(user) {
|
|
|
|
|
|
return user?.id || user?.userId || user?.uid || null
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const currentUser = ref({})
|
|
|
|
|
|
const activeTab = ref(1)
|
|
|
|
|
|
const list = ref([])
|
|
|
|
|
|
const postedList = ref([]) // 发布的PK
|
|
|
|
|
|
const invitedList = ref([]) // 邀请的PK
|
|
|
|
|
|
const selectedData = ref(null)
|
|
|
|
|
|
const roundDetails = ref([])
|
|
|
|
|
|
|
|
|
|
|
|
const tabOptions = [
|
|
|
|
|
|
{
|
|
|
|
|
|
label: '发布的PK',
|
|
|
|
|
|
value: 1,
|
|
|
|
|
|
icon: iconPublish,
|
|
|
|
|
|
selectedIcon: iconPublishSelected
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
label: '邀请的PK',
|
|
|
|
|
|
value: 2,
|
|
|
|
|
|
icon: iconInvitation,
|
|
|
|
|
|
selectedIcon: iconInvitationSelected
|
|
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
const formatTime = TimestamptolocalTime
|
|
|
|
|
|
|
|
|
|
|
|
function formatCoin(value) {
|
|
|
|
|
|
if (value == null) return '0'
|
|
|
|
|
|
if (value >= 10000) {
|
|
|
|
|
|
return (value / 10000).toFixed(1) + 'w'
|
|
|
|
|
|
} else if (value >= 1000) {
|
|
|
|
|
|
return (value / 1000).toFixed(1) + 'k'
|
|
|
|
|
|
}
|
|
|
|
|
|
return String(value)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function switchTab(value) {
|
|
|
|
|
|
activeTab.value = value
|
|
|
|
|
|
selectedData.value = null
|
|
|
|
|
|
roundDetails.value = []
|
|
|
|
|
|
list.value = value === 1 ? postedList.value : invitedList.value
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async function selectRecord(item) {
|
|
|
|
|
|
selectedData.value = item
|
|
|
|
|
|
try {
|
|
|
|
|
|
const res = await queryPkDetail({ id: item.id })
|
|
|
|
|
|
roundDetails.value = res || []
|
|
|
|
|
|
} catch (e) {
|
|
|
|
|
|
console.error('获取PK详情失败', e)
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async function loadRecords(type) {
|
|
|
|
|
|
const userId = getUserId(currentUser.value)
|
|
|
|
|
|
if (!userId) return
|
|
|
|
|
|
try {
|
|
|
|
|
|
const res = await getPkRecord({
|
|
|
|
|
|
type: type,
|
|
|
|
|
|
userId: userId,
|
|
|
|
|
|
page: 0,
|
|
|
|
|
|
size: 50
|
|
|
|
|
|
})
|
|
|
|
|
|
if (type === 1) {
|
|
|
|
|
|
postedList.value = res || []
|
|
|
|
|
|
if (activeTab.value === 1) {
|
|
|
|
|
|
list.value = postedList.value
|
|
|
|
|
|
}
|
|
|
|
|
|
} else {
|
|
|
|
|
|
invitedList.value = res || []
|
|
|
|
|
|
if (activeTab.value === 2) {
|
|
|
|
|
|
list.value = invitedList.value
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
} catch (e) {
|
|
|
|
|
|
console.error('加载PK记录失败', e)
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
onMounted(() => {
|
|
|
|
|
|
currentUser.value = getMainUserData() || {}
|
|
|
|
|
|
const userId = getUserId(currentUser.value)
|
|
|
|
|
|
|
|
|
|
|
|
console.log('[PKRecord] 当前用户数据:', currentUser.value)
|
|
|
|
|
|
console.log('[PKRecord] 解析的用户 ID:', userId)
|
|
|
|
|
|
|
|
|
|
|
|
if (userId) {
|
|
|
|
|
|
loadRecords(1)
|
|
|
|
|
|
loadRecords(2)
|
|
|
|
|
|
} else {
|
|
|
|
|
|
console.warn('[PKRecord] 未找到用户 ID,无法加载数据')
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<style scoped lang="less">
|
|
|
|
|
|
.pk-record {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-26 13:15:19 +08:00
|
|
|
|
.pk-layout {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-direction: row;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.left-panel {
|
|
|
|
|
|
flex: 1;
|
|
|
|
|
|
min-width: 0;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.right-panel {
|
|
|
|
|
|
width: 380px;
|
|
|
|
|
|
flex-shrink: 0;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
border-left: 1px solid #03aba82f;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-08 15:33:10 +08:00
|
|
|
|
.demo-panel {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab-header {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
padding: 20px 30px;
|
|
|
|
|
|
gap: 80px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab-item {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 12px;
|
|
|
|
|
|
padding: 15px 30px;
|
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
border-bottom: 3px solid transparent;
|
|
|
|
|
|
transition: all 0.3s;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab-item.active {
|
|
|
|
|
|
border-bottom-color: #03aba8;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab-icon {
|
|
|
|
|
|
width: 28px;
|
|
|
|
|
|
height: 28px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab-label {
|
|
|
|
|
|
font-size: 20px;
|
|
|
|
|
|
color: #636363;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab-item.active .tab-label {
|
|
|
|
|
|
color: #03aba8;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-list {
|
|
|
|
|
|
flex: 1;
|
|
|
|
|
|
overflow: auto;
|
|
|
|
|
|
padding: 0 20px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-item {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: space-around;
|
|
|
|
|
|
padding: 20px;
|
|
|
|
|
|
margin-bottom: 15px;
|
|
|
|
|
|
background: url('https://vv-1317974657.cos.ap-shanghai.myqcloud.com/util/PKbackground.png') no-repeat center/cover;
|
|
|
|
|
|
border-radius: 16px;
|
|
|
|
|
|
box-shadow: 0 2px 8px rgba(0,0,0,0.1);
|
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
transition: all 0.3s;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-item:hover {
|
|
|
|
|
|
transform: scale(1.02);
|
|
|
|
|
|
box-shadow: 0 4px 12px rgba(0,0,0,0.2);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-item.selected {
|
|
|
|
|
|
background-color: #fffbfa;
|
|
|
|
|
|
border: 1px solid #f4d0c9;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-info {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 15px;
|
|
|
|
|
|
width: 40%;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-info.right {
|
|
|
|
|
|
justify-content: flex-end;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-avatar {
|
|
|
|
|
|
width: 80px;
|
|
|
|
|
|
height: 80px;
|
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
|
object-fit: cover;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-detail {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
|
gap: 8px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-info.right .record-detail {
|
|
|
|
|
|
align-items: flex-end;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-name {
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-time {
|
|
|
|
|
|
font-size: 13px;
|
|
|
|
|
|
color: #999;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.record-coins {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 8px;
|
|
|
|
|
|
font-size: 13px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.coin-icon {
|
|
|
|
|
|
width: 24px;
|
|
|
|
|
|
height: 24px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.vs-icon {
|
|
|
|
|
|
width: 40px;
|
|
|
|
|
|
height: 40px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.vs-icon img {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.empty-tip {
|
|
|
|
|
|
flex: 1;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
|
color: #03aba8;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 右侧详情
|
|
|
|
|
|
.detail-panel {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
|
align-items: center;
|
2026-02-26 13:15:19 +08:00
|
|
|
|
padding: 15px;
|
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
|
overflow: hidden;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.detail-avatars {
|
|
|
|
|
|
display: flex;
|
2026-02-26 13:15:19 +08:00
|
|
|
|
gap: 20px;
|
|
|
|
|
|
margin-bottom: 12px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.detail-avatar {
|
2026-02-26 13:15:19 +08:00
|
|
|
|
width: 50px;
|
|
|
|
|
|
height: 50px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
border-radius: 50%;
|
|
|
|
|
|
object-fit: cover;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.detail-total {
|
|
|
|
|
|
width: 100%;
|
2026-02-26 13:15:19 +08:00
|
|
|
|
margin-bottom: 12px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.total-card {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: space-around;
|
2026-02-26 13:15:19 +08:00
|
|
|
|
padding: 10px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
background: linear-gradient(90deg, #e4ffff, #fff, #e4ffff);
|
|
|
|
|
|
border-radius: 30px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.total-num {
|
2026-02-26 13:15:19 +08:00
|
|
|
|
font-size: 13px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
font-weight: bold;
|
|
|
|
|
|
color: #333;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.total-icon {
|
2026-02-26 13:15:19 +08:00
|
|
|
|
width: 28px;
|
|
|
|
|
|
height: 22px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.detail-rounds {
|
|
|
|
|
|
flex: 1;
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
display: flex;
|
2026-02-26 13:15:19 +08:00
|
|
|
|
gap: 10px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.rounds-column {
|
|
|
|
|
|
flex: 1;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-direction: column;
|
2026-02-26 13:15:19 +08:00
|
|
|
|
gap: 8px;
|
|
|
|
|
|
padding: 10px;
|
|
|
|
|
|
border-radius: 12px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
overflow: auto;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.rounds-column.left {
|
|
|
|
|
|
background: #dffefc;
|
|
|
|
|
|
border: 1px solid #86e1e3;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.rounds-column.right {
|
|
|
|
|
|
background: #fbece9;
|
|
|
|
|
|
border: 1px solid #f4d0c9;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.round-item {
|
2026-02-26 13:15:19 +08:00
|
|
|
|
padding: 8px 10px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
border-radius: 8px;
|
2026-02-26 13:15:19 +08:00
|
|
|
|
font-size: 13px;
|
2026-02-08 15:33:10 +08:00
|
|
|
|
font-weight: bold;
|
|
|
|
|
|
color: #03aba8;
|
|
|
|
|
|
text-align: center;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.round-item.win {
|
|
|
|
|
|
background: #d1f6f7;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.round-item.lose {
|
|
|
|
|
|
background: #f9dfd9;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.empty-detail {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
border-left: 1px solid #03aba82f;
|
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
|
color: #03aba8;
|
|
|
|
|
|
}
|
|
|
|
|
|
</style>
|