From 24fe2b1c79d9836ebc61091e32367395b1b90c6b Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Thu, 08 May 2025 16:34:12 +0800
Subject: [PATCH] feat(signActivity): 添加签到日历和签到记录功能

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java |  136 +++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 130 insertions(+), 6 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java
index d989ce3..7785770 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java
@@ -1,34 +1,44 @@
 package cc.mrbird.febs.mall.service.impl;
 
+import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
 import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
 import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
 import cc.mrbird.febs.common.exception.FebsException;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.mall.dto.ScoreSettingDto;
-import cc.mrbird.febs.mall.entity.DataDictionaryCustom;
-import cc.mrbird.febs.mall.entity.MallMember;
-import cc.mrbird.febs.mall.entity.MallMemberWallet;
-import cc.mrbird.febs.mall.entity.MallScoreSignRecord;
+import cc.mrbird.febs.mall.dto.signActivity.ApiSignDataDto;
+import cc.mrbird.febs.mall.dto.signActivity.ApiSignListDto;
+import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper;
 import cc.mrbird.febs.mall.mapper.MallMemberWalletMapper;
 import cc.mrbird.febs.mall.mapper.MallScoreSignRecordMapper;
 import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
 import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
 import cc.mrbird.febs.mall.service.IScoreService;
+import cc.mrbird.febs.mall.vo.ApiActivityInfoVo;
 import cc.mrbird.febs.mall.vo.ScoreSignVo;
-import cn.hutool.core.date.DateField;
+import cc.mrbird.febs.mall.vo.signActivity.ApiGetRunDateVo;
+import cc.mrbird.febs.mall.vo.signActivity.ApiSignListVo;
+import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateTime;
 import cn.hutool.core.date.DateUnit;
 import cn.hutool.core.date.DateUtil;
 import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
+import java.util.ArrayList;
 import java.util.Date;
