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密钥,重启前后端 --- backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java | 34 +++++++++++++++++++++++++++++++++- 1 files changed, 33 insertions(+), 1 deletions(-) diff --git a/backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java b/backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java index 014519b..419dcbe 100644 --- a/backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java +++ b/backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java @@ -8,6 +8,7 @@ import java.util.List; import java.util.Optional; +import java.time.LocalDateTime; /** * 娲诲姩閫夋墜Repository鎺ュ彛 @@ -90,6 +91,32 @@ List<ActivityPlayer> findTopRankedPlayers(@Param("activityId") Long activityId); /** + * 缁熻鏈�杩戞姤鍚嶈秼鍔匡紙浠呯涓�闃舵锛宻tate鍖呭惈寰呭鏍镐笌閫氳繃锛� + */ + @Query(value = "SELECT DATE(ap.create_time) AS signup_date, COUNT(*) AS total " + + "FROM t_activity_player ap " + + "JOIN t_activity stage ON stage.id = ap.stage_id " + + "WHERE stage.sort_order = 1 AND stage.state = 1 " + + " AND ap.state IN (0, 1) " + + " AND ap.create_time >= :startDate " + + "GROUP BY DATE(ap.create_time) " + + "ORDER BY signup_date", nativeQuery = true) + List<Object[]> countFirstStageRegistrationsByDate(@Param("startDate") LocalDateTime startDate); + + /** + * 缁熻鍚勫尯鍩熸姤鍚嶆暟閲忥紙浠呯涓�闃舵锛宻tate鍖呭惈寰呭鏍镐笌閫氳繃锛� + */ + @Query(value = "SELECT ap.region_id, r.name, r.leaf_flag, COUNT(*) AS total " + + "FROM t_activity_player ap " + + "JOIN t_activity stage ON stage.id = ap.stage_id " + + "LEFT JOIN t_region r ON r.id = ap.region_id " + + "WHERE stage.sort_order = 1 AND stage.state = 1 " + + " AND ap.state IN (0, 1) " + + "GROUP BY ap.region_id, r.name, r.leaf_flag " + + "ORDER BY total DESC", nativeQuery = true) + List<Object[]> countFirstStageRegistrationsByRegion(); + + /** * 缁熻鎸囧畾鐘舵�佺殑鍙傝禌閫夋墜鏁伴噺 */ long countByState(Integer state); @@ -124,4 +151,9 @@ * 妫�鏌ラ�夋墜鏄惁宸插湪鎸囧畾闃舵鎶ュ悕 */ boolean existsByStageIdAndPlayerId(Long stageId, Long playerId); -} \ No newline at end of file + + /** + * 鏍规嵁闃舵鍜岄�夋墜鏌ヨ鎶ュ悕璁板綍 + */ + Optional<ActivityPlayer> findByStageIdAndPlayerId(Long stageId, Long playerId); +} -- Gitblit v1.8.0