From c8553669f87a7bc4df3b2279ad4473b6b212a127 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Wed, 15 Mar 2023 14:46:42 +0800 Subject: [PATCH] 后台修改 --- src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java | 123 +++++++++++++++++----------------------- 1 files changed, 52 insertions(+), 71 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 62d0087..7697f74 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 @@ -5,23 +5,26 @@ 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.conversion.MallOrderInfoConversion; +import cc.mrbird.febs.mall.dto.ApiMallScoreSignRecordDto; 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.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.ApiMallScoreSignRecordVo; import cc.mrbird.febs.mall.vo.ScoreSignVo; import cn.hutool.core.date.DateField; 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.QueryWrapper; +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; @@ -29,6 +32,7 @@ import java.math.BigDecimal; import java.util.Date; +import java.util.List; /** * @author wzy @@ -51,21 +55,13 @@ MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(member.getId()); - MallScoreSignRecord mallScoreSignRecord = mallScoreSignRecordMapper.selectRecentSignRecord(member.getId()); - ScoreSignVo scoreSign = new ScoreSignVo(); scoreSign.setMineScore(wallet.getPrizeScore().intValue()); - if (mallScoreSignRecord == null) { - scoreSign.setHasSignDays(0); - } else { - mallScoreSignRecord = judgeScoreIsContinuity(mallScoreSignRecord); - scoreSign.setHasSignDays(mallScoreSignRecord.getTotalCnt()); - } - - DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.SCORE_SIGN_SETTING.getType(), DataDictionaryEnum.SCORE_SIGN_SETTING.getCode()); - if (dic != null) { - scoreSign.setSetting(JSONObject.parseObject(dic.getValue(), ScoreSettingDto.class)); + DataDictionaryCustom signScpreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + DataDictionaryEnum.SIGN_SCORE.getType(), DataDictionaryEnum.SIGN_SCORE.getCode()); + if (signScpreDic != null) { + scoreSign.setSetting(Integer.parseInt(signScpreDic.getValue())); } return scoreSign; } @@ -85,14 +81,27 @@ } @Override + public List<ApiMallScoreSignRecordVo> findMallScoreSignRecordList(ApiMallScoreSignRecordDto apiMallScoreSignRecordDto) { + + MallMember member = LoginUserUtil.getLoginUser(); + IPage<ApiMallScoreSignRecordVo> page = new Page<>(apiMallScoreSignRecordDto.getPageNum(), apiMallScoreSignRecordDto.getPageSize()); + apiMallScoreSignRecordDto.setMemberId(member.getId()); + IPage<ApiMallScoreSignRecordVo> apiMallScoreSignRecordVos = mallScoreSignRecordMapper.selectApiOrderListInPage(page, apiMallScoreSignRecordDto); + return apiMallScoreSignRecordVos.getRecords(); + } + + @Override @Transactional(rollbackFor = Exception.class) public void sign() { MallMember member = LoginUserUtil.getLoginUser(); - DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.SCORE_SIGN_SETTING.getType(), DataDictionaryEnum.SCORE_SIGN_SETTING.getCode()); - if (dic == null) { - throw new FebsException("暂未设置积分"); + DataDictionaryCustom signScoreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + DataDictionaryEnum.SIGN_SCORE.getType(), + DataDictionaryEnum.SIGN_SCORE.getCode()); + if (signScoreDic == null) { + throw new FebsException("签到活动未开启"); } + Integer signScore = Integer.parseInt(signScoreDic.getValue()); MallScoreSignRecord mallScoreSignRecord = mallScoreSignRecordMapper.selectRecentSignRecord(member.getId()); if (mallScoreSignRecord == null) { @@ -100,65 +109,37 @@ } if (mallScoreSignRecord.getSignTime() != null && DateUtil.betweenDay(mallScoreSignRecord.getSignTime(), new Date(), true) == 0) { - throw new FebsException("今天已签到"); + throw new FebsException("今日已签到"); } - - mallScoreSignRecord = judgeScoreIsContinuity(mallScoreSignRecord); - - ScoreSettingDto scoreSetting = JSONObject.parseObject(dic.getValue(),ScoreSettingDto.class); - int days = mallScoreSignRecord.getTotalCnt() == null ? 1 : mallScoreSignRecord.getTotalCnt() + 1; - switch (days) { - case 1: - if (scoreSetting.getSignInOne() == null) { - throw new FebsException("积分未设置"); - } - mallScoreSignRecord.setScore(scoreSetting.getSignInOne()); - break; - case 2: - if (scoreSetting.getSignInTwo() == null) { - throw new FebsException("积分未设置"); - } - mallScoreSignRecord.setScore(scoreSetting.getSignInTwo()); - break; - case 3: - if (scoreSetting.getSignInThree() == null) { - throw new FebsException("积分未设置"); - } - mallScoreSignRecord.setScore(scoreSetting.getSignInThree()); - break; - case 4: - if (scoreSetting.getSignInFour() == null) { - throw new FebsException("积分未设置"); - } - mallScoreSignRecord.setScore(scoreSetting.getSignInFour()); - break; - case 5: - if (scoreSetting.getSignInFive() == null) { - throw new FebsException("积分未设置"); - } - mallScoreSignRecord.setScore(scoreSetting.getSignInFive()); - break; - case 6: - if (scoreSetting.getSignInSix() == null) { - throw new FebsException("积分未设置"); - } - mallScoreSignRecord.setScore(scoreSetting.getSignInSix()); - break; - case 7: - if (scoreSetting.getSignInSeven() == null) { - throw new FebsException("积分未设置"); - } - mallScoreSignRecord.setScore(scoreSetting.getSignInSeven()); - break; + /** + * 获取签到次数 + * 判断签到次数是否大于规定的时长signScoreDays,超出则获得的积分数为signScoreCnt + */ + Integer count = mallScoreSignRecordMapper.selectCountByMemberId(member.getId()); + DataDictionaryCustom signScoreDaysDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + DataDictionaryEnum.SIGN_SCORE_DAYS.getType(), + DataDictionaryEnum.SIGN_SCORE_DAYS.getCode()); + Integer signScoreDays = Integer.parseInt(signScoreDaysDic.getValue()); + if(count >= signScoreDays){ + DataDictionaryCustom signScoreCntDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + DataDictionaryEnum.SIGN_SCORE_CNT.getType(), + DataDictionaryEnum.SIGN_SCORE_CNT.getCode()); + Integer signScoreCnt = Integer.parseInt(signScoreCntDic.getValue()); + signScore = signScoreCnt; } - mallScoreSignRecord.setMemberId(member.getId()); - mallScoreSignRecord.setTotalCnt(days); + mallScoreSignRecord.setTotalCnt(signScore); mallScoreSignRecord.setSignTime(new Date()); + mallScoreSignRecord.setScore(signScore); mallScoreSignRecordMapper.insert(mallScoreSignRecord); 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