From 413a57e2524cb0b839d5d83d961de3b59814eb6e Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 24 Oct 2025 16:53:11 +0800
Subject: [PATCH] feat(ai): 实现产品依赖解锁功能 - 在AiMemberAnswerServiceImpl中注入AiProductDependencyService和AiMemberProductUnlockService - 修改insure方法,根据答题分数解锁符合条件的产品 - 新增selectListByProductIds和insertList方法到AiMemberProductUnlockService - 实现产品依赖关系查询方法selectListByProductId到AiProductDependencyService- 在AiProductServiceImpl中增加产品状态判断逻辑,支持锁定和解锁状态显示 - 添加memberId字段到ApiProductPageDto用于查询用户已解锁产品 - 在ApiProductVo中新增state字段表示产品锁定/解锁状态

---
 src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberPointServiceImpl.java |   20 +++++++++++++++++++-
 1 files changed, 19 insertions(+), 1 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberPointServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberPointServiceImpl.java
index eea26fd..123455d 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberPointServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberPointServiceImpl.java
@@ -15,6 +15,7 @@
 import org.springframework.stereotype.Service;
 
 import java.util.Date;
+import java.util.List;
 
 @Slf4j
 @Service
@@ -51,7 +52,7 @@
 
         AiMemberPoint aiMemberPoint = this.getById(productPointId);
         if (ObjectUtil.isNull(aiMemberPoint)){
-            aiMemberPoint = this.add(memberUuid, productPointId, companyId, totalTime);
+            this.add(memberUuid, productPointId, companyId, totalTime);
         }else{
             Integer oldTotalTime = aiMemberPoint.getTotalTime();
             aiMemberPointMapper.update(
@@ -64,4 +65,21 @@
         }
         return new FebsResponse().success();
     }
+
+    @Override
+    public List<AiMemberPoint> getListByCompanyId(String companyId) {
+        return aiMemberPointMapper.selectList(
+                Wrappers.lambdaQuery(AiMemberPoint.class)
+                .eq(AiMemberPoint::getCompanyId, companyId)
+        );
+    }
+
+    @Override
+    public List<AiMemberPoint> getListByCompanyIdAndMemberUuid(String companyId, String memberUuid) {
+        return aiMemberPointMapper.selectList(
+                Wrappers.lambdaQuery(AiMemberPoint.class)
+                        .eq(AiMemberPoint::getCompanyId, companyId)
+                        .eq(AiMemberPoint::getMemberId, memberUuid)
+        );
+    }
 }

--
Gitblit v1.9.1