From 6c98fa6643e00e6a31b87d58184b6470f990e76f Mon Sep 17 00:00:00 2001 From: Hentua <wangdoubleone@gmail.com> Date: Tue, 25 Apr 2023 23:08:17 +0800 Subject: [PATCH] fix --- src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java | 201 +++++++++++++++++++++++++++++++++++++------------ 1 files changed, 151 insertions(+), 50 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 38d7485..5c12fec 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 @@ -6,27 +6,23 @@ import cc.mrbird.febs.common.enumerates.GreenScoreEnum; import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum; import cc.mrbird.febs.common.exception.FebsException; +import cc.mrbird.febs.common.utils.AppContants; import cc.mrbird.febs.common.utils.LoginUserUtil; import cc.mrbird.febs.common.utils.MallUtils; import cc.mrbird.febs.mall.conversion.MallOrderInfoConversion; -import cc.mrbird.febs.mall.dto.ApiMallScoreSignRecordDto; -import cc.mrbird.febs.mall.dto.ApiScoreVoucherRecordDto; -import cc.mrbird.febs.mall.dto.ApiVoucherBusinessDto; -import cc.mrbird.febs.mall.dto.ScoreSettingDto; +import cc.mrbird.febs.mall.dto.*; import cc.mrbird.febs.mall.entity.*; import cc.mrbird.febs.mall.mapper.*; import cc.mrbird.febs.mall.service.IApiMallMemberService; 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.ApiScoreVoucherInfoVo; -import cc.mrbird.febs.mall.vo.ApiScoreVoucherRecordVo; -import cc.mrbird.febs.mall.vo.ScoreSignVo; +import cc.mrbird.febs.mall.vo.*; 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 cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; import cn.hutool.crypto.SecureUtil; import com.alibaba.fastjson.JSONObject; @@ -39,8 +35,10 @@ import org.springframework.transaction.annotation.Transactional; import java.math.BigDecimal; +import java.math.RoundingMode; import java.util.Date; import java.util.List; +import java.util.Map; /** * @author wzy @@ -59,6 +57,10 @@ private final MallMemberMapper mallMemberMapper; private final MallScoreVoucherMapper mallScoreVoucherMapper; private final IApiMallMemberWalletService memberWalletService; + private final MallMemberBankMapper mallMemberBankMapper; + private final MallMemberWithdrawMapper mallMemberWithdrawMapper; + private final IApiMallMemberService mallMemberService; + private final MallMoneyFlowMapper mallMoneyFlowMapper; @Override public ScoreSignVo scoreSign() { @@ -69,10 +71,17 @@ ScoreSignVo scoreSign = new ScoreSignVo(); scoreSign.setMineScore(wallet.getPrizeScore().intValue()); - DataDictionaryCustom signScpreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( - DataDictionaryEnum.SIGN_SCORE.getType(), DataDictionaryEnum.SIGN_SCORE.getCode()); + MallScoreSignRecord mallScoreSignRecord = mallScoreSignRecordMapper.selectRecentSignRecord(member.getId()); + if (mallScoreSignRecord == null) { + scoreSign.setHasSignDays(0); + } else { + mallScoreSignRecord = judgeScoreIsContinuity(mallScoreSignRecord); + scoreSign.setHasSignDays(mallScoreSignRecord.getTotalCnt()); + } + + DataDictionaryCustom signScpreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.SCORE_SIGN_SETTING.getType(), DataDictionaryEnum.SCORE_SIGN_SETTING.getCode()); if (signScpreDic != null) { - scoreSign.setSetting(Integer.parseInt(signScpreDic.getValue())); + scoreSign.setSetting(JSONObject.parseObject(signScpreDic.getValue(), ScoreSettingDto.class)); } return scoreSign; } @@ -109,6 +118,7 @@ MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(member.getId()); apiScoreVoucherInfoVo.setVoucherCnt(mallMemberWallet.getVoucherCnt().compareTo(BigDecimal.ZERO) < 0 ? BigDecimal.ZERO : mallMemberWallet.getVoucherCnt()); apiScoreVoucherInfoVo.setVoucherAmount(mallMemberWallet.getVoucherAmount().compareTo(BigDecimal.ZERO) < 0 ? BigDecimal.ZERO : mallMemberWallet.getVoucherAmount()); + apiScoreVoucherInfoVo.setVoucherFireCnt(mallMemberWallet.getVoucherFireCnt().compareTo(BigDecimal.ZERO) < 0 ? BigDecimal.ZERO : mallMemberWallet.getVoucherFireCnt()); DataDictionaryCustom scorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( GreenScoreEnum.SCORE_PRICE.getType(), GreenScoreEnum.SCORE_PRICE.getCode()); @@ -174,7 +184,9 @@ scorePoolCntDic.setValue(scorePoolCnt.toString()); dataDictionaryCustomMapper.updateById(scorePoolCntDic); //增加凭证数量 - mallMemberWalletMapper.addVorCherCntByMemberId(voucherCnt,memberId); +// mallMemberWalletMapper.addVorCherCntByMemberId(voucherCnt,memberId); + //增加凭证燃烧值数量 + mallMemberWalletMapper.addVorCherFireCntByMemberId(voucherCnt,memberId); //增加购买记录 String voucherNo = MallUtils.getOrderNum("VB"); MallScoreVoucher mallScoreVoucher = new MallScoreVoucher(); @@ -221,7 +233,7 @@ MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId); BigDecimal voucherCntMember = mallMemberWallet.getVoucherCnt(); if(voucherCntMember.compareTo(voucherCnt) < 0){ - throw new FebsException("绿色积分不足"); + throw new FebsException("数量不足"); } DataDictionaryCustom scorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( @@ -258,8 +270,78 @@ voucherAmount, MoneyFlowTypeEnum.VOUCHER_SALE.getValue(), voucherNo, - FlowTypeEnum.VOUCHER_AMOUNT.getValue()); + FlowTypeEnum.BALANCE.getValue()); return new FebsResponse().success().message("操作成功"); + } + + @Override + @Transactional(rollbackFor = Exception.class) + public void withdrawal(WithdrawalDto withdrawalDto) { + Long memberId = LoginUserUtil.getLoginUser().getId(); + MallMember mallMember = mallMemberMapper.selectById(memberId); + if (StrUtil.isBlank(mallMember.getTradePassword())) { + throw new FebsException("未设置支付密码"); + } + + if (!mallMember.getTradePassword().equals(SecureUtil.md5(withdrawalDto.getTradePwd()))) { + throw new FebsException("支付密码错误"); + } + + CashOutSettingVo cashOutSettingVo = new CashOutSettingVo(); + DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.CASHOUT_SETTING.getType(), DataDictionaryEnum.CASHOUT_SETTING.getCode()); + if (dic != null) { + cashOutSettingVo = JSONObject.parseObject(dic.getValue(), CashOutSettingVo.class); + } + + if (withdrawalDto.getAmount().compareTo(cashOutSettingVo.getMinCashOut()) < 0) { + throw new FebsException("最小提现金额为"+cashOutSettingVo.getMinCashOut().setScale(2, RoundingMode.DOWN)); + } + + MallMemberBank mallMemberBank = mallMemberBankMapper.selectById(withdrawalDto.getBankId()); + if(ObjectUtil.isEmpty(mallMemberBank)){ + throw new FebsException("未找到银行卡信息"); + } + + MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(memberId); + BigDecimal profit = mallMoneyFlowMapper.selectProfitByDateAndMemberId(memberId); + + BigDecimal canMoney = wallet.getCommission(); + if (profit != null) { + if(canMoney.compareTo(BigDecimal.ZERO) > 0) { + canMoney = canMoney.subtract(profit); + } + } + + if(withdrawalDto.getAmount().compareTo(canMoney) > 0) { + throw new FebsException("金额不足"); + } + + int flag = walletService.reduce(withdrawalDto.getAmount(), memberId, "commission"); + if (flag == 2) { + throw new FebsException("请刷新页面后重新提现"); + } + + String orderNo = MallUtils.getOrderNum("W"); + + MallMemberWithdraw withdraw = new MallMemberWithdraw(); + withdraw.setWithdrawNo(orderNo); + withdraw.setMemberId(memberId); + withdraw.setAmount(withdrawalDto.getAmount()); + withdraw.setStatus(1); + withdraw.setAmountFee(BigDecimal.ZERO); + withdraw.setWtihdrawTypeId(mallMemberBank.getId()); + mallMemberWithdrawMapper.insert(withdraw); + + mallMemberService.addMoneyFlow(memberId, withdrawalDto.getAmount().negate(), MoneyFlowTypeEnum.WITHDRAWAL.getValue(), orderNo, null, null, null, 1, FlowTypeEnum.COMMISSION.getValue()); + } + + @Override + public FebsResponse findMallScoreVoucherListInPage(ApiScoreVoucherRecordDto apiScoreVoucherRecordDto) { + IPage<ApiScoreVoucherRecordVo> page = new Page<>(apiScoreVoucherRecordDto.getPageNum(), apiScoreVoucherRecordDto.getPageSize()); + Long id = LoginUserUtil.getLoginUser().getId(); + apiScoreVoucherRecordDto.setMemberId(id); + IPage<ApiScoreVoucherRecordVo> pages = mallScoreVoucherMapper.findMallScoreVoucherListInPage(page, apiScoreVoucherRecordDto); + return new FebsResponse().success().data(pages); } @Override @@ -267,13 +349,10 @@ public void sign() { MallMember member = LoginUserUtil.getLoginUser(); - DataDictionaryCustom signScoreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( - DataDictionaryEnum.SIGN_SCORE.getType(), - DataDictionaryEnum.SIGN_SCORE.getCode()); - if (signScoreDic == null) { - throw new FebsException("签到活动未开启"); + DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.SCORE_SIGN_SETTING.getType(), DataDictionaryEnum.SCORE_SIGN_SETTING.getCode()); + if (dic == null) { + throw new FebsException("暂未设置积分"); } - Integer signScore = Integer.parseInt(signScoreDic.getValue()); MallScoreSignRecord mallScoreSignRecord = mallScoreSignRecordMapper.selectRecentSignRecord(member.getId()); if (mallScoreSignRecord == null) { @@ -281,45 +360,67 @@ } if (mallScoreSignRecord.getSignTime() != null && DateUtil.betweenDay(mallScoreSignRecord.getSignTime(), new Date(), true) == 0) { - throw new FebsException("今日已签到"); + throw new FebsException("今天已签到"); } - /** - * 用户注册时间开始计算 - * 判断签到时间是否大于规定的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()); - MallMember mallMember = mallMemberMapper.selectById(member.getId()); - Date createdTime = mallMember.getCreatedTime(); + mallScoreSignRecord = judgeScoreIsContinuity(mallScoreSignRecord); - DateTime dateTime = DateUtil.offsetDay(createdTime, signScoreDays); - /** - * 签到时间不在系统设置的第一个阶段,则获取签到设置-签到积分后续获得积分数量 - */ - if(DateUtil.compare(dateTime, new Date()) < 0){ - DataDictionaryCustom signScoreCntDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( - DataDictionaryEnum.SIGN_SCORE_CNT.getType(), - DataDictionaryEnum.SIGN_SCORE_CNT.getCode()); - Integer signScoreCnt = Integer.parseInt(signScoreCntDic.getValue()); - signScore = signScoreCnt; + 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; + default: + break; } + mallScoreSignRecord.setMemberId(member.getId()); - mallScoreSignRecord.setTotalCnt(signScore); + mallScoreSignRecord.setTotalCnt(days); 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