From bac072f518a357363ae3f201beb665021cd75efc Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Mon, 03 Apr 2023 18:13:51 +0800
Subject: [PATCH] 关于积分凭证

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ScoreServiceImpl.java |  177 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 173 insertions(+), 4 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 6f6bf9a..38d7485 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,28 +1,34 @@
 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.GreenScoreEnum;
 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.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.entity.*;
-import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper;
-import cc.mrbird.febs.mall.mapper.MallMemberMapper;
-import cc.mrbird.febs.mall.mapper.MallMemberWalletMapper;
-import cc.mrbird.febs.mall.mapper.MallScoreSignRecordMapper;
+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 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.StrUtil;
+import cn.hutool.crypto.SecureUtil;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
@@ -51,6 +57,8 @@
     private final IMallMoneyFlowService mallMoneyFlowService;
     private final IApiMallMemberWalletService walletService;
     private final MallMemberMapper mallMemberMapper;
+    private final MallScoreVoucherMapper mallScoreVoucherMapper;
+    private final IApiMallMemberWalletService memberWalletService;
 
     @Override
     public ScoreSignVo scoreSign() {
@@ -94,6 +102,167 @@
     }
 
     @Override
+    public ApiScoreVoucherInfoVo memberScoreVoucher() {
+        MallMember member = LoginUserUtil.getLoginUser();
+        ApiScoreVoucherInfoVo apiScoreVoucherInfoVo = new ApiScoreVoucherInfoVo();
+
+        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());
+        DataDictionaryCustom scorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                GreenScoreEnum.SCORE_PRICE.getType(),
+                GreenScoreEnum.SCORE_PRICE.getCode());
+        apiScoreVoucherInfoVo.setScorePrice(new BigDecimal(scorePriceDic.getValue()).setScale(2,BigDecimal.ROUND_DOWN));
+        DataDictionaryCustom scorePoolCntDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                GreenScoreEnum.SCORE_POOL_CNT.getType(),
+                GreenScoreEnum.SCORE_POOL_CNT.getCode());
+        apiScoreVoucherInfoVo.setScorePoolCnt(new BigDecimal(scorePoolCntDic.getValue()).setScale(2,BigDecimal.ROUND_DOWN));
+        return apiScoreVoucherInfoVo;
+    }
+
+    @Override
+    public List<ApiScoreVoucherRecordVo> findMallScoreVoucherList(ApiScoreVoucherRecordDto apiScoreVoucherRecordDto) {
+        IPage<ApiScoreVoucherRecordVo> page = new Page<>(apiScoreVoucherRecordDto.getPageNum(), apiScoreVoucherRecordDto.getPageSize());
+        IPage<ApiScoreVoucherRecordVo> apiScoreVoucherRecordVoIPage = mallScoreVoucherMapper.findMallScoreVoucherListInPage(page, apiScoreVoucherRecordDto);
+        return apiScoreVoucherRecordVoIPage.getRecords();
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public FebsResponse voucherBusinessBuy(ApiVoucherBusinessDto apiVoucherBusinessDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        BigDecimal voucherCnt = apiVoucherBusinessDto.getVoucherCnt();
+        if(voucherCnt.compareTo(BigDecimal.ZERO) <= 0){
+            throw new FebsException("请输入合理的数量");
+        }
+        DataDictionaryCustom scorePoolCntDic = dataDictionaryCustomMapper.selectScorePoolCntForUpdate(
+                GreenScoreEnum.SCORE_POOL_CNT.getType(),
+                GreenScoreEnum.SCORE_POOL_CNT.getCode());
+        BigDecimal scorePoolCnt = new BigDecimal(scorePoolCntDic.getValue() == null ? "0" : scorePoolCntDic.getValue());
+        if(scorePoolCnt.compareTo(voucherCnt) < 0){
+            throw new FebsException("可购买总量不足");
+        }
+        String tradePassword = apiVoucherBusinessDto.getTradePassword();
+        if (StrUtil.isBlank(tradePassword)) {
+            throw new FebsException("支付密码错误");
+        }
+
+        MallMember mallMember = mallMemberMapper.selectById(memberId);
+        if (StrUtil.isBlank(mallMember.getTradePassword())) {
+            throw new FebsException("未设置支付密码");
+        }
+
+        if (!SecureUtil.md5(tradePassword).equals(mallMember.getTradePassword())) {
+            throw new FebsException("支付密码错误");
+        }
+
+        DataDictionaryCustom scorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                GreenScoreEnum.SCORE_PRICE.getType(),
+                GreenScoreEnum.SCORE_PRICE.getCode());
+        BigDecimal scorePrice = new BigDecimal(scorePriceDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN);
+        BigDecimal voucherAmount = voucherCnt.multiply(scorePrice);
+
+        MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
+        BigDecimal balance = mallMemberWallet.getBalance();
+        if(voucherAmount.compareTo(balance) > 0){
+            throw new FebsException("余额不足");
+        }
+        //减少余额
+        memberWalletService.reduceBalance(voucherAmount,memberId);
+        //减少绿色积分池
+        scorePoolCnt = scorePoolCnt.subtract(voucherCnt);
+        scorePoolCntDic.setValue(scorePoolCnt.toString());
+        dataDictionaryCustomMapper.updateById(scorePoolCntDic);
+        //增加凭证数量
+        mallMemberWalletMapper.addVorCherCntByMemberId(voucherCnt,memberId);
+        //增加购买记录
+        String voucherNo = MallUtils.getOrderNum("VB");
+        MallScoreVoucher mallScoreVoucher = new MallScoreVoucher();
+        mallScoreVoucher.setVoucherNo(voucherNo);
+        mallScoreVoucher.setMemberId(memberId);
+        mallScoreVoucher.setVoucherCnt(voucherCnt);
+        mallScoreVoucher.setPrice(scorePrice);
+        mallScoreVoucher.setVoucherAmount(voucherAmount);
+        mallScoreVoucher.setType("B");
+        mallScoreVoucherMapper.insert(mallScoreVoucher);
+
+        //产生一条流水记录
+        mallMoneyFlowService.addMoneyFlow(
+                mallMemberWallet.getMemberId(),
+                voucherCnt,
+                MoneyFlowTypeEnum.VOUCHER_BUY.getValue(),
+                voucherNo,
+                FlowTypeEnum.VOUCHER_CNT.getValue());
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public FebsResponse voucherBusinessSale(ApiVoucherBusinessDto apiVoucherBusinessDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        BigDecimal voucherCnt = apiVoucherBusinessDto.getVoucherCnt();
+        if(voucherCnt.compareTo(BigDecimal.ZERO) <= 0){
+            throw new FebsException("请输入合理的数量");
+        }
+        String tradePassword = apiVoucherBusinessDto.getTradePassword();
+        if (StrUtil.isBlank(tradePassword)) {
+            throw new FebsException("支付密码错误");
+        }
+
+        MallMember mallMember = mallMemberMapper.selectById(memberId);
+        if (StrUtil.isBlank(mallMember.getTradePassword())) {
+            throw new FebsException("未设置支付密码");
+        }
+
+        if (!SecureUtil.md5(tradePassword).equals(mallMember.getTradePassword())) {
+            throw new FebsException("支付密码错误");
+        }
+
+        MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
+        BigDecimal voucherCntMember = mallMemberWallet.getVoucherCnt();
+        if(voucherCntMember.compareTo(voucherCnt) < 0){
+            throw new FebsException("绿色积分不足");
+        }
+
+        DataDictionaryCustom scorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                GreenScoreEnum.SCORE_PRICE.getType(),
+                GreenScoreEnum.SCORE_PRICE.getCode());
+        BigDecimal scorePrice = new BigDecimal(scorePriceDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN);
+        BigDecimal voucherAmount = voucherCnt.multiply(scorePrice);
+        //减少凭证积分
+        //增加凭证现金
+        mallMemberWalletMapper.addVorCherAmountAndCntById(voucherAmount,voucherCnt,mallMemberWallet.getId());
+        //增加积分池
+        DataDictionaryCustom scorePoolCntDic = dataDictionaryCustomMapper.selectScorePoolCntForUpdate(
+                GreenScoreEnum.SCORE_POOL_CNT.getType(),
+                GreenScoreEnum.SCORE_POOL_CNT.getCode());
+        BigDecimal scorePoolCnt = new BigDecimal(scorePoolCntDic.getValue() == null ? "0" : scorePoolCntDic.getValue());
+        scorePoolCnt = scorePoolCnt.add(voucherCnt).setScale(2,BigDecimal.ROUND_DOWN);
+        scorePoolCntDic.setValue(scorePoolCnt.toString());
+        dataDictionaryCustomMapper.updateById(scorePoolCntDic);
+
+        //增加购买记录
+        String voucherNo = MallUtils.getOrderNum("VS");
+        MallScoreVoucher mallScoreVoucher = new MallScoreVoucher();
+        mallScoreVoucher.setVoucherNo(voucherNo);
+        mallScoreVoucher.setMemberId(memberId);
+        mallScoreVoucher.setVoucherCnt(voucherCnt);
+        mallScoreVoucher.setPrice(scorePrice);
+        mallScoreVoucher.setVoucherAmount(voucherAmount);
+        mallScoreVoucher.setType("S");
+        mallScoreVoucherMapper.insert(mallScoreVoucher);
+
+        //产生一条流水记录
+        mallMoneyFlowService.addMoneyFlow(
+                mallMemberWallet.getMemberId(),
+                voucherAmount,
+                MoneyFlowTypeEnum.VOUCHER_SALE.getValue(),
+                voucherNo,
+                FlowTypeEnum.VOUCHER_AMOUNT.getValue());
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
     @Transactional(rollbackFor = Exception.class)
     public void sign() {
         MallMember member = LoginUserUtil.getLoginUser();

--
Gitblit v1.9.1