From c6675b55023dff3c4f441ab0bb9493198949126e Mon Sep 17 00:00:00 2001
From: rk <94314517@qq.com>
Date: 星期五, 16 一月 2026 18:22:41 +0800
Subject: [PATCH] 小程序   接口开发

---
 server/dmmall_service/src/main/java/com/doumee/service/business/impl/IntegralServiceImpl.java |   86 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 86 insertions(+), 0 deletions(-)

diff --git a/server/dmmall_service/src/main/java/com/doumee/service/business/impl/IntegralServiceImpl.java b/server/dmmall_service/src/main/java/com/doumee/service/business/impl/IntegralServiceImpl.java
index bd8aeb3..06eff63 100644
--- a/server/dmmall_service/src/main/java/com/doumee/service/business/impl/IntegralServiceImpl.java
+++ b/server/dmmall_service/src/main/java/com/doumee/service/business/impl/IntegralServiceImpl.java
@@ -16,8 +16,11 @@
 import com.doumee.dao.business.model.Integral;
 import com.doumee.dao.business.model.Member;
 import com.doumee.dao.business.model.Shop;
+import com.doumee.dao.system.model.SystemDictData;
 import com.doumee.dao.web.dto.IntegralDTO;
+import com.doumee.dao.web.dto.IntegralRecordDTO;
 import com.doumee.dao.web.request.DealIntegralRequest;
+import com.doumee.dao.web.response.IntegralDataResponse;
 import com.doumee.service.business.AreasService;
 import com.doumee.service.business.IntegralService;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
@@ -384,4 +387,87 @@
         integralDTOIPage.setCurrent(result.getCurrent());
         return PageData.from(integralDTOIPage);
     }
+
+
+
+    public List<Integral> getMyIntegralList(Integer memberId) {
+
+
+
+        QueryWrapper<Integral> queryWrapper = new QueryWrapper<>();
+        queryWrapper.lambda().eq(Integral::getMemberId,memberId);
+        return integralMapper.selectList(queryWrapper);
+    }
+
+    @Override
+    public PageData<Integral> findIntegralRecordPage(PageWrap<IntegralRecordDTO> pageWrap) {
+        IPage<Integral> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
+        Utils.MP.blankToNull(pageWrap.getModel());
+        IntegralRecordDTO model = pageWrap.getModel();
+
+        IPage<Integral> result = integralMapper.selectPage(page,new QueryWrapper<Integral>()
+                .lambda()
+                .eq(Objects.nonNull(model.getUserType()),Integral::getUserType,model.getUserType())
+                .eq(Objects.nonNull(model.getType()),Integral::getType,model.getType())
+                .eq(Integral::getMemberId,model.getMemberId())
+                .orderByDesc(Integral::getCreateDate)
+        );
+
+        if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(result.getRecords())){
+            for (Integral integral:result.getRecords()) {
+                integral.setStrType(Constants.IntegralObjType.getName(integral.getObjType()));
+            }
+        }
+        return PageData.from(result);
+    }
+
+
+    @Override
+    public IntegralDataResponse getIntegralData(IntegralRecordDTO model){
+        IntegralDataResponse integralDataResponse = new IntegralDataResponse();
+        integralDataResponse.setSurplusIntegral(BigDecimal.ZERO);
+        integralDataResponse.setExpiredIntegral(BigDecimal.ZERO);
+        List<Integral> list = integralMapper.selectList(new QueryWrapper<Integral>().lambda()
+                .eq(Objects.nonNull(model.getUserType()),Integral::getUserType,model.getUserType())
+                .eq(Objects.nonNull(model.getType()),Integral::getType,model.getType())
+                .eq(Integral::getMemberId,model.getMemberId())
+                .orderByDesc(Integral::getCreateDate));
+
+        if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(list)){
+            integralDataResponse.setSurplusIntegral(
+                    list.stream().map(i->i.getNum().multiply(new BigDecimal(i.getType().toString()))
+                    ).reduce(BigDecimal.ZERO, BigDecimal::add)
+            );
+
+            //绉垎澶辨晥鏂瑰紡 0闀挎湡鏈夋晥 1鎸夌Н鍒嗕骇鐢熸椂闂村け鏁�
+            Integer type  = Integer.valueOf(systemDictDataBiz.queryByCode(Constants.INTEGRAL_SET, Constants.INTERALSET_INTEGRALINVALIDTYPE).getCode());
+            //娑堣垂鑰呯Н鍒� 闇�瑕佹煡璇㈠嵆灏嗚繃鏈熺Н鍒�
+            if(Constants.equalsInteger(type,Constants.ZERO)){
+                Integer validYear  = Integer.valueOf(systemDictDataBiz.queryByCode(Constants.INTEGRAL_SET, Constants.INTERALSET_INTEGRALINVALIDCIRCLE).getCode());
+                if(validYear.compareTo(Constants.ZERO)>Constants.ZERO){
+                     list = integralMapper.selectList(new QueryWrapper<Integral>().lambda()
+                            .eq(Objects.nonNull(model.getUserType()),Integral::getUserType,model.getUserType())
+                            .eq(Objects.nonNull(model.getType()),Integral::getType,model.getType())
+                            .eq(Integral::getMemberId,model.getMemberId())
+                             .apply(" CREATE_DATE >= DATE_SUB(DATE_FORMAT(CURDATE(), '%Y-%m-01'),INTERVAL "+(validYear*12)+1+" MONTH) ")
+                            .orderByDesc(Integral::getCreateDate));
+                    BigDecimal newIntegral = list.stream().map(i->i.getNum().multiply(new BigDecimal(i.getType().toString()))
+                    ).reduce(BigDecimal.ZERO, BigDecimal::add);
+                    integralDataResponse.setExpiredIntegral(
+                            integralDataResponse.getSurplusIntegral().compareTo(newIntegral)>Constants.ZERO?integralDataResponse.getSurplusIntegral().subtract(newIntegral):BigDecimal.ZERO
+                    );
+                }
+            }
+
+        }
+        String info  = systemDictDataBiz.queryByCode(Constants.INTEGRAL_SET, Constants.INTERALSET_INTEGRALRULEINFO).getCode();
+        integralDataResponse.setInfo(info);
+
+        return integralDataResponse;
+    }
+
+
+
+
+
 }

--
Gitblit v1.9.3