From 75d8b0ad39a7eb04f72ef8654dbb895322f07cfd Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 21 Oct 2025 13:41:42 +0800
Subject: [PATCH] feat(ai): 新增会员答题分页及详情查询功能 - 在 AiMemberAnswerMapper 中新增 getAnswerPage 方法及对应 XML 查询语句 - 新增 ApiMemberAnswerPageDto 和 ApiMemberAnswerPageVo 用于分页查询参数和返回结果 - 在 AiMemberAnswerService 及其实现类中添加 getAnswerPage 方法 - 在 AiMemberService 及其实现类中新增 answerPage 和 answerInfo 接口实现 - 新增 ApiMemberAnswerInfoDto 和 ApiMemberAnswerInfoVo 用于答题详情接口参数和响应 - 在 ApiMemberController 中增加 /answerPage 和 /answerInfo两个 POST 接口 - 优化 AiMemberTeamPracticeVo,增加 memberUuid 字段 - 统一导入包路径,简化代码结构

---
 src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java |   51 +++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 39 insertions(+), 12 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 faa3876..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,11 +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.res.memberAnswer.ApiMemberProductWorkVo;
+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;
@@ -17,6 +13,7 @@
 import cc.mrbird.febs.ai.service.AiTalkItemService;
 import cc.mrbird.febs.ai.service.AiTalkService;
 import cc.mrbird.febs.ai.strategy.LlmStrategyFactory;
+import cc.mrbird.febs.ai.strategy.enumerates.LlmStrategyContextEnum;
 import cc.mrbird.febs.ai.strategy.enumerates.LlmStrategyEnum;
 import cc.mrbird.febs.ai.strategy.param.LlmStrategyDto;
 import cc.mrbird.febs.ai.utils.UUID;
@@ -26,6 +23,7 @@
 import cn.hutool.core.date.DateTime;
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.StrUtil;
+import cn.hutool.json.JSONUtil;
 import com.alibaba.dashscope.common.Role;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
@@ -38,6 +36,7 @@
 
 import java.util.ArrayList;
 import java.util.Date;
+import java.util.HashMap;
 import java.util.List;
 
 @Slf4j
@@ -68,19 +67,45 @@
     }
 
     @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();
         Integer type = dto.getType();
+        String reasoningContent = dto.getReasoningContent();
         String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
+        String companyId = LoginUserUtil.getLoginUser().getCompanyId();
 
         AiTalk aiTalk = this.getById(talkId);
         DateTime date = DateUtil.date();
         if (StrUtil.isEmpty(talkId)){
-            aiTalk = this.add(memberUuid,context, date);
+            aiTalk = this.add(memberUuid,companyId,context, date);
         }
-
-        aiTalkItemService.add(aiTalk.getId(), type, context, memberUuid, date);
+        HashMap<String, String> stringStringHashMap = new HashMap<>();
+        stringStringHashMap.put(LlmStrategyContextEnum.THINK.getName(),reasoningContent);
+        stringStringHashMap.put(LlmStrategyContextEnum.CONTENT.getName(),context);
+        aiTalkItemService.add(aiTalk.getId(), companyId,type, JSONUtil.toJsonStr(stringStringHashMap), memberUuid, date);
 
         ApiTalkVo apiTalkVo = new ApiTalkVo();
         apiTalkVo.setTalkId(aiTalk.getId());
@@ -88,9 +113,10 @@
     }
 
     @Override
-    public AiTalk add(String memberUuid, String question, Date date) {
+    public AiTalk add(String memberUuid,String companyId, String question, Date date) {
         AiTalk aiTalk = new AiTalk();
         aiTalk.setId(UUID.getSimpleUUIDString());
+        aiTalk.setCompanyId(companyId);
         aiTalk.setQuestion(question);
         aiTalk.setCreatedTime(date);
         aiTalk.setMemberId(memberUuid);
@@ -133,17 +159,18 @@
         if (dto.getPrompt() != null){
             LlmStrategyDto llmStrategyDto = new LlmStrategyDto();
             llmStrategyDto.setRole(Role.SYSTEM.getValue());
-            llmStrategyDto.setContent(AiPromptEnum.STREAM_NORMAL.getPrompt());
+            llmStrategyDto.setContent(aiService.getSystemSetLTAiPrompt());
             llmStrategyDtoList.add(llmStrategyDto);
         }
         if (dto.getQuestion() != null){
             LlmStrategyDto llmStrategyDto = new LlmStrategyDto();
             llmStrategyDto.setRole(Role.USER.getValue());
-            llmStrategyDto.setContent(dto.getQuestion());
+            String format = StrUtil.format("请使用中文回答:{}", dto.getQuestion());
+            llmStrategyDto.setContent(format);
             llmStrategyDtoList.add(llmStrategyDto);
         }
         String modelName = LlmStrategyEnum.getName(aiService.getSystemSetAiType());
-        return llmStrategyFactory.getCalculationStrategyMap().get(modelName).llmInvokeStreaming(llmStrategyDtoList);
+        return llmStrategyFactory.getCalculationStrategyMap().get(modelName).llmInvokeStreamingWithThink(llmStrategyDtoList);
     }
 
 }

--
Gitblit v1.9.1