From e3f9f30e2f814e39157017e7f9bf2be886335877 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Wed, 04 Feb 2026 15:51:12 +0800
Subject: [PATCH] feat(mall): 添加会员角色ID字段
---
src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java | 111 +++++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 103 insertions(+), 8 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java
index 2434673..93419ec 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java
@@ -1,8 +1,15 @@
package cc.mrbird.febs.ai.service.impl;
import cc.mrbird.febs.ai.entity.*;
+import cc.mrbird.febs.ai.enumerates.AiTypeEnum;
import cc.mrbird.febs.ai.mapper.AiMemberAnswerMapper;
+import cc.mrbird.febs.ai.req.member.ApiCompanyStudyDto;
+import cc.mrbird.febs.ai.req.member.ApiCompanyStudyRecordDto;
+import cc.mrbird.febs.ai.req.member.ApiMemberAnswerPageDto;
import cc.mrbird.febs.ai.req.memberAnswer.*;
+import cc.mrbird.febs.ai.res.member.ApiCompanyStudyRecordVo;
+import cc.mrbird.febs.ai.res.member.ApiCompanyStudyVo;
+import cc.mrbird.febs.ai.res.member.ApiMemberAnswerPageVo;
import cc.mrbird.febs.ai.res.memberAnswer.*;
import cc.mrbird.febs.ai.res.product.ApiProductVo;
import cc.mrbird.febs.ai.res.productQuestionItem.ApiMemberAnswerItemVo;
@@ -16,6 +23,7 @@
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.ObjectUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -26,9 +34,8 @@
import java.math.BigDecimal;
import java.math.RoundingMode;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
+import java.util.stream.Collectors;
/**
* AI用户答题记录 Service实现类
@@ -46,6 +53,8 @@
private final AiProductService aiProductService;
private final AiProductQuestionService aiProductQuestionService;
private final AiProductQuestionItemService aiProductQuestionItemService;
+ private final AiProductDependencyService aiProductDependencyService;
+ private final AiMemberProductUnlockService aiMemberProductUnlockService;
@Override
@@ -55,6 +64,7 @@
}
@Override
+ @Transactional
public FebsResponse startAnswerV2(ApiMemberAnswerDto dto) {
String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
ApiMemberAnswerVoV2 apiMemberAnswerVoV2 = new ApiMemberAnswerVoV2();
@@ -99,9 +109,30 @@
aiMemberAnswer.setCorrectCnt(0);
aiMemberAnswerMapper.insert(aiMemberAnswer);
List<AiMemberAnswerItem> aiMemberAnswerItems = new ArrayList<>();
- for (int i = 1; i <= questionCount; i++){
- //初始化答题记录
- AiProductQuestion aiProductQuestion = aiProductQuestionService.createQuestion(aiProduct.getId());
+// for (int i = 1; i <= questionCount; i++){
+// //初始化答题记录
+// AiProductQuestion aiProductQuestion = aiProductQuestionService.createQuestion(aiProduct.getId());
+// AiMemberAnswerItem aiMemberAnswerItem = new AiMemberAnswerItem();
+// aiMemberAnswerItem.setId(UUID.getSimpleUUIDString());
+// aiMemberAnswerItem.setCompanyId(companyId);
+// aiMemberAnswerItem.setCreatedTime(createdTime);
+// aiMemberAnswerItem.setAnswerId(aiMemberAnswer.getId());
+// aiMemberAnswerItem.setProductId(aiMemberAnswer.getProductId());
+// aiMemberAnswerItem.setMemberId(memberUuid);
+// aiMemberAnswerItem.setProductQuestionId(aiProductQuestion.getId());
+// aiMemberAnswerItem.setTitle(aiProductQuestion.getTitle());
+// aiMemberAnswerItem.setDifficulty(aiProductQuestion.getDifficulty());
+// aiMemberAnswerItem.setMemberAnswerState(0);
+// aiMemberAnswerItem.setSort( i );
+// aiMemberAnswerItems.add(aiMemberAnswerItem);
+// }
+
+ List<AiProductQuestion> questionList = aiProductQuestionService.createQuestionList(aiProduct.getId(), questionCount);
+ if (CollUtil.isEmpty(questionList)){
+ throw new FebsException("产品没有题目");
+ }
+ for (int i = 0; i < questionList.size(); i++){
+ AiProductQuestion aiProductQuestion = questionList.get(i);
AiMemberAnswerItem aiMemberAnswerItem = new AiMemberAnswerItem();
aiMemberAnswerItem.setId(UUID.getSimpleUUIDString());
aiMemberAnswerItem.setCompanyId(companyId);
@@ -113,7 +144,7 @@
aiMemberAnswerItem.setTitle(aiProductQuestion.getTitle());
aiMemberAnswerItem.setDifficulty(aiProductQuestion.getDifficulty());
aiMemberAnswerItem.setMemberAnswerState(0);
- aiMemberAnswerItem.setSort( i );
+ aiMemberAnswerItem.setSort( i +1);
aiMemberAnswerItems.add(aiMemberAnswerItem);
}
aiMemberAnswerItemService.saveBatch(aiMemberAnswerItems);
@@ -302,6 +333,7 @@
@Override
public FebsResponse insure(ApiMemberAnswerInsureDto dto) {
String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
+ String companyId = LoginUserUtil.getLoginUser().getCompanyId();
ApiMemberAnswerInsureVo apiMemberAnswerInsureVo = new ApiMemberAnswerInsureVo();
String memberAnswerId = dto.getMemberAnswerId();
@@ -329,6 +361,22 @@
.set(AiMemberAnswer::getScore, percentage.intValue())
.eq(AiMemberAnswer::getId, memberAnswerId)
);
+
+ //如果有升级规则,则解锁
+ List<AiProductDependency> aiProductDependencies = aiProductDependencyService.selectListByProductId(aiMemberAnswer.getProductId(),percentage.intValue());
+ if (CollUtil.isNotEmpty(aiProductDependencies)){
+ //stream流操作aiProductDependencies,获取全部的targetProductId
+ Set<String> targetProductIds = aiProductDependencies.stream().map(AiProductDependency::getTargetProductId).collect(Collectors.toSet());
+
+ List<AiMemberProductUnlock> aiMemberProductUnlocks = aiMemberProductUnlockService.selectListByProductIds(targetProductIds, memberUuid);
+ Set<String> doneProductIds = aiMemberProductUnlocks.stream().map(AiMemberProductUnlock::getProductId).collect(Collectors.toSet());
+
+ //获取在targetProductIds集合中,并且不在doneProductIds集合中的productId
+ Set<String> unlockProductIds = targetProductIds.stream().filter(productId -> !doneProductIds.contains(productId)).collect(Collectors.toSet());
+ if (CollUtil.isNotEmpty(unlockProductIds)){
+ aiMemberProductUnlockService.insertList(companyId,unlockProductIds, memberUuid,percentage.intValue());
+ }
+ }
return new FebsResponse().success().data(apiMemberAnswerInsureVo);
}
@@ -360,9 +408,10 @@
List<ApiMemberAnswerPreviousItemVo> answerList = new ArrayList<>();
LambdaQueryWrapper<AiProductQuestionItem> productQuestionItemLambdaQueryWrapper = Wrappers.lambdaQuery(AiProductQuestionItem.class);
productQuestionItemLambdaQueryWrapper.eq(AiProductQuestionItem::getProductQuestionId,productQuestionId);
- productQuestionItemLambdaQueryWrapper.orderByAsc(AiProductQuestionItem::getCreatedTime);
List<AiProductQuestionItem> listByQuery = aiProductQuestionItemService.getListByQuery(productQuestionItemLambdaQueryWrapper);
if(CollUtil.isNotEmpty(listByQuery)){
+ //让listByQuery随机排序一次
+ Collections.shuffle(listByQuery);
for (AiProductQuestionItem aiProductQuestionItem : listByQuery){
ApiMemberAnswerPreviousItemVo apiMemberAnswerPreviousItemVo = new ApiMemberAnswerPreviousItemVo();
apiMemberAnswerPreviousItemVo.setId(aiProductQuestionItem.getId());
@@ -406,4 +455,50 @@
.eq(AiMemberAnswer::getId,memberAnswerId)
);
}
+
+ @Override
+ public List<AiMemberAnswer> getListByCompanyId(String companyId) {
+ return aiMemberAnswerMapper.selectList(
+ Wrappers.lambdaQuery(AiMemberAnswer.class)
+ .eq(AiMemberAnswer::getCompanyId, companyId)
+ .eq(AiMemberAnswer::getState, AiTypeEnum.AI_MEMBER_ANSWER_STATE_DONE.getCode())
+ );
+ }
+
+ @Override
+ public List<AiMemberAnswer> getListByCompanyIdAndMemberUuid(String companyId, String memberUuid) {
+ return aiMemberAnswerMapper.selectList(
+ Wrappers.lambdaQuery(AiMemberAnswer.class)
+ .eq(AiMemberAnswer::getCompanyId, companyId)
+ .eq(AiMemberAnswer::getMemberId, memberUuid)
+ .eq(AiMemberAnswer::getState, AiTypeEnum.AI_MEMBER_ANSWER_STATE_DONE.getCode())
+ );
+ }
+
+ @Override
+ public Page<ApiMemberAnswerPageVo> getAnswerPage(Page<ApiMemberAnswerPageVo> page, ApiMemberAnswerPageDto dto) {
+
+ return aiMemberAnswerMapper.getAnswerPage(page,dto);
+ }
+
+ @Override
+ public IPage<ApiCompanyStudyVo> selectListPage(ApiCompanyStudyDto dto, Page<ApiCompanyStudyVo> page) {
+ return aiMemberAnswerMapper.selectProductListPage(page,dto);
+ }
+
+ @Override
+ public IPage<ApiCompanyStudyRecordVo> getStudyRecordList(Page<ApiCompanyStudyRecordVo> page, ApiCompanyStudyRecordDto dto) {
+ return aiMemberAnswerMapper.getStudyRecordList(page,dto);
+ }
+
+ @Override
+ public List<AiMemberAnswer> getIdListByCompanyIdAndProductId(String companyId, Set<String> collect) {
+ return aiMemberAnswerMapper.selectList(
+ Wrappers.lambdaQuery(AiMemberAnswer.class)
+ .select(AiMemberAnswer::getId,AiMemberAnswer::getProductId)
+ .eq(AiMemberAnswer::getCompanyId, companyId)
+ .in(AiMemberAnswer::getProductId, collect)
+ .eq(AiMemberAnswer::getState, AiTypeEnum.AI_MEMBER_ANSWER_STATE_DONE.getCode())
+ );
+ }
}
--
Gitblit v1.9.1