From 441d81870507e15214d9c8cbf64e6f3cddb14404 Mon Sep 17 00:00:00 2001
From: gongzuming <gongzuming>
Date: 星期一, 02 九月 2024 17:02:09 +0800
Subject: [PATCH] 优化积分

---
 src/main/java/com/mzl/flower/service/point/CustomerPointService.java |   12 +++++++-----
 1 files changed, 7 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/mzl/flower/service/point/CustomerPointService.java b/src/main/java/com/mzl/flower/service/point/CustomerPointService.java
index 04800ee..a75a7a9 100644
--- a/src/main/java/com/mzl/flower/service/point/CustomerPointService.java
+++ b/src/main/java/com/mzl/flower/service/point/CustomerPointService.java
@@ -85,13 +85,15 @@
         if(POINT_CHANGE_TYPE.add.name().equals(detail.getChangeType())){
             point.setTotalPoint(point.getTotalPoint() + detail.getPoint());
         }else if(POINT_CHANGE_TYPE.reduce.name().equals(detail.getChangeType())){
-            if(point.getTotalPoint()!= null && point.getTotalPoint()!=0 && point.getTotalPoint()>= detail.getPoint()){
-                point.setTotalPoint(point.getTotalPoint() - detail.getPoint());
+            Integer balancePoint = point.getTotalPoint() - point.getUsedPoint()-point.getExpiredPoint();//可用积分
+            balancePoint = balancePoint.intValue()>0?balancePoint.intValue():0;
+            if(balancePoint.intValue() >= detail.getPoint().intValue()){
+                point.setUsedPoint(point.getUsedPoint() + detail.getPoint());
             }else{
                 //积分不足,直接清0
-                point.setTotalPoint(0);
-                detail.setPoint(point.getTotalPoint());
-                detail.setRemarks(detail.getRemarks()+",积分不足,扣除剩余积分"+point.getTotalPoint());
+                point.setUsedPoint(point.getUsedPoint() + balancePoint);
+                detail.setPoint(balancePoint);
+                detail.setRemarks(detail.getRemarks()+",积分不足,扣除积分"+balancePoint);
             }
         }
         if(isAdd){

--
Gitblit v1.9.3