From 5ea1abc297842faf1500aa159cbfbc1a1d16b80f Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 10 Oct 2025 10:36:15 +0800
Subject: [PATCH] feat(ai): 添加公司知识库和分类字段
---
src/main/java/cc/mrbird/febs/mall/service/impl/ApiHappySocialCircleServiceImpl.java | 32 ++++++++++++++++++++++++++++----
1 files changed, 28 insertions(+), 4 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiHappySocialCircleServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiHappySocialCircleServiceImpl.java
index 602c0df..0cbbe04 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiHappySocialCircleServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiHappySocialCircleServiceImpl.java
@@ -3,9 +3,11 @@
import cc.mrbird.febs.common.entity.FebsResponse;
import cc.mrbird.febs.common.enumerates.StateUpDownEnum;
import cc.mrbird.febs.mall.dto.activity.ApiScInfoDto;
+import cc.mrbird.febs.mall.entity.HappyFollow;
import cc.mrbird.febs.mall.entity.HappySocialCircle;
import cc.mrbird.febs.mall.entity.HappySocialCircleCategory;
import cc.mrbird.febs.mall.entity.MallMember;
+import cc.mrbird.febs.mall.mapper.HappyFollowMapper;
import cc.mrbird.febs.mall.mapper.HappySocialCircleCategoryMapper;
import cc.mrbird.febs.mall.mapper.HappySocialCircleMapper;
import cc.mrbird.febs.mall.mapper.MallMemberMapper;
@@ -14,6 +16,7 @@
import cc.mrbird.febs.mall.vo.activity.ApiScCategoryInfoVo;
import cc.mrbird.febs.mall.vo.activity.ApiScInfoVo;
import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.ObjectUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -21,8 +24,8 @@
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
-import java.util.ArrayList;
-import java.util.List;
+import java.util.*;
+import java.util.stream.Collectors;
@Slf4j
@Service
@@ -30,6 +33,7 @@
public class ApiHappySocialCircleServiceImpl extends ServiceImpl<HappySocialCircleMapper, HappySocialCircle> implements ApiHappySocialCircleService {
private final HappySocialCircleCategoryMapper happySocialCircleCategoryMapper;
+ private final HappyFollowMapper happyFollowMapper;
private final MallMemberMapper mallMemberMapper;
@Override
public FebsResponse allCategory() {
@@ -39,7 +43,7 @@
.select(HappySocialCircleCategory::getId, HappySocialCircleCategory::getName)
.eq(HappySocialCircleCategory::getState, StateUpDownEnum.UP.getCode())
.eq(HappySocialCircleCategory::getDeleteFlag, StateUpDownEnum.DOWN.getCode())
- .orderByDesc(HappySocialCircleCategory::getOrderCnt)
+ .orderByAsc(HappySocialCircleCategory::getOrderCnt)
);
if(CollUtil.isNotEmpty(happySocialCircleCategories)){
for (HappySocialCircleCategory happySocialCircleCategory : happySocialCircleCategories) {
@@ -61,7 +65,7 @@
.eq(HappySocialCircleCategory::getState, StateUpDownEnum.UP.getCode())
.eq(HappySocialCircleCategory::getHotState, StateUpDownEnum.UP.getCode())
.eq(HappySocialCircleCategory::getDeleteFlag, StateUpDownEnum.DOWN.getCode())
- .orderByDesc(HappySocialCircleCategory::getOrderCnt)
+ .orderByAsc(HappySocialCircleCategory::getOrderCnt)
);
if(CollUtil.isNotEmpty(happySocialCircleCategories)){
for (HappySocialCircleCategory happySocialCircleCategory : happySocialCircleCategories) {
@@ -98,6 +102,26 @@
apiScInfoVo.setIndexFile(happySocialCircle.getIndexFile());
apiScInfoVo.setContent(happySocialCircle.getContent());
apiScInfoVo.setCreatedTime(happySocialCircle.getCreatedTime());
+
+ List<HappyFollow> happyFollows = happyFollowMapper.selectList(
+ new LambdaQueryWrapper<HappyFollow>()
+ .select(HappyFollow::getId, HappyFollow::getType)
+ .eq(HappyFollow::getSourceType, StateUpDownEnum.SOURCE_TYPE_SOCIAL_CIRCLE.getCode())
+ .eq(HappyFollow::getSourceId, happySocialCircle.getId())
+ .in(HappyFollow::getType, Arrays.asList(StateUpDownEnum.FOLLOW.getCode(), StateUpDownEnum.LIKE.getCode(), StateUpDownEnum.SHARE.getCode()))
+ .eq(HappyFollow::getDeleteFlag, StateUpDownEnum.DOWN.getCode())
+ );
+ if(CollUtil.isNotEmpty(happyFollows)){
+ // 使用Stream流操作happyFollows,按照type分类,返回每一个不同type的总数量,并返回一个Map
+ Map<Integer, Long> typeCountMap = happyFollows.stream()
+ .collect(Collectors.groupingBy(HappyFollow::getType, Collectors.counting()));
+ Long zanCnt = ObjectUtil.defaultIfNull(typeCountMap.get(StateUpDownEnum.LIKE.getCode()), 0L);
+ apiScInfoVo.setZanCnt(Math.toIntExact(zanCnt));
+ Long sendCnt = ObjectUtil.defaultIfNull(typeCountMap.get(StateUpDownEnum.SHARE.getCode()), 0L);
+ apiScInfoVo.setSendCnt(Math.toIntExact(sendCnt));
+ Long followCnt = ObjectUtil.defaultIfNull(typeCountMap.get(StateUpDownEnum.FOLLOW.getCode()), 0L);
+ apiScInfoVo.setFollowCnt(Math.toIntExact(followCnt));
+ }
}
return new FebsResponse().success().data(apiScInfoVo);
}
--
Gitblit v1.9.1