From b51e14a5709a7433bc3ca4a2dab06b0e2a64156f Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 02 Sep 2025 13:54:39 +0800
Subject: [PATCH] refactor(ai): 优化 ApiMemberTalkStreamServiceImpl 中的代码逻辑- 移除了无用的代码行 - 调整了变量赋值的顺序,提高了代码可读性
---
src/main/java/cc/mrbird/febs/ai/service/impl/AiProductPointServiceImpl.java | 62 +++++++++++++++++++++++++++++++
1 files changed, 62 insertions(+), 0 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductPointServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductPointServiceImpl.java
index f9115c9..3800bfd 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductPointServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductPointServiceImpl.java
@@ -1,16 +1,28 @@
package cc.mrbird.febs.ai.service.impl;
import cc.mrbird.febs.ai.entity.AiProductPoint;
+import cc.mrbird.febs.ai.entity.AiProductPointLink;
import cc.mrbird.febs.ai.mapper.AiProductPointMapper;
+import cc.mrbird.febs.ai.req.productPoint.ApiProductPointInfoDto;
+import cc.mrbird.febs.ai.res.productPoint.ApiProductPointInfoVo;
+import cc.mrbird.febs.ai.res.productPoint.ApiProductPointVo;
+import cc.mrbird.febs.ai.service.AiProductPointLinkService;
import cc.mrbird.febs.ai.service.AiProductPointService;
+import cc.mrbird.febs.common.entity.FebsResponse;
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.ObjectUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
+import java.util.ArrayList;
import java.util.List;
+import java.util.Set;
+import java.util.stream.Collectors;
/**
* AI产品知识点 Service实现类
@@ -24,6 +36,56 @@
public class AiProductPointServiceImpl extends ServiceImpl<AiProductPointMapper, AiProductPoint> implements AiProductPointService {
private final AiProductPointMapper aiProductPointMapper;
+ private final AiProductPointLinkService aiProductPointLinkService;
+ @Override
+ public AiProductPoint getById(String id) {
+ return aiProductPointMapper.selectById( id);
+ }
+ @Override
+ public List<AiProductPoint> getListByPointIds(Set<String> collect) {
+ return aiProductPointMapper.selectBatchIds( collect);
+ }
+ @Override
+ public List<ApiProductPointVo> listByProductId(String productId) {
+ List<ApiProductPointVo> vos = new ArrayList<>();
+
+ LambdaQueryWrapper<AiProductPointLink> pointLinkQUery = Wrappers.lambdaQuery(AiProductPointLink.class);
+ pointLinkQUery.eq(AiProductPointLink::getProductId, productId);
+ List<AiProductPointLink> linkList = aiProductPointLinkService.getListByProductId(pointLinkQUery);
+ if (CollUtil.isEmpty(linkList)){
+ return vos;
+ }
+
+ Set<String> collect = linkList.stream().map(AiProductPointLink::getProductPointId).collect(Collectors.toSet());
+ List<AiProductPoint> list = this.getListByPointIds(collect);
+ if (CollUtil.isEmpty(list)){
+ return vos;
+ }
+
+ for (AiProductPoint point : list){
+ ApiProductPointVo vo = new ApiProductPointVo();
+ vo.setId(point.getId());
+ vo.setTitle(point.getTitle());
+ vos.add(vo);
+ }
+ return vos;
+ }
+
+ @Override
+ public FebsResponse productPointInfo(ApiProductPointInfoDto dto) {
+ ApiProductPointInfoVo apiProductPointInfoVo = new ApiProductPointInfoVo();
+ String id = dto.getId();
+ AiProductPoint entity = this.getById(id);
+ if (ObjectUtil.isNotNull( entity)){
+ apiProductPointInfoVo.setIsNormal(entity.getIsNormal());
+ apiProductPointInfoVo.setFinderUserName(entity.getFinderUserName());
+ apiProductPointInfoVo.setFeedId(entity.getFeedId());
+ apiProductPointInfoVo.setFeedImg(entity.getFeedImg());
+ apiProductPointInfoVo.setTitle(entity.getTitle());
+ apiProductPointInfoVo.setDescription(entity.getDescription());
+ }
+ return new FebsResponse().success().data(apiProductPointInfoVo);
+ }
}
--
Gitblit v1.9.1