From 1442f149019ee0590389abd7a88a79c4d9b59034 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期二, 27 五月 2025 18:23:34 +0800 Subject: [PATCH] bug修改 --- ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/WithdrawController.java | 162 ++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 152 insertions(+), 10 deletions(-) diff --git a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/WithdrawController.java b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/WithdrawController.java index b6bbf54..264301d 100644 --- a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/WithdrawController.java +++ b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/WithdrawController.java @@ -1,19 +1,32 @@ package com.ruoyi.admin.controller; -import com.ruoyi.admin.entity.Withdraw; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.ruoyi.admin.entity.Franchisee; +import com.ruoyi.admin.entity.User; +import com.ruoyi.admin.service.FranchiseeService; +import com.ruoyi.admin.service.UserService; import com.ruoyi.admin.service.WithdrawService; import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.exception.GlobalException; +import com.ruoyi.common.security.service.TokenService; +import com.ruoyi.order.api.entity.UserWithdrawRecordVO; +import com.ruoyi.order.api.entity.Withdraw; +import com.ruoyi.order.api.entity.WithdrawExportRequest; +import com.ruoyi.order.api.feignClient.WithdrawClient; +import com.ruoyi.system.api.model.LoginUser; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; -import org.springframework.web.bind.annotation.GetMapping; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RequestParam; -import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; +import javax.servlet.http.HttpServletResponse; +import java.lang.reflect.Array; +import java.util.Arrays; +import java.util.List; +import java.util.stream.Collectors; /** * <p> @@ -25,25 +38,154 @@ */ @RestController @RequestMapping("/withdraw") -@Api(tags = {"后台-用户管理-用户列表"}) +@Api(tags = {"后台-用户管理-提现列表"}) public class WithdrawController { @Resource private WithdrawService withdrawService; + @Resource + private WithdrawClient withdrawClient; + @Resource + private UserService userService; + + @Resource + private TokenService tokenService; + @Resource + private FranchiseeService franchiseeService; + /** + * 用户所关联提现记录分页列表 + * + * @param pageNum 页码 + * @param pageSize 每页显示条数 + * @return 分页列表 + */ + @ApiOperation(value = "用户提现管理-提现记录分页列表", tags = {"后台-用户管理-提现列表"}) + @GetMapping(value = "/withdrawPage") + @ApiImplicitParams({ + @ApiImplicitParam(value = "用户昵称", name = "nickname", dataType = "String"), + @ApiImplicitParam(value = "手机号", name = "userPhone", dataType = "String"), + @ApiImplicitParam(value = "申请时间", name = "applyForTime", dataType = "String"), + @ApiImplicitParam(value = "审核状态(0待审核;1已通过;2已驳回)", name = "state", dataType = "Integer"), + @ApiImplicitParam(value = "页码", name = "pageNum", dataType = "Integer", required = true), + @ApiImplicitParam(value = "每页条数", name = "pageSize", dataType = "Integer", required = true) + }) + public R<Page<UserWithdrawRecordVO>> withdrawPage(String nickname, String userPhone, + String applyForTime, Integer state, + @RequestParam(name = "pageNum", defaultValue = "1") Integer pageNum, + @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) { + + List<Integer> userIds = userService.lambdaQuery().like(User::getNickname, nickname).list().stream().map(User::getId).collect(Collectors.toList()); + if (nickname!=null&&nickname!="") { + if (userIds.isEmpty()) { + return R.ok(new Page<UserWithdrawRecordVO>()); + } + } + LoginUser loginUser = tokenService.getLoginUser(); + List<String> cityList = loginUser.getCityList(); + + + Integer franchiseeId = loginUser.getSysUser().getFranchiseeId(); + String[] siteIds = new String[0]; + if (franchiseeId!=null){ + Franchisee byId = franchiseeService.getById(franchiseeId); + siteIds = byId.getSiteIds().split(","); + if (loginUser.getIsFranchisee()&&siteIds.length==0){ + return R.ok(); + } + } + + + Page<UserWithdrawRecordVO> page = withdrawClient.withdrawPage1(cityList,nickname, userPhone, applyForTime, + state, pageNum, pageSize,userIds, Arrays.asList(siteIds)).getData(); + if (null != page) { + for (UserWithdrawRecordVO record : page.getRecords()) { + Integer userId = record.getUserId(); + User user = userService.lambdaQuery() + .eq(User::getId, userId) + .eq(User::getIsDelete, 0).one(); + if (null != user) { + record.setUserNo(user.getUserNo()); + record.setNickname(user.getNickname()); + record.setProfilePicture(user.getProfilePicture()); + } + } + } + return R.ok(page); + } /** * 查看提现记录详情 * * @param id 提现记录id */ - @ApiOperation(value = "提现记录详情", tags = {"后台-用户管理-用户列表"}) + @ApiOperation(value = "提现记录详情", tags = {"后台-用户管理-提现列表"}) @GetMapping(value = "/withdrawRecordDetail") @ApiImplicitParams({ @ApiImplicitParam(value = "提现记录id", name = "id", dataType = "Integer", required = true) }) - public R<Withdraw> withdrawRecordDetail(@RequestParam Integer id) { - Withdraw withdraw = withdrawService.lambdaQuery().eq(Withdraw::getId, id).eq(Withdraw::getIsDelete, 0).one(); - return R.ok(withdraw); + public R<Withdraw> withdrawRecordDetail(@RequestParam Long id) { + return withdrawClient.withdrawRecordDetail(id); + } + + /** + * 提现管理-提现审批 + * + * @param id 提现记录id + * @param state 审批结果 + * @param opinion 审批意见 + */ + @ApiOperation(value = "提现管理-提现审批", tags = {"后台-用户管理-提现列表"}) + @GetMapping(value = "/withdrawExamine") + @ApiImplicitParams({ + @ApiImplicitParam(value = "提现记录id", name = "id", dataType = "Integer", required = true), + @ApiImplicitParam(value = "审批意见", name = "opinion", dataType = "String"), + @ApiImplicitParam(value = "审批同意/不同意(1同意;2驳回)", name = "state", dataType = "Integer", required = true) + }) + public R<String> withdrawExamine(@RequestParam Long id, @RequestParam Integer state, String opinion) { + Withdraw withdraw = withdrawClient.withdrawRecordDetail(id).getData(); + if (null == withdraw) { + throw new GlobalException("提现记录不存在或已删除!"); + } + User user = userService.lambdaQuery() + .eq(User::getId, withdraw.getUserId()) + .eq(User::getIsDelete, 0).one(); + if (null == user) { + throw new GlobalException("提交申请的用户信息不存在!"); + } + Boolean data = withdrawClient.withdrawExamine(id, state, opinion, user.getOpenId(), user.getId()).getData(); + if (null != data) { + return data ? R.ok(null, "审批成功!") : R.fail("审批失败!"); + } else { + return R.fail("审批失败!"); + } + } + + /** + * 用户提现记录导出 + * + * @param exportRequest 提现记录 + */ + @ApiOperation(value = "用户提现管理-excel导出用户提现记录", tags = {"后台-用户管理-提现列表"}) + @PostMapping(value = "/excelExport") + public R<String> excelExport(@RequestBody WithdrawExportRequest exportRequest, HttpServletResponse response) { + List<UserWithdrawRecordVO> data = withdrawClient.excelExport(exportRequest).getData(); + // 独立service + return withdrawService.excelExport(data, response); + } + + /** + * 批量删除提现记录 + * + * @param ids 轮播图多条id拼接 + * @return 封装分页数据 + */ + @ApiOperation(value = "批量删除提现记录", tags = {"后台-用户管理-提现列表"}) + @GetMapping(value = "/batchDelete") + @ApiImplicitParams({ + @ApiImplicitParam(value = "多个id ',' 拼接", name = "ids", dataType = "String", required = true) + }) + public R<String> batchDelete(@RequestParam String ids) { + return withdrawClient.batchDelete(ids); } } -- Gitblit v1.7.1