+import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
+import java.util.stream.IntStream;
 
 /**
  * @author wzy
@@ -71,6 +81,86 @@
     }
 
     @Override
+    public List<ApiGetRunDateVo> signData(ApiSignDataDto dto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        DateTime dateTime = DateUtil.parseDate(dto.getDateStr());
+
+        DateTime startTime = DateUtil.beginOfMonth(dateTime);
+        DateTime endTime = DateUtil.endOfMonth(dateTime);
+        long between = DateUtil.between(startTime, endTime, DateUnit.DAY);
+        List<ApiGetRunDateVo> apiGetRunDateVos = generateDateList(startTime, between);
+
+        List<MallMoneyFlow> mallMoneyFlows = mallMoneyFlowService.getBaseMapper().selectList(
+                new LambdaQueryWrapper<MallMoneyFlow>()
+                        .eq(MallMoneyFlow::getMemberId, memberId)
+                        .eq(MallMoneyFlow::getFlowType, FlowTypeEnum.PRIZE_SCORE.getValue())
+                        .eq(MallMoneyFlow::getType, MoneyFlowTypeEnum.SCORE_SIGN.getValue())
+                        .ge(MallMoneyFlow::getCreatedTime, startTime)
+                        .le(MallMoneyFlow::getCreatedTime, endTime)
+        );
+        if(CollUtil.isNotEmpty(mallMoneyFlows)){
+            calculateProfits(apiGetRunDateVos,mallMoneyFlows);
+        }
+
+        return apiGetRunDateVos;
+    }
+
+    /**
+     * 生成日期列表
+     *
+     * @param startDate 开始日期
+     * @param days      从开始日期算起的天数
+     * @return 一个包含日期信息的ApiGetRunDateVo对象列表
+     */
+    private List<ApiGetRunDateVo> generateDateList(DateTime startDate, long days) {
+        // 使用IntStream生成从0到days(包含days)的整数流,表示每一天
+        return IntStream.range(0, (int) days + 1)
+                // 将每个整数映射为一个ApiGetRunDateVo对象
+                .mapToObj(i -> {
+                    // 创建ApiGetRunDateVo对象
+                    ApiGetRunDateVo apiGetRunDateVo = new ApiGetRunDateVo();
+                    // 计算日期:从起始日期开始偏移i天
+                    DateTime dateTime = DateUtil.offsetDay(startDate, i);
+                    // 格式化日期为"yyyy-MM-dd"字符串,并设置到对象中
+                    apiGetRunDateVo.setDateStr(DateUtil.format(dateTime, "yyyy-MM-dd"));
+                    // 初始化碳积分为0
+                    apiGetRunDateVo.setScore(BigDecimal.ZERO);
+                    // 返回构建好的对象
+                    return apiGetRunDateVo;
+                })
+                // 将流中的对象收集到一个列表中
+                .collect(Collectors.toList());
+    }
+    /**
+     * 计算每日累计碳积分
+     *
+     * @param dateList 日期列表,包含了每日的碳积分信息
+     * @param mallMoneyFlows 商城资金流列表,包含了每笔碳积分信息
+     */
+    private void calculateProfits(List<ApiGetRunDateVo> dateList, List<MallMoneyFlow> mallMoneyFlows) {
+        // 将日期列表转换为映射,以便通过日期快速访问每日碳积分信息
+        Map<String, ApiGetRunDateVo> dateMap = dateList.stream()
+                .collect(Collectors.toMap(ApiGetRunDateVo::getDateStr, vo -> vo));
+
+        // 遍历mallMoneyFlows
+        for (MallMoneyFlow item : mallMoneyFlows) {
+            // 格式化当前项的创建时间,提取日期
+            String date = DateUtil.format(item.getCreatedTime(), "yyyy-MM-dd");
+            // 从日期映射中获取对应的每日碳积分信息
+            ApiGetRunDateVo apiGetRunDateVo = dateMap.get(date);
+            // 如果找到了对应的每日碳积分信息
+            if (apiGetRunDateVo != null) {
+                // 获取当前日期的碳积分
+                BigDecimal score = apiGetRunDateVo.getScore();
+                // 计算新的碳积分,将碳积分与碳积分相加,并向下取整到个位数
+                BigDecimal profit = score.add(item.getAmount().abs()).setScale(0,BigDecimal.ROUND_DOWN);
+                // 更新每日碳积分信息的利润值
+                apiGetRunDateVo.setScore(profit);
+            }
+        }
+    }
+
+    @Override
     public MallScoreSignRecord judgeScoreIsContinuity(MallScoreSignRecord mallScoreSignRecord) {
         if (mallScoreSignRecord.getSignTime() == null) {
             return mallScoreSignRecord;
@@ -82,6 +172,35 @@
             mallScoreSignRecordMapper.updateById(mallScoreSignRecord);
         }
         return mallScoreSignRecord;
+    }
+
+    @Override
+    public FebsResponse signList(ApiSignListDto dto) {
+
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+
+        ArrayList<ApiSignListVo> apiSignListVos = new ArrayList<>();
+        // 创建分页对象,传入当前页和每页大小
+        Page<MallMoneyFlow> page = new Page<>(dto.getPageNow(), dto.getPageSize());
+        LambdaQueryWrapper<MallMoneyFlow> mallMoneyFlowLambdaQueryWrapper = new LambdaQueryWrapper<>();
+        mallMoneyFlowLambdaQueryWrapper
+                .select(MallMoneyFlow::getCreatedTime, MallMoneyFlow::getAmount)
+                .eq(MallMoneyFlow::getMemberId, memberId)
+                .eq(MallMoneyFlow::getFlowType, FlowTypeEnum.PRIZE_SCORE.getValue())
+                .eq(MallMoneyFlow::getType, MoneyFlowTypeEnum.SCORE_SIGN.getValue())
+                .orderByDesc(MallMoneyFlow::getId)
+        ;
+        // 调用Mapper方法获取活动分页数据
+        Page<MallMoneyFlow> mallMoneyFlowPage = mallMoneyFlowService.getBaseMapper().selectPage(page, mallMoneyFlowLambdaQueryWrapper);
+        if(CollUtil.isNotEmpty(mallMoneyFlowPage.getRecords())){
+            mallMoneyFlowPage.getRecords().forEach(item -> {
+                ApiSignListVo apiSignListVo = new ApiSignListVo();
+                apiSignListVo.setAmount(item.getAmount());
+                apiSignListVo.setCreatedTime(item.getCreatedTime());
+                apiSignListVos.add(apiSignListVo);
+            });
+        }
+        return new FebsResponse().success().data(apiSignListVos);
     }
 
     @Override
@@ -169,6 +288,11 @@
 
         BigDecimal amount = BigDecimal.valueOf(mallScoreSignRecord.getScore());
         walletService.add(amount, member.getId(), "prizeScore");
-        mallMoneyFlowService.addMoneyFlow(member.getId(), amount, MoneyFlowTypeEnum.SCORE_SIGN.getValue(), null, FlowTypeEnum.PRIZE_SCORE.getValue());
+        mallMoneyFlowService.addMoneyFlow(
+                member.getId(),
+                amount,
+                MoneyFlowTypeEnum.SCORE_SIGN.getValue(),
+                null,
+                FlowTypeEnum.PRIZE_SCORE.getValue());
     }
 }

--
Gitblit v1.9.1