From 2d25f8ca6ee3ebcdaa572169b2c478d23f6bd053 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Fri, 17 Jun 2022 17:44:28 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallActServiceImpl.java |   19 +++++++++++++++----
 1 files changed, 15 insertions(+), 4 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallActServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallActServiceImpl.java
index f95a34d..6dc0050 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallActServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallActServiceImpl.java
@@ -1,6 +1,8 @@
 package cc.mrbird.febs.mall.service.impl;
 
 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.ApiMallActListDto;
@@ -8,6 +10,8 @@
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.IApiMallActService;
+import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
+import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
 import cc.mrbird.febs.mall.vo.*;
 import cn.hutool.core.util.*;
 import cn.hutool.core.collection.CollUtil;
@@ -34,6 +38,8 @@
     private final MallActLuckdrawRecordMapper mallActLuckdrawRecordMapper;
     private final MallMemberWalletMapper mallMemberWalletMapper;
     private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
+    private final IMallMoneyFlowService mallMoneyFlowService;
+    private final IApiMallMemberWalletService mallMemberWalletService;
 
     @Override
     public IPage<ApiMallActListVo> findApiMallActListInPage(ApiMallActListDto apiMallActListDto) {
@@ -538,11 +544,16 @@
         }
 
         //扣竞猜积分
-        prizeScore = prizeScore.subtract(new BigDecimal(actScoreCnt));
-        wallet.setPrizeScore(prizeScore);
-        wallet.setCommission(commission);
-        mallMemberWalletMapper.updateAmountWithVersion(wallet);
+//        prizeScore = prizeScore.subtract(new BigDecimal(actScoreCnt));
+//        wallet.setPrizeScore(prizeScore);
+//        wallet.setCommission(commission);
+//        mallMemberWalletMapper.updateAmountWithVersion(wallet);
 
+        BigDecimal useScore = new BigDecimal(actScoreCnt);
+        mallMemberWalletService.reduce(useScore, wallet.getMemberId(), "prizeScore");
+        mallMemberWalletService.add(commission, wallet.getMemberId(), "commission");
+        mallMoneyFlowService.addMoneyFlow(wallet.getMemberId(), useScore.negate(), MoneyFlowTypeEnum.PRIZE.getValue(), null, FlowTypeEnum.PRIZE_SCORE.getValue());
+        mallMoneyFlowService.addMoneyFlow(wallet.getMemberId(), commission, MoneyFlowTypeEnum.PRIZE.getValue(), null, FlowTypeEnum.COMMISSION.getValue());
         return apiMallAwardDetailsVo;
     }
 

--
Gitblit v1.9.1