From f2070facdb5715e7349df69cfe257289c680d292 Mon Sep 17 00:00:00 2001
From: huliguo <2023611923@qq.com>
Date: 星期三, 23 四月 2025 18:12:46 +0800
Subject: [PATCH] 前端联调

---
 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserPointServiceImpl.java |  135 +++++++++++++++++++++++++++++++++------------
 1 files changed, 99 insertions(+), 36 deletions(-)

diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserPointServiceImpl.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserPointServiceImpl.java
index 2aff81d..2f1c2e9 100644
--- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserPointServiceImpl.java
+++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserPointServiceImpl.java
@@ -7,16 +7,19 @@
 import com.ruoyi.account.api.model.*;
 import com.ruoyi.account.mapper.UserPointMapper;
 import com.ruoyi.account.service.*;
-import com.ruoyi.account.vo.UserPointDetailVO;
-import com.ruoyi.account.vo.UserPointStatistics;
-import com.ruoyi.account.vo.UserPointVO;
+import com.ruoyi.account.vo.*;
+import com.ruoyi.common.core.annotation.Excel;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.utils.PhoneNumberValidator;
+import com.ruoyi.common.core.utils.StringUtils;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.other.api.enums.PointChangeType;
+import com.ruoyi.system.api.domain.SysConfig;
+import com.ruoyi.system.api.feignClient.SysConfigClient;
 import com.ruoyi.system.api.model.LoginUser;
 import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
@@ -42,26 +45,33 @@
     private TokenService tokenService;
     @Resource
     private UserPointService userPointService;
-    
-
-
+    @Resource
+    private SysConfigClient sysConfigClient;
+    @Autowired
+    private UserPointMapper userPointMapper;
 
 
     @Override
     public UserPointVO getUserPoint(Long userId) {
         AppUser appUser = appUserService.getById(userId);
-        int totalPoint = 0;
-        int sharePoint = 0;
-        int shopAchievementPoint = 0;
-        int shopSharePoint = 0;
         UserPointVO userPointVO = new UserPointVO();
-        userPointVO.setTotalPoint(appUser.getTotalPoint() + totalPoint);
+        userPointVO.setTotalPoint(appUser.getTotalPoint() );
         userPointVO.setConsumePoint(appUser.getAvailablePoint());
-        userPointVO.setShopPoint(appUser.getShopPoint());
-        userPointVO.setSharePoint(appUser.getSharePoint() + sharePoint);
-        userPointVO.setPullNewPoint(appUser.getTotalInvitePoint());
-        userPointVO.setShopAchievementPoint(appUser.getShopAchievementPoint() + shopAchievementPoint);
-        userPointVO.setShopSharePoint(appUser.getShopSharePoint() + shopSharePoint);
+        userPointVO.setRechargePoint(appUser.getRechargePoint());
+        userPointVO.setCancelPoint(appUser.getCancelPoint());
+        userPointVO.setExpendPoint(appUser.getExchangePoint());
+        userPointVO.setTransferableInPoint(appUser.getTransferableInPoint());
+        userPointVO.setTransferableOutPoint(appUser.getTransferableOutPoint());
+        R<SysConfig> info = sysConfigClient.getInfo(9L);
+        if (info == null || info.getData() == null) {
+            throw new RuntimeException("获取积分兑换比例配置失败");
+        }
+        String configValue = info.getData().getConfigValue();
+        if (StringUtils.isBlank(configValue)) {
+            throw new RuntimeException("积分兑换比例配置值为空");
+        }
+        Boolean isTransferable = Boolean.valueOf(configValue.trim());
+        userPointVO.setIsTransferable(isTransferable);
         return userPointVO;
     }
 
