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 |   40 +++++++++++++++++++++++++++++++++++++---
 1 files changed, 37 insertions(+), 3 deletions(-)

diff --git a/web/src/components/PlayerInfoCard.vue b/web/src/components/PlayerInfoCard.vue
index 88f82e4..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>
@@ -35,13 +37,35 @@
         <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: {
@@ -56,6 +80,16 @@
   }
 })
 
+// 鍝嶅簲寮忔暟鎹�
+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