From c3a79d24dc10551b7a7830f1d11f66e3adb1430e Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Sat, 11 Oct 2025 09:54:11 +0800
Subject: [PATCH] feat(ai): 实现报告列表流式传输功能

---
 src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkStreamServiceImpl.java |   35 ++++++++++++++++++++++++++++++-----
 1 files changed, 30 insertions(+), 5 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkStreamServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkStreamServiceImpl.java
index a3a9a44..ac91786 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkStreamServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkStreamServiceImpl.java
@@ -122,15 +122,40 @@
     }
 
     @Override
-    public FebsResponse talkReportList(ApiTalkReportListDto dto) {
-        ApiTalkReportListVo apiTalkReportListDto = new ApiTalkReportListVo();
-
+    public Flux<FebsResponse> talkReportList(ApiTalkReportListDto dto) {
         String memberTalkId = dto.getMemberTalkId();
         AiMemberTalk byId = aiMemberTalkService.getById(memberTalkId);
-        apiTalkReportListDto.setAnalysis(byId.getAnalysis());
-        return new FebsResponse().success().data(apiTalkReportListDto);
+        String analysis = byId.getAnalysis();
+
+        if (StrUtil.isEmpty(analysis)) {
+            return Flux.just(new FebsResponse().success().data(""));
+        }
+
+        // 将分析报告分块,每块100个字符
+        return Flux.generate(
+            () -> 0, // 初始状态
+            (index, sink) -> {
+                int endIndex = Math.min(index + 100, analysis.length());
+                String chunk = analysis.substring(index, endIndex);
+
+                Map<String, Object> responseData = new HashMap<>();
+                responseData.put("chunk", chunk);
+                responseData.put("isLast", endIndex >= analysis.length());
+                responseData.put("progress", Math.min(100, (endIndex * 100) / analysis.length()));
+
+                sink.next(new FebsResponse().success().data(responseData));
+
+                if (endIndex >= analysis.length()) {
+                    sink.complete();
+                    return index; // 结束状态
+                }
+
+                return endIndex; // 下一次的起始索引
+            }
+        );
     }
 
+
     @Override
     public FebsResponse reload(ApiMemberTalkReloadStreamDto dto) {
 

--
Gitblit v1.9.1