From c5857a50d688d0c42b3893854e6f30dc45e61ca9 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期一, 11 十一月 2024 22:32:12 +0800
Subject: [PATCH] 代码提交
---
xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserWalletRecordController.java | 243 +++++++++++++++++++++++++++++++++++++-----------
1 files changed, 188 insertions(+), 55 deletions(-)
diff --git a/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserWalletRecordController.java b/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserWalletRecordController.java
index 12a7eed..b7d08d6 100644
--- a/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserWalletRecordController.java
+++ b/xinquan-modules/xinquan-user/src/main/java/com/xinquan/user/controller/client/ClientAppUserWalletRecordController.java
@@ -1,31 +1,44 @@
package com.xinquan.user.controller.client;
+import com.alibaba.nacos.common.utils.UuidUtils;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.xinquan.common.core.domain.R;
import com.xinquan.common.core.utils.page.CollUtils;
import com.xinquan.common.core.utils.page.PageDTO;
import com.xinquan.common.core.web.domain.BaseModel;
+import com.xinquan.common.security.service.TokenService;
import com.xinquan.common.security.utils.SecurityUtils;
+import com.xinquan.course.api.domain.Course;
+import com.xinquan.course.api.feign.RemoteCourseService;
+import com.xinquan.meditation.api.domain.Meditation;
+import com.xinquan.meditation.api.feign.RemoteMeditationService;
import com.xinquan.order.api.domain.Order;
import com.xinquan.order.api.feign.RemoteOrderService;
import com.xinquan.system.api.domain.AppUser;
import com.xinquan.system.api.domain.AppUserWalletRecord;
+import com.xinquan.system.api.domain.AppUserWithdraw;
import com.xinquan.system.api.domain.vo.InviteRankListVO;
import com.xinquan.system.api.domain.vo.OrderDetailVO;
import com.xinquan.system.api.domain.vo.OrderListVO;
+import com.xinquan.system.api.model.LoginUser;
import com.xinquan.user.api.domain.dto.UserBalanceDetailDTO;
+import com.xinquan.user.api.domain.dto.UserChildDTO;
import com.xinquan.user.service.AppUserService;
import com.xinquan.user.service.AppUserWalletRecordService;
+import com.xinquan.user.service.AppUserWithdrawService;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.expression.spel.ast.OpNE;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.math.BigDecimal;
+import java.time.LocalDateTime;
import java.util.List;
import java.util.stream.Collectors;
@@ -45,7 +58,72 @@
@Resource
private AppUserWalletRecordService walletRecordService;
@Resource
+ private AppUserWithdrawService appUserWithdrawService;
+ @Resource
+ private AppUserWalletRecordService appUserWalletRecordService;
+ @Resource
private RemoteOrderService remoteOrderService;
+ @Resource
+ private RemoteCourseService remoteCourseService;
+ @Resource
+ private RemoteMeditationService remoteMeditationService;
+ // 用户获得分佣收益 新增一条余额明细记录
+ @PostMapping("/addBalanceRecord")
+ public R addBalanceRecord(@RequestBody AppUserWalletRecord appUserWalletRecord) {
+ appUserWalletRecordService.save(appUserWalletRecord);
+ if(appUserWalletRecord.getReason().contains("分佣")){
+ AppUser byId = appUserService.getById(appUserWalletRecord.getAppUserId());
+ byId.setBalance(byId.getBalance().add(appUserWalletRecord.getAmount()));
+ appUserService.updateById(byId);
+ }
+ if (appUserWalletRecord.getChangeType() == 2){
+ AppUser byId = appUserService.getById(appUserWalletRecord.getAppUserId());
+ byId.setBalance(byId.getBalance().subtract(appUserWalletRecord.getAmount()));
+ appUserService.updateById(byId);
+ }
+ return R.ok();
+ }
+
+ @PostMapping("/childUserList")
+ @ApiOperation(value = "用户详情-下级用户列表",tags = "管理后台-用户管理")
+ public R<PageDTO<AppUser>> childUserList(@RequestBody UserChildDTO dto) {
+ String startTime = null;
+ String endTime = null;
+ if (org.springframework.util.StringUtils.hasLength(dto.getTime())){
+ String[] split = dto.getTime().split(" - ");
+ startTime = split[0]+"00:00:00";
+ endTime = split[1]+"23:59:59";
+ }
+ String userId = dto.getUid();
+ LambdaQueryWrapper<AppUser> appUserWalletRecordLambdaQueryWrapper = new LambdaQueryWrapper<>();
+ appUserWalletRecordLambdaQueryWrapper.between(startTime!=null,BaseModel::getCreateTime,startTime,endTime);
+ appUserWalletRecordLambdaQueryWrapper.eq(AppUser::getInviteUserId, userId);
+ appUserWalletRecordLambdaQueryWrapper.like(StringUtils.hasLength(dto.getCellPhone()),AppUser::getCellPhone,dto.getCellPhone());
+ appUserWalletRecordLambdaQueryWrapper.like(StringUtils.hasLength(dto.getNickName()),AppUser::getNickname,dto.getNickName());
+ appUserWalletRecordLambdaQueryWrapper.eq(StringUtils.hasLength(dto.getUserStatus()),AppUser::getUserStatus,dto.getUserStatus());
+ appUserWalletRecordLambdaQueryWrapper.orderByDesc(BaseModel::getCreateTime);
+ Page<AppUser> page = appUserService
+ .page(new Page<>(dto.getPageCurr(), dto.getPageSize()),appUserWalletRecordLambdaQueryWrapper);
+ if (CollUtils.isEmpty(page.getRecords())){
+ PageDTO<AppUser> empty = PageDTO.empty(page);
+ return R.ok(empty);
+ }
+ for (AppUser record : page.getRecords()) {
+ // 查询该用户带来收益
+ List<AppUserWalletRecord> list = appUserWalletRecordService.lambdaQuery()
+ .eq(AppUserWalletRecord::getAppUserId, userId)
+ .eq(AppUserWalletRecord::getChildAppUserId, record.getId()).list();
+ BigDecimal bigDecimal = new BigDecimal("0");
+ record.setMoney(new BigDecimal("0"));
+ for (AppUserWalletRecord appUserWalletRecord : list) {
+ if (appUserWalletRecord.getAmount()!=null && appUserWalletRecord.getChangeType() == 1){
+ bigDecimal = bigDecimal.add(appUserWalletRecord.getAmount());
+ }
+ record.setMoney(bigDecimal);
+ }
+ }
+ return R.ok(PageDTO.of(page, AppUser.class));
+ }
@PostMapping("/userBalanceList")
@ApiOperation(value = "用户详情-余额明细",tags = "管理后台-用户管理")
public R<PageDTO<OrderListVO>> userBalanceList(@RequestBody UserBalanceDetailDTO dto) {
@@ -53,8 +131,8 @@
String endTime = null;
if (org.springframework.util.StringUtils.hasLength(dto.getTime())){
String[] split = dto.getTime().split(" - ");
- startTime = split[0]+"00:00:00";
- endTime = split[1]+"23:59:59";
+ startTime = split[0]+" 00:00:00";
+ endTime = split[1]+" 23:59:59";
}
String userId = dto.getUid();
LambdaQueryWrapper<AppUserWalletRecord> appUserWalletRecordLambdaQueryWrapper = new LambdaQueryWrapper<>();
@@ -68,8 +146,13 @@
PageDTO<OrderListVO> empty = PageDTO.empty(page);
return R.ok(empty);
}
+ for (AppUserWalletRecord record : page.getRecords()) {
+ record.setId(record.getOrderId());
+ }
return R.ok(PageDTO.of(page, OrderListVO.class));
}
+ @Autowired
+ private TokenService tokenService;
/**
* 爱心助力榜单-分页
*
@@ -85,11 +168,14 @@
@ApiImplicitParam(value = "分页参数,每页数量", name = "pageSize", required = true, dataType = "Integer")
})
public R<PageDTO<OrderListVO>> balanceList(Integer state,Integer pageCurr, Integer pageSize) {
- Long userId = SecurityUtils.getUserId();
- if (userId==0)return R.tokenError("登录失效");
+ LoginUser loginUser = tokenService.getLoginUser();
+ if (loginUser==null){
+ return R.tokenError("登录失效");
+ }
+ Long userId = loginUser.getUserid();
LambdaQueryWrapper<AppUserWalletRecord> appUserWalletRecordLambdaQueryWrapper = new LambdaQueryWrapper<>();
if (state!=1){
- appUserWalletRecordLambdaQueryWrapper.eq(AppUserWalletRecord::getChangeType, state);
+ appUserWalletRecordLambdaQueryWrapper.eq(AppUserWalletRecord::getChangeType, state-1);
}
appUserWalletRecordLambdaQueryWrapper.eq(AppUserWalletRecord::getAppUserId, userId);
appUserWalletRecordLambdaQueryWrapper.orderByDesc(BaseModel::getCreateTime);
@@ -114,33 +200,39 @@
AppUserWalletRecord byId = walletRecordService.getById(uid);
if (byId.getOrderId()!=null){
if (byId.getReason().equals("提现")){
- // 远程查询提现记录
+ AppUserWithdraw byId1 = appUserWithdrawService.getById(byId.getOrderId());
orderDetailVO.setType("提现");
+ orderDetailVO.setRemark("银行卡提现");
+ orderDetailVO.setPayOrderNo(byId1.getSerialNo());
+ orderDetailVO.setWithdrawType(byId1.getWithdrawType());
+ orderDetailVO.setAmount(byId1.getAmount());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setPaymentTime(byId1.getUpdateTime());
}else if (byId.getReason().equals("充值")){
Order one = remoteOrderService.getOrderById(byId.getOrderId()).getData();
if (byId.getChildAppUserId() == null && one!=null){
- if (one.getOrderFrom()!=null){
- switch (one.getOrderFrom()){
- case 1:
- orderDetailVO.setType("购买疗愈");
- break;
- case 2:
- orderDetailVO.setType("购买课程");
- break;
- case 3:
- orderDetailVO.setType("购买会员");
- break;
- case 4:
- orderDetailVO.setType("充值");
- break;
- }
+ orderDetailVO.setType("充值");
+ orderDetailVO.setPayType(one.getPayType());
+ orderDetailVO.setPayOrderNo(one.getPayOrderNo());
+ if (one.getPayType()==1){
+ orderDetailVO.setRemark("微信支付");
+ }else if (one.getPayType()==2){
+ orderDetailVO.setRemark("支付宝支付");
}
- orderDetailVO.setRemark(one.getRemark());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setAmount(byId.getAmount());
orderDetailVO.setPaymentTime(one.getPaymentTime());
return R.ok(orderDetailVO);
- }else if (byId.getChildAppUserId()!=null && one!=null){
+ }
+ }else if (byId.getReason().equals("分佣收益")){
+ Order one = remoteOrderService.getOrderById(byId.getOrderId()).getData();
+ if (byId.getChildAppUserId()!=null && one!=null){
orderDetailVO.setType("分佣");
orderDetailVO.setPayOrderNo(one.getPayOrderNo());
+ orderDetailVO.setPaymentTime(byId.getCreateTime());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setAmount(byId.getAmount());
+ orderDetailVO.setRemark("分佣收益");
if (one.getCommissionId()!=null){
AppUser appUserById = appUserService.getById(one.getCommissionId());
orderDetailVO.setUserName(appUserById.getNickname());
@@ -148,12 +240,19 @@
}
return R.ok(new OrderDetailVO());
}
- }else if (byId.getReason().equals("分佣收益")){
-
}else if (byId.getReason().equals("提现回退")){
+ AppUserWithdraw byId1 = appUserWithdrawService.getById(byId.getOrderId());
+ orderDetailVO.setType("提现回退");
+ orderDetailVO.setPayOrderNo(byId1.getSerialNo());
+ orderDetailVO.setWithdrawType(byId1.getWithdrawType());
+ orderDetailVO.setAmount(byId1.getAmount());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setPaymentTime(byId1.getUpdateTime());
+ return R.ok(new OrderDetailVO());
+
+ }
}
- }
- return R.ok();
+ return R.ok(orderDetailVO);
}
@PostMapping("/balanceDetail")
@@ -162,50 +261,84 @@
@ApiImplicitParam(name = "id", value = "id", dataType = "Long", required = true),
})
public R<OrderDetailVO> balanceDetail(Long id) {
- Long userId = SecurityUtils.getUserId();
- if (userId==0)return R.tokenError("登录失效");
+ LoginUser loginUser = tokenService.getLoginUser();
+ if (loginUser==null){
+ return R.tokenError("登录失效");
+ }
+ Long userId = loginUser.getUserid();
OrderDetailVO orderDetailVO = new OrderDetailVO();
AppUserWalletRecord byId = walletRecordService.getById(id);
if (byId.getOrderId()!=null){
- if (byId.getReason().equals("提现")){
- // 远程查询提现记录
+ if (byId.getReason().contains("提现")){
+ AppUserWithdraw byId1 = appUserWithdrawService.getById(byId.getOrderId());
orderDetailVO.setType("提现");
- }else{
+ orderDetailVO.setPayOrderNo(byId1.getSerialNo());
+ orderDetailVO.setWithdrawType(byId1.getWithdrawType());
+ orderDetailVO.setAmount(byId1.getAmount());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setPaymentTime(byId1.getUpdateTime());
+ }else if (byId.getReason().equals("充值")){
Order one = remoteOrderService.getOrderById(byId.getOrderId()).getData();
- if (byId.getChildAppUserId() == null && one!=null){
- orderDetailVO.setId(id);
- if (one.getOrderFrom()!=null){
- switch (one.getOrderFrom()){
- case 1:
- orderDetailVO.setType("购买疗愈");
- break;
- case 2:
- orderDetailVO.setType("购买课程");
- break;
- case 3:
- orderDetailVO.setType("购买会员");
- break;
- case 4:
- orderDetailVO.setType("充值");
- break;
- }
- }
+ orderDetailVO.setType("充值");
+ orderDetailVO.setPayType(one.getPayType());
+ orderDetailVO.setPayOrderNo(one.getBizOrderNo());
orderDetailVO.setRemark(one.getRemark());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setAmount(byId.getAmount());
orderDetailVO.setPaymentTime(one.getPaymentTime());
return R.ok(orderDetailVO);
- }else if (byId.getChildAppUserId()!=null && one!=null){
+ }else if (byId.getReason().equals("分佣收益")){
+ Order one = remoteOrderService.getOrderById(byId.getOrderId()).getData();
+ if (byId.getChildAppUserId()!=null && one!=null){
orderDetailVO.setType("分佣");
- orderDetailVO.setPayOrderNo(one.getPayOrderNo());
+ orderDetailVO.setPayOrderNo(one.getBizOrderNo());
+ orderDetailVO.setPaymentTime(byId.getCreateTime());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setAmount(byId.getAmount());
+ orderDetailVO.setRemark(one.getRemark());
if (one.getCommissionId()!=null){
- AppUser appUserById = appUserService.getById(one.getCommissionId());
+ AppUser appUserById = appUserService.getById(one.getAppUserId());
orderDetailVO.setUserName(appUserById.getNickname());
orderDetailVO.setAvatar(appUserById.getAvatar());
}
- return R.ok(new OrderDetailVO());
+ return R.ok(orderDetailVO);
}
+ }else if (byId.getReason().equals("提现回退")){
+ AppUserWithdraw byId1 = appUserWithdrawService.getById(byId.getOrderId());
+ orderDetailVO.setType("提现回退");
+ orderDetailVO.setPayOrderNo(byId1.getSerialNo());
+ orderDetailVO.setWithdrawType(byId1.getWithdrawType());
+ orderDetailVO.setAmount(byId1.getAmount());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setPaymentTime(byId1.getUpdateTime());
+ return R.ok(orderDetailVO);
+ }else if (byId.getReason().contains("课程")){
+ Order data = remoteOrderService.getOrderById(byId.getOrderId()).getData();
+ if (data!=null){
+ Course data1 = remoteCourseService.getCourseById(data.getBusinessId()).getData();
+ orderDetailVO.setType("课程购买");
+ orderDetailVO.setPayOrderNo(data.getBizOrderNo());
+ orderDetailVO.setAmount(data.getBalance());
+ orderDetailVO.setChangeType(byId.getChangeType());
+ orderDetailVO.setPaymentTime(data.getPaymentTime());
+ }
+ return R.ok(orderDetailVO);
+
+ } else if (byId.getReason().contains("疗愈")) {
+ Order data = remoteOrderService.getOrderById(byId.getOrderId()).getData();
+ if (data!=null){
+ Meditation data1 = remoteMeditationService.getMeditationById(data.getBusinessId()).getData();
+ orderDetailVO.setType("疗愈购买");
+ orderDetailVO.setPayOrderNo(data.getBizOrderNo());
+ orderDetailVO.setAmount(data.getBalance());
+ orderDetailVO.setChangeType(2);
+ orderDetailVO.setPaymentTime(data.getPaymentTime());
+ }
+ return R.ok(orderDetailVO);
+
}
}
- return R.ok();
+ return R.ok(orderDetailVO);
}
}
--
Gitblit v1.7.1