From ec00cb3e936147ae1c080cbb5d723ef368a3d2da Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 10 Oct 2025 16:51:02 +0800
Subject: [PATCH] fix(mapper): 调整对话记录查询条件 - 移除了AiMemberTalkItemMapper中对state=1的限制 - 在AiMemberTalkMapper中增加了state=1的过滤条件 - 优化了对话记录的查询逻辑,确保数据准确性 - 统一了前后端对于对话状态的处理方式 - 提高了查询效率,减少了不必要的数据加载 - 保证了对话列表按创建时间倒序排列的正确性

---
 src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java |   27 +++++++++++++++++++++++----
 1 files changed, 23 insertions(+), 4 deletions(-)

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 299d64c..1480379 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
@@ -4,10 +4,7 @@
 import cc.mrbird.febs.ai.entity.AiTalk;
 import cc.mrbird.febs.ai.enumerates.AiPromptEnum;
 import cc.mrbird.febs.ai.mapper.AiTalkMapper;
-import cc.mrbird.febs.ai.req.talk.AiTalkAnswerStream;
-import cc.mrbird.febs.ai.req.talk.ApiTalkDto;
-import cc.mrbird.febs.ai.req.talk.ApiTalkItemPageDto;
-import cc.mrbird.febs.ai.req.talk.ApiTalkPageDto;
+import cc.mrbird.febs.ai.req.talk.*;
 import cc.mrbird.febs.ai.res.talk.ApiTalkPageVo;
 import cc.mrbird.febs.ai.res.talk.ApiTalkQuestionVo;
 import cc.mrbird.febs.ai.res.talk.ApiTalkVo;
@@ -70,6 +67,28 @@
     }
 
     @Override
+    public FebsResponse questionListV2(ApiQuestionListDto dto) {
+        List<ApiTalkQuestionVo> list = new ArrayList<>();
+        LambdaQueryWrapper<AiProductQuestion> queryWrapper = Wrappers.lambdaQuery(AiProductQuestion.class);
+        if (StrUtil.isNotEmpty(dto.getCompanyId())){
+            queryWrapper.eq(AiProductQuestion::getCompanyId,dto.getCompanyId());
+        }else{
+            queryWrapper.isNull(AiProductQuestion::getCompanyId);
+        }
+        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();
         String context = dto.getContext();

--
Gitblit v1.9.1