From 05c40a68b5664c5ed41dbaa57ba30f0c73757b26 Mon Sep 17 00:00:00 2001 From: Hentua <wangdoubleone@gmail.com> Date: Tue, 25 Apr 2023 11:10:48 +0800 Subject: [PATCH] fix --- src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java | 138 +++++++++++++++++++++++++++++---------------- 1 files changed, 89 insertions(+), 49 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 0f0581c..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 @@ -35,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 @@ -58,6 +60,7 @@ private final MallMemberBankMapper mallMemberBankMapper; private final MallMemberWithdrawMapper mallMemberWithdrawMapper; private final IApiMallMemberService mallMemberService; + private final MallMoneyFlowMapper mallMoneyFlowMapper; @Override public ScoreSignVo scoreSign() { @@ -68,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; } @@ -108,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()); @@ -173,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(); @@ -220,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( @@ -257,14 +270,13 @@ 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())) { @@ -282,7 +294,7 @@ } if (withdrawalDto.getAmount().compareTo(cashOutSettingVo.getMinCashOut()) < 0) { - throw new FebsException("最小提现金额为"+cashOutSettingVo.getMinCashOut().setScale(2,BigDecimal.ROUND_DOWN)); + throw new FebsException("最小提现金额为"+cashOutSettingVo.getMinCashOut().setScale(2, RoundingMode.DOWN)); } MallMemberBank mallMemberBank = mallMemberBankMapper.selectById(withdrawalDto.getBankId()); @@ -291,14 +303,24 @@ } MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(memberId); - // 可提现 - BigDecimal canMoney = wallet.getVoucherAmount(); + 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("金额不足"); } - walletService.reduce(withdrawalDto.getAmount(), memberId, "voucher_amount"); + int flag = walletService.reduce(withdrawalDto.getAmount(), memberId, "commission"); + if (flag == 2) { + throw new FebsException("请刷新页面后重新提现"); + } + String orderNo = MallUtils.getOrderNum("W"); MallMemberWithdraw withdraw = new MallMemberWithdraw(); @@ -307,11 +329,10 @@ withdraw.setAmount(withdrawalDto.getAmount()); withdraw.setStatus(1); withdraw.setAmountFee(BigDecimal.ZERO); - withdraw.setRemark(AppContants.MEMBER_WITHDRAW_VOUCHER_AMOUNT); withdraw.setWtihdrawTypeId(mallMemberBank.getId()); mallMemberWithdrawMapper.insert(withdraw); - mallMemberService.addMoneyFlow(memberId, withdrawalDto.getAmount().negate(), MoneyFlowTypeEnum.WITHDRAWAL.getValue(), orderNo, null, null, null, 1, FlowTypeEnum.VOUCHER_AMOUNT.getValue()); + mallMemberService.addMoneyFlow(memberId, withdrawalDto.getAmount().negate(), MoneyFlowTypeEnum.WITHDRAWAL.getValue(), orderNo, null, null, null, 1, FlowTypeEnum.COMMISSION.getValue()); } @Override @@ -328,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) { @@ -342,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