From 5538b26be505fcf27c4440cadd4787e1c975ac62 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 25 Jul 2025 11:52:11 +0800
Subject: [PATCH] fix:修复投票活动群组图片双击上传问题
---
src/main/java/cc/mrbird/febs/mall/service/impl/ApiHappySocialCircleServiceImpl.java | 34 ++++++++++++++++++++++++++++++----
1 files changed, 30 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 02a33f8..95b9080 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,13 +33,14 @@
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() {
ArrayList<ApiScCategoryInfoVo> objects = new ArrayList<>();
List<HappySocialCircleCategory> happySocialCircleCategories = happySocialCircleCategoryMapper.selectList(
new LambdaQueryWrapper<HappySocialCircleCategory>()
- .select(HappySocialCircleCategory::getId, HappySocialCircleCategory::getName)
+ .select(HappySocialCircleCategory::getId, HappySocialCircleCategory::getName, HappySocialCircleCategory::getBackImage)
.eq(HappySocialCircleCategory::getState, StateUpDownEnum.UP.getCode())
.eq(HappySocialCircleCategory::getDeleteFlag, StateUpDownEnum.DOWN.getCode())
.orderByAsc(HappySocialCircleCategory::getOrderCnt)
@@ -46,6 +50,7 @@
ApiScCategoryInfoVo apiScCategoryInfoVo = new ApiScCategoryInfoVo();
apiScCategoryInfoVo.setId(happySocialCircleCategory.getId());
apiScCategoryInfoVo.setName(happySocialCircleCategory.getName());
+ apiScCategoryInfoVo.setBackImage(happySocialCircleCategory.getBackImage());
objects.add(apiScCategoryInfoVo);
}
}
@@ -57,7 +62,7 @@
ArrayList<ApiScCategoryInfoVo> objects = new ArrayList<>();
List<HappySocialCircleCategory> happySocialCircleCategories = happySocialCircleCategoryMapper.selectList(
new LambdaQueryWrapper<HappySocialCircleCategory>()
- .select(HappySocialCircleCategory::getId, HappySocialCircleCategory::getName)
+ .select(HappySocialCircleCategory::getId, HappySocialCircleCategory::getName, HappySocialCircleCategory::getBackImage)
.eq(HappySocialCircleCategory::getState, StateUpDownEnum.UP.getCode())
.eq(HappySocialCircleCategory::getHotState, StateUpDownEnum.UP.getCode())
.eq(HappySocialCircleCategory::getDeleteFlag, StateUpDownEnum.DOWN.getCode())
@@ -68,6 +73,7 @@
ApiScCategoryInfoVo apiScCategoryInfoVo = new ApiScCategoryInfoVo();
apiScCategoryInfoVo.setId(happySocialCircleCategory.getId());
apiScCategoryInfoVo.setName(happySocialCircleCategory.getName());
+ apiScCategoryInfoVo.setBackImage(happySocialCircleCategory.getBackImage());
objects.add(apiScCategoryInfoVo);
}
}
@@ -98,6 +104,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