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/activity/service/ActivityService.java |   31 +++++++++++++++++++++++++++++--
 1 files changed, 29 insertions(+), 2 deletions(-)

diff --git a/backend/src/main/java/com/rongyichuang/activity/service/ActivityService.java b/backend/src/main/java/com/rongyichuang/activity/service/ActivityService.java
index 75bebca..845d515 100644
--- a/backend/src/main/java/com/rongyichuang/activity/service/ActivityService.java
+++ b/backend/src/main/java/com/rongyichuang/activity/service/ActivityService.java
@@ -60,11 +60,18 @@
     /**
      * 鍒嗛〉鏌ヨ姣旇禌鍒楄〃
      */
-    public PageResponse<ActivityResponse> findActivities(PageRequest pageRequest, String name) {
+    public PageResponse<ActivityResponse> findActivities(PageRequest pageRequest, String name, Integer state) {
         Pageable pageable = pageRequest.toPageable();
         Page<Activity> page;
 
-        if (StringUtils.hasText(name)) {
+        boolean hasName = StringUtils.hasText(name);
+        if (state != null) {
+            if (hasName) {
+                page = activityRepository.findByPidAndStateAndNameContainingOrderByCreateTimeDesc(0L, state, name, pageable);
+            } else {
+                page = activityRepository.findByPidAndStateOrderByCreateTimeDesc(0L, state, pageable);
+            }
+        } else if (hasName) {
             page = activityRepository.findByPidAndNameContainingOrderByCreateTimeDesc(0L, name, pageable);
         } else {
             // 鏌ヨ鎵�鏈変富娲诲姩锛坧id = 0锛�
@@ -90,6 +97,15 @@
                 return response;
             })
             .collect(Collectors.toList());
+
+        // 璋冭瘯锛氭墦鍗拌繑鍥炵粰鍓嶇鐨勫搷搴斿璞′腑鐨勬姤鍚嶆埅姝�
+        try {
+            content.stream().limit(10).forEach(r ->
+                log.info("Response(id={}, name={}) signupDeadline={}, matchTime={}", r.getId(), r.getName(), r.getSignupDeadline(), r.getMatchTime())
+            );
+        } catch (Exception e) {
+            log.warn("鎵撳嵃ActivityResponse鏃ュ織澶辫触: {}", e.getMessage());
+        }
         
         return new PageResponse<>(content, page.getTotalElements(), page.getNumber(), page.getSize());
     }
@@ -353,6 +369,17 @@
         }
         return false;
     }
+
+    public boolean updateActivityState(Long id, Integer state) {
+        Optional<Activity> activityOpt = activityRepository.findById(id);
+        if (activityOpt.isPresent()) {
+            Activity activity = activityOpt.get();
+            activity.setState(state);
+            activityRepository.save(activity);
+            return true;
+        }
+        return false;
+    }
     
     /**
      * 鑾峰彇鎵�鏈夋湁鏁堜富姣旇禌锛堢敤浜庝笅鎷夐�夋嫨锛�

--
Gitblit v1.8.0