From 23ade5c0e386c6403a9c89f264ae3d6933c756aa Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 26 Aug 2025 09:42:37 +0800
Subject: [PATCH] feat(ai): 添加题目轮播功能

---
 src/main/java/cc/mrbird/febs/ai/controller/talk/ApiAiTalkController.java |   11 +++++
 src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java      |   27 +++++++++++++
 src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java               |    2 +
 src/main/java/cc/mrbird/febs/ai/res/talk/ApiTalkQuestionVo.java          |   20 ++++++++++
 src/main/java/cc/mrbird/febs/common/configure/WebMvcConfigure.java       |    1 
 5 files changed, 61 insertions(+), 0 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/controller/talk/ApiAiTalkController.java b/src/main/java/cc/mrbird/febs/ai/controller/talk/ApiAiTalkController.java
index adf10b1..ada9ad3 100644
--- a/src/main/java/cc/mrbird/febs/ai/controller/talk/ApiAiTalkController.java
+++ b/src/main/java/cc/mrbird/febs/ai/controller/talk/ApiAiTalkController.java
@@ -12,6 +12,7 @@
 import cc.mrbird.febs.ai.res.memberTalk.ApiMemberTalkVo;
 import cc.mrbird.febs.ai.res.talk.ApiTalkItemPageVo;
 import cc.mrbird.febs.ai.res.talk.ApiTalkPageVo;
+import cc.mrbird.febs.ai.res.talk.ApiTalkQuestionVo;
 import cc.mrbird.febs.ai.res.talk.ApiTalkVo;
 import cc.mrbird.febs.ai.service.AiMemberTalkService;
 import cc.mrbird.febs.ai.service.AiTalkService;
@@ -39,6 +40,16 @@
 
     private final AiTalkService aiTalkService;
 
+    @ApiOperation(value = "题目轮播", notes = "题目轮播")
+    @ApiResponses({
+            @ApiResponse(code = 200, message = "success", response = ApiTalkQuestionVo.class)
+    })
+    @GetMapping(value = "/questionList")
+    public FebsResponse questionList() {
+
+        return aiTalkService.questionList();
+    }
+
     @ApiOperation(value = "用户AI问答", notes = "用户AI问答")
     @ApiResponses({
             @ApiResponse(code = 200, message = "success", response = ApiTalkVo.class)
diff --git a/src/main/java/cc/mrbird/febs/ai/res/talk/ApiTalkQuestionVo.java b/src/main/java/cc/mrbird/febs/ai/res/talk/ApiTalkQuestionVo.java
new file mode 100644
index 0000000..0749adf
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/ai/res/talk/ApiTalkQuestionVo.java
@@ -0,0 +1,20 @@
+package cc.mrbird.febs.ai.res.talk;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import javax.validation.constraints.NotBlank;
+import javax.validation.constraints.NotNull;
+
+/**
+ * @author Administrator
+ */
+@Data
+@ApiModel(value = "ApiTalkQuestionVo", description = "参数")
+public class ApiTalkQuestionVo {
+
+    @ApiModelProperty(value = "内容", example = "10")
+    private String context;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java b/src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java
index 01f286a..414ba34 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java
@@ -13,6 +13,8 @@
 
 public interface AiTalkService extends IService<AiTalk> {
 
+    FebsResponse questionList();
+
     FebsResponse talkOpen(ApiTalkDto dto);
 
     AiTalk add(String memberUuid, String question, Date date);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
index 81c8ed3..2cabe56 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
@@ -1,5 +1,6 @@
 package cc.mrbird.febs.ai.service.impl;
 
+import cc.mrbird.febs.ai.entity.AiProductQuestion;
 import cc.mrbird.febs.ai.entity.AiTalk;
 import cc.mrbird.febs.ai.mapper.AiTalkMapper;
 import cc.mrbird.febs.ai.req.talk.AiTalkAnswerStream;
@@ -8,16 +9,21 @@
 import cc.mrbird.febs.ai.req.talk.ApiTalkPageDto;
 import cc.mrbird.febs.ai.res.memberAnswer.ApiMemberProductWorkVo;
 import cc.mrbird.febs.ai.res.talk.ApiTalkPageVo;
+import cc.mrbird.febs.ai.res.talk.ApiTalkQuestionVo;
 import cc.mrbird.febs.ai.res.talk.ApiTalkVo;
+import cc.mrbird.febs.ai.service.AiProductQuestionService;
 import cc.mrbird.febs.ai.service.AiService;
 import cc.mrbird.febs.ai.service.AiTalkItemService;
 import cc.mrbird.febs.ai.service.AiTalkService;
 import cc.mrbird.febs.ai.utils.UUID;
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
+import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateTime;
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.StrUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import lombok.RequiredArgsConstructor;
@@ -25,7 +31,9 @@
 import org.springframework.stereotype.Service;
 import reactor.core.publisher.Flux;
 
+import java.util.ArrayList;
 import java.util.Date;
+import java.util.List;
 
 @Slf4j
 @Service
@@ -33,7 +41,26 @@
 public class AiTalkServiceImpl extends ServiceImpl<AiTalkMapper, AiTalk> implements AiTalkService {
 
     private final AiTalkItemService aiTalkItemService;
+    private final AiProductQuestionService aiProductQuestionService;
     private final AiService aiService;
+
+    @Override
+    public FebsResponse questionList() {
+        List<ApiTalkQuestionVo> list = new ArrayList<>();
+        LambdaQueryWrapper<AiProductQuestion> queryWrapper = Wrappers.lambdaQuery(AiProductQuestion.class);
+        queryWrapper.orderByDesc(AiProductQuestion::getCreatedTime);
+        queryWrapper.last("limit 30");
+        List<AiProductQuestion> listByQuery = aiProductQuestionService.getListByQuery(queryWrapper);
+        if (CollUtil.isNotEmpty(listByQuery)){
+            for (AiProductQuestion aiProductQuestion : listByQuery){
+                ApiTalkQuestionVo apiTalkQuestionVo = new ApiTalkQuestionVo();
+                apiTalkQuestionVo.setContext(aiProductQuestion.getTitle());
+                list.add(apiTalkQuestionVo);
+            }
+        }
+        return new FebsResponse().success().data(list);
+    }
+
     @Override
     public FebsResponse talkOpen(ApiTalkDto dto) {
         String talkId = dto.getTalkId();
diff --git a/src/main/java/cc/mrbird/febs/common/configure/WebMvcConfigure.java b/src/main/java/cc/mrbird/febs/common/configure/WebMvcConfigure.java
index 1794703..85c1728 100644
--- a/src/main/java/cc/mrbird/febs/common/configure/WebMvcConfigure.java
+++ b/src/main/java/cc/mrbird/febs/common/configure/WebMvcConfigure.java
@@ -63,5 +63,6 @@
         registration.excludePathPatterns("/api/ai/productPoint/**");
         registration.excludePathPatterns("/api/ai/test/**");
         registration.excludePathPatterns("/api/ai/memberTalk/answer-stream");
+        registration.excludePathPatterns("/api/ai/talk/questionList");
     }
 }

--
Gitblit v1.9.1