From c4a9cad1c50e89365e2a58b50e259af642ed3b8c Mon Sep 17 00:00:00 2001 From: Codex Assistant <codex@example.com> Date: 星期二, 07 十月 2025 16:12:20 +0800 Subject: [PATCH] feat(review): 调整评审详情展示顺序与样式,描述支持多行,项目信息列宽40/60 fix(auth): 登录页与首页循环跳转保护;api.ts 在登录页不再重定向;401分支在登录页不跳转 fix(router): /login 放行策略优化,避免死循环;评审列表跳转到 /project-review/:id/detail fix(frontend): 补齐 utils/appConfig.ts,避免启动白屏 fix(review): 详情页提交评分缺少stageId时回退使用项目详情的stageId feat(backend): ActivityPlayerDetailResponse.playerInfo 补充 avatarUrl/avatar,服务组装时填充用户头像 chore(dev): 启动脚本注入本地JWT密钥,重启前后端 --- web/src/components/PlayerInfoCard.vue | 49 ++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 46 insertions(+), 3 deletions(-) diff --git a/web/src/components/PlayerInfoCard.vue b/web/src/components/PlayerInfoCard.vue index d3bd64d..8e9765d 100644 --- a/web/src/components/PlayerInfoCard.vue +++ b/web/src/components/PlayerInfoCard.vue @@ -9,6 +9,8 @@ :size="80" :src="playerInfo.avatarUrl" :style="{ backgroundColor: avatarBgColor }" + class="clickable-avatar" + @click="handleAvatarClick" > {{ playerInfo.name ? playerInfo.name.charAt(0) : '?' }} </el-avatar> @@ -26,27 +28,68 @@ <!-- 璇︾粏淇℃伅 --> <div class="detail-info"> + <div v-if="regionInfo" class="info-item"> + <label>鎵�灞炲尯鍩燂細</label> + <p>{{ regionInfo.fullPath || regionInfo.name || '鏈缃�' }}</p> + </div> <div v-if="playerInfo.description" class="info-item"> <label>涓汉绠�浠嬶細</label> <p>{{ playerInfo.description }}</p> </div> </div> + + <!-- 澶村儚棰勮瀵硅瘽妗� --> + <el-dialog + v-model="previewVisible" + title="澶村儚棰勮" + width="500px" + :show-close="true" + center + > + <div class="avatar-preview-container"> + <img + v-if="playerInfo.avatarUrl" + :src="playerInfo.avatarUrl" + class="preview-image" + alt="澶村儚棰勮" + /> + <div v-else class="no-avatar"> + <el-icon size="80"><Picture /></el-icon> + <p>鏆傛棤澶村儚</p> + </div> + </div> + </el-dialog> </div> </template> <script setup> -import { computed } from 'vue' -import { ElAvatar, ElIcon } from 'element-plus' -import { Phone } from '@element-plus/icons-vue' +import { computed, ref } from 'vue' +import { ElAvatar, ElIcon, ElDialog } from 'element-plus' +import { Phone, Picture } from '@element-plus/icons-vue' const props = defineProps({ playerInfo: { type: Object, required: true, default: () => ({}) + }, + regionInfo: { + type: Object, + required: false, + default: () => null } }) +// 鍝嶅簲寮忔暟鎹� +const previewVisible = ref(false) + +// 澶村儚鐐瑰嚮澶勭悊 +const handleAvatarClick = () => { + if (props.playerInfo.avatarUrl) { + previewVisible.value = true + } +} + // 鏍规嵁濮撳悕鐢熸垚澶村儚鑳屾櫙鑹� const avatarBgColor = computed(() => { if (!props.playerInfo.name) return '#409EFF' -- Gitblit v1.8.0