From 6e9730ebbbff634d27c2c49ec328156c8905b508 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Thu, 30 Oct 2025 13:52:14 +0800
Subject: [PATCH] feat(ai): 简化AI对话项创建逻辑并新增连续对话类型 - 移除复杂的对话项更新逻辑,统一通过add方法创建新项 - 新增AiTalkOutputEnum枚举值CONTEXT_TALK用于AI陪练连续对话 - 更新ApiMemberTalkAnswerSavaDto注释以包含新的对话类型 - 修复对话项创建时类型参数未正确传递的问题 - 优化代码结构,减少冗余的条件判断和数据转换操作

---
 src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java |   62 ++++++++++++++++++++++++++++++
 1 files changed, 61 insertions(+), 1 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
index 566e82f..63f5657 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
@@ -1,20 +1,32 @@
 package cc.mrbird.febs.ai.service.impl;
 
+import cc.mrbird.febs.ai.entity.AiMemberProductUnlock;
 import cc.mrbird.febs.ai.entity.AiProduct;
+import cc.mrbird.febs.ai.entity.AiProductDependency;
 import cc.mrbird.febs.ai.entity.AiProductPoint;
 import cc.mrbird.febs.ai.mapper.AiProductMapper;
 import cc.mrbird.febs.ai.req.product.ApiProductInfoDto;
 import cc.mrbird.febs.ai.req.product.ApiProductPageDto;
 import cc.mrbird.febs.ai.res.product.ApiProductInfoVo;
 import cc.mrbird.febs.ai.res.product.ApiProductVo;
+import cc.mrbird.febs.ai.res.productPoint.ApiProductPointVo;
 import cc.mrbird.febs.ai.service.*;
 import cc.mrbird.febs.common.entity.FebsResponse;
+import cc.mrbird.febs.common.exception.FebsException;
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
+
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.stream.Collectors;
 
 /**
  * AI产品表 Service实现类
@@ -31,6 +43,8 @@
     private final AiMemberRoleService aiMemberRoleService;
     private final AiProductCategoryService aiProductCategoryService;
     private final AiProductPointService aiProductPointService;
+    private final AiProductDependencyService aiProductDependencyService;
+    private final AiMemberProductUnlockService aiMemberProductUnlockService;
 
 
     @Override
@@ -58,15 +72,48 @@
         // 创建分页对象,传入当前页和每页大小
         Page<ApiProductVo> page = new Page<>(dto.getPageNow(), dto.getPageSize());
         Page<ApiProductVo> pageListByQuery = this.getPageListByQuery(page, dto);
+        List<ApiProductVo> records = pageListByQuery.getRecords();
+        if (CollUtil.isNotEmpty( records)){
+
+            //stream流操作records,返回一个id的集合
+            Set<String> productIds = records.stream().map(ApiProductVo::getId).collect(Collectors.toSet());
+
+            List<AiProductDependency> aiProductDependencies = aiProductDependencyService.selectListByProductIds(productIds);
+            if (CollUtil.isNotEmpty( aiProductDependencies)){
+                //stream流操作aiProductDependencies,返回一个Map<targetProductId,AiProductDependency>
+                Map<String, AiProductDependency> targetProductIdAiProductDependencyMap = aiProductDependencies.stream().collect(Collectors.toMap(AiProductDependency::getTargetProductId, aiProductDependency -> aiProductDependency));
+                for (ApiProductVo record : records){
+                    if (targetProductIdAiProductDependencyMap.containsKey(record.getId())){
+                        record.setState(0);
+                    }
+                }
+            }
+
+            if (StrUtil.isNotEmpty(dto.getMemberId())){
+                List<AiMemberProductUnlock> aiMemberProductUnlocks = aiMemberProductUnlockService.selectListByMemberId(dto.getMemberId());
+                if (CollUtil.isNotEmpty( aiMemberProductUnlocks)){
+                    //stream流操作aiMemberProductUnlocks,返回一个Map<targetProductId,AiMemberProductUnlock>
+                    Map<String, AiMemberProductUnlock> aiMemberProductUnlocksMap = aiMemberProductUnlocks.stream().collect(Collectors.toMap(AiMemberProductUnlock::getProductId, aiMemberProductUnlock -> aiMemberProductUnlock));
+                    for (ApiProductVo record : records){
+                        if (aiMemberProductUnlocksMap.containsKey(record.getId())){
+                            record.setState(1);
+                        }
+                    }
+                }
+            }
+        }
         return new FebsResponse().success().data(pageListByQuery);
     }
 
     @Override
     public FebsResponse productInfo(ApiProductInfoDto dto) {
 
+        ApiProductInfoVo vo = new ApiProductInfoVo();
         String id = dto.getId();
         AiProduct entity = this.getById(id);
-        ApiProductInfoVo vo = new ApiProductInfoVo();
+        if (ObjectUtil.isNull( entity)){
+            throw new FebsException("产品不存在");
+        }
         vo.setId(entity.getId());
         vo.setProductCategoryId(entity.getProductCategoryId());
         vo.setName(entity.getName());
@@ -80,4 +127,17 @@
         vo.setProductPointList(aiProductPointService.listByProductId(id));
         return new FebsResponse().success().data(vo);
     }
+
+    @Override
+    public FebsResponse pointInfoList(ApiProductInfoDto dto) {
+        String id = dto.getId();
+        AiProduct entity = this.getById(id);
+        List<ApiProductPointVo> apiProductPointVos = aiProductPointService.listByProductId(id);
+        return new FebsResponse().success().data(apiProductPointVos);
+    }
+
+    @Override
+    public List<AiProduct> getProductListByQuery(LambdaQueryWrapper<AiProduct> productQuery) {
+        return aiProductMapper.selectList(productQuery);
+    }
 }

--
Gitblit v1.9.1