@@ -74,12 +84,16 @@
         for (UserPointDetailVO userPointDetailVO : userPointDetail) {
             Integer type1 = userPointDetailVO.getType();
             if (type1 != null && type1.equals(12)){
-                AppUser appUser = appUserService.getById(userPointDetailVO.getReceiveUserId());
+                //他人赠送
+                AppUser appUser = appUserService.getById(userPointDetailVO.getObjectId());
                 userPointDetailVO.setName(appUser.getName());
+                userPointDetailVO.setTransferUserId(appUser.getId());
             }
             if (type1 != null && type1.equals(13)){
-                AppUser appUser = appUserService.getById(userPointDetailVO.getTransferUserId());
+                //赠予他人
+                AppUser appUser = appUserService.getById(userPointDetailVO.getObjectId());
                 userPointDetailVO.setName(appUser.getName());
+                userPointDetailVO.setReceiveUserId(appUser.getId());
             }
             Integer historicalPoint = userPointDetailVO.getHistoricalPoint();
             Integer balance = userPointDetailVO.getBalance();
@@ -107,10 +121,8 @@
         if (appUser == null) {
             return R.fail("用户未找到");
         }
-        // 可转赠积分总数
-        Integer transferablePoint = appUser.getTransferablePoint();
-        if (point > transferablePoint) {
-            return R.fail("可转赠积分不足");
+        if (appUser.getAvailablePoint() < point) {
+            return R.fail("用户可用积分不足");
         }
 
         AppUser appUserForPhoe = appUserService.getOne(new LambdaQueryWrapper<AppUser>()
@@ -124,38 +136,65 @@
         if(appUserForPhoe.getId().equals(userid)){
             return R.fail("不能转增给自己");
         }
-        Integer lavePoint1 = appUserForPhoe.getLavePoint();
-        appUserForPhoe.setLavePoint(appUserForPhoe.getLavePoint() + point);
-        appUserForPhoe.setTotalPoint(appUserForPhoe.getTotalPoint() + point);
-        appUserForPhoe.setTransferablePoint(transferablePoint + point);
-        appUserForPhoe.setAvailablePoint(appUserForPhoe.getAvailablePoint() + point);
-        appUserForPhoe.setTotalAvailablePoint(appUserForPhoe.getTotalAvailablePoint() + point);
+
+        if (null==appUserForPhoe.getTotalPoint()){
+            appUserForPhoe.setTotalPoint(0);
+        }
+        if (null==appUserForPhoe.getTransferableInPoint()){
+            appUserForPhoe.setTransferableInPoint(0);
+        }
+        if(null==appUserForPhoe.getAvailablePoint()){
+            appUserForPhoe.setAvailablePoint(0);
+        }
+
+        Integer historicalPoint = appUserForPhoe.getAvailablePoint();//历史积分
+        Integer balance = historicalPoint +point;//变动后积分
+
+        appUserForPhoe.setAvailablePoint(balance);//可用积分增加
+
+        appUserForPhoe.setTotalPoint(appUserForPhoe.getTotalPoint() + point);//总积分增加
+        appUserForPhoe.setTransferableInPoint(appUserForPhoe.getTransferableInPoint() + point);//转入积分增加
+
         appUserService.updateById(appUserForPhoe);
         //构建积分流水记录
         if(point > 0){
+            //转入用户
             UserPoint userPoint = new UserPoint();
             userPoint.setType(12);
-            userPoint.setHistoricalPoint(lavePoint1);
+            userPoint.setHistoricalPoint(historicalPoint);
             userPoint.setVariablePoint(point);
-            userPoint.setBalance(appUserForPhoe.getLavePoint());
+            userPoint.setBalance(balance);
             userPoint.setCreateTime(LocalDateTime.now());
             userPoint.setAppUserId(appUserForPhoe.getId());
             userPoint.setObjectId(userid);
             userPointService.save(userPoint);
         }
 
-        Integer lavePoint = appUser.getLavePoint();
-        appUser.setLavePoint(appUser.getLavePoint() - point);
-        appUser.setTransferablePoint(appUser.getTransferablePoint() - point);
-        appUser.setAvailablePoint(appUser.getAvailablePoint() - point);
+        if (null==appUser.getTotalPoint()){
+            appUser.setTotalPoint(0);
+        }
+        if (null==appUser.getTransferableOutPoint()){
+            appUser.setTransferableOutPoint(0);
+        }
+        if (null==appUser.getAvailablePoint()){
+            appUser.setAvailablePoint(0);
+        }
+        Integer historicalPoint2 = appUser.getAvailablePoint();//历史积分
+        Integer balance2 = historicalPoint2 - point;//变动后积分
+
+
+        appUser.setAvailablePoint(balance2);//可用积分减少
+        appUser.setTotalPoint(appUser.getTotalPoint() + point);//总积分增加
+        appUser.setTransferableOutPoint(appUser.getTransferableOutPoint() + point);//转出积分增加
+
         appUserService.updateById(appUser);
         //构建积分流水记录
         if(point > 0){
             UserPoint userPoint = new UserPoint();
             userPoint.setType(13);
-            userPoint.setHistoricalPoint(lavePoint);
+            userPoint.setHistoricalPoint(historicalPoint2);
             userPoint.setVariablePoint(point);
-            userPoint.setBalance(appUser.getLavePoint());
+            userPoint.setBalance(balance2);
             userPoint.setCreateTime(LocalDateTime.now());
             userPoint.setAppUserId(appUser.getId());
             userPoint.setObjectId(appUserForPhoe.getId());
@@ -223,4 +262,28 @@
         });
         return userPointIPage;
     }
+
+    @Override
+    public PageInfo<UserPointDetailVO> getUserPontDetailPageList(Collection<Integer> types, Long id, Integer pageCurr, Integer pageSize) {
+        PageInfo<UserPointDetailVO> pageInfo = new PageInfo<>(pageCurr, pageSize);
+        List<UserPointDetailVO> list =baseMapper.getUserPontDetailPageList(pageInfo,id,types);
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
+
+    @Override
+    public Integer selectRechargeAndUse(String name, String phone, LocalDateTime beginTime, LocalDateTime endTime,Integer type) {
+
+        return  baseMapper.selectRechargeAndUse(name,phone,beginTime,endTime,type);
+    }
+
+    @Override
+    public PageInfo<UserPointStatisticsPageVO> getUserPointStatisticsPageList(Collection<Integer> types, String name, String phone, LocalDateTime beginTime, LocalDateTime endTime, Integer pageCurr, Integer pageSize) {
+        PageInfo<UserPointStatisticsPageVO> pageInfo = new PageInfo<>(pageCurr, pageSize);
+        List<UserPointStatisticsPageVO>list=baseMapper.getUserPointStatisticsPageList(pageInfo,types,name,phone,beginTime,endTime);
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
+
+
 }

--
Gitblit v1.7.1