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/carousel/service/CarouselService.java |   14 +++++++++-----
 1 files changed, 9 insertions(+), 5 deletions(-)

diff --git a/backend/src/main/java/com/rongyichuang/carousel/service/CarouselService.java b/backend/src/main/java/com/rongyichuang/carousel/service/CarouselService.java
index 44f072f..383077a 100644
--- a/backend/src/main/java/com/rongyichuang/carousel/service/CarouselService.java
+++ b/backend/src/main/java/com/rongyichuang/carousel/service/CarouselService.java
@@ -10,6 +10,7 @@
 import com.rongyichuang.common.dto.PageResponse;
 import com.rongyichuang.common.entity.Media;
 import com.rongyichuang.common.exception.BusinessException;
+import com.rongyichuang.common.enums.MediaTargetType;
 import com.rongyichuang.common.repository.MediaRepository;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.domain.Page;
@@ -56,8 +57,9 @@
                     .map(CarouselResponse::getId)
                     .collect(Collectors.toList());
             
-            // 鏌ヨ濯掍綋鏁伴噺锛坱argetType=4琛ㄧず杞挱鍥撅級
-            List<Object[]> mediaCountResults = mediaRepository.countByTargetTypeAndTargetIdInAndState(4, carouselIds, 1);
+            // 鏌ヨ濯掍綋鏁伴噺锛堜娇鐢ㄦ灇涓惧父閲忚〃绀鸿疆鎾浘绫诲瀷锛�
+            List<Object[]> mediaCountResults = mediaRepository.countByTargetTypeAndTargetIdInAndState(
+                MediaTargetType.CAROUSEL.getValue(), carouselIds, 1);
             Map<Long, Integer> mediaCountMap = mediaCountResults.stream()
                     .collect(Collectors.toMap(
                             result -> (Long) result[0],
@@ -84,17 +86,19 @@
         CarouselResponse response = convertToResponse(carousel);
         
         // 鏌ヨ濯掍綋鏁伴噺
-        List<Media> mediaList = mediaRepository.findByTargetTypeAndTargetIdAndState(4, id, 1);
+        List<Media> mediaList = mediaRepository.findByTargetTypeAndTargetIdAndState(
+            MediaTargetType.CAROUSEL.getValue(), id, 1);
         response.setMediaCount(mediaList.size());
         
         return response;
     }
 
     /**
-     * 鑾峰彇鎾斁鍒楄〃
+     * 鑾峰彇鎾斁鍒楄〃锛堝墠5涓級
      */
     public List<CarouselResponse> getPlayList() {
-        List<Carousel> carousels = carouselRepository.findPlayList();
+        Pageable pageable = org.springframework.data.domain.PageRequest.of(0, 5);
+        List<Carousel> carousels = carouselRepository.findPlayList(pageable);
         return carousels.stream()
                 .map(this::convertToResponse)
                 .collect(Collectors.toList());

--
Gitblit v1.8.0