nnnn
This commit is contained in:
@@ -48,7 +48,10 @@ public class OrderLogsController extends BaseController {
|
||||
*/
|
||||
@GetMapping("/list")
|
||||
public TableDataInfo<OrderLogs> list(OrderLogs bo, PageQuery pageQuery) {
|
||||
Page<OrderLogs> page = orderLogsService.page(pageQuery.build(), Wrappers.lambdaQuery(OrderLogs.class).orderByDesc(OrderLogs::getCreateTime));
|
||||
Page<OrderLogs> page = orderLogsService.page(pageQuery.build(), Wrappers.lambdaQuery(bo)
|
||||
.ge(bo.getCreateTimeMin() != null, OrderLogs::getCreateTime, bo.getCreateTimeMin())
|
||||
.le(bo.getCreateTimeMax() != null,OrderLogs::getCreateTime, bo.getCreateTimeMax())
|
||||
.orderByDesc(OrderLogs::getCreateTime));
|
||||
return TableDataInfo.build(page);
|
||||
}
|
||||
|
||||
|
||||
@@ -1,8 +1,10 @@
|
||||
package com.ruoyi.cai.domain;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import lombok.Data;
|
||||
import org.joda.time.LocalDate;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.time.LocalDateTime;
|
||||
@@ -50,5 +52,9 @@ public class OrderLogs implements Serializable {
|
||||
private String success;
|
||||
|
||||
private LocalDateTime createTime;
|
||||
@TableField(exist = false)
|
||||
private LocalDateTime createTimeMin;
|
||||
@TableField(exist = false)
|
||||
private LocalDateTime createTimeMax;
|
||||
|
||||
}
|
||||
|
||||
@@ -0,0 +1,16 @@
|
||||
package com.ruoyi.cai.dto.proxy;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
@Data
|
||||
public class BindUserListDTO {
|
||||
private String usercode;
|
||||
private String nickname;
|
||||
private String avatar;
|
||||
private Integer gender;
|
||||
private LocalDateTime inviteTime;
|
||||
private LocalDateTime inviteTimeMin;
|
||||
private LocalDateTime inviteTimeMax;
|
||||
}
|
||||
@@ -0,0 +1,46 @@
|
||||
package com.ruoyi.cai.dto.proxy;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
@Data
|
||||
public class OrderListDTO {
|
||||
/**
|
||||
* 价格
|
||||
*/
|
||||
private BigDecimal price;
|
||||
|
||||
/**
|
||||
* 商品名称
|
||||
*/
|
||||
private String rechargeName;
|
||||
|
||||
/**
|
||||
* 订单号
|
||||
*/
|
||||
private String orderNo;
|
||||
|
||||
/**
|
||||
* 昵称
|
||||
*/
|
||||
private String nickname;
|
||||
|
||||
/**
|
||||
* 头像
|
||||
*/
|
||||
private String avatar;
|
||||
|
||||
/**
|
||||
* 用户号/ID号
|
||||
*/
|
||||
private String usercode;
|
||||
|
||||
private LocalDateTime payTime;
|
||||
|
||||
private LocalDateTime payTimeMin;
|
||||
private LocalDateTime payTimeMax;
|
||||
|
||||
|
||||
}
|
||||
@@ -0,0 +1,12 @@
|
||||
package com.ruoyi.cai.dto.proxy;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
@Data
|
||||
public class ProxyTotalDTO {
|
||||
private Long bindUserCount;
|
||||
private BigDecimal priceSum;
|
||||
}
|
||||
@@ -75,6 +75,9 @@ public class CurrentUserManager {
|
||||
public CurrentUserInfoVo currentInfo() {
|
||||
Long userId = LoginHelper.getUserId();
|
||||
User user = userService.getById(userId);
|
||||
if(user == null) {
|
||||
return null;
|
||||
}
|
||||
CurrentUserInfoVo res = BeanConvertUtil.convertTo(user, CurrentUserInfoVo::new);
|
||||
res.setUserId(userId);
|
||||
Anchor anchor = anchorService.getByUserId(userId);
|
||||
|
||||
@@ -0,0 +1,56 @@
|
||||
package com.ruoyi.cai.manager;
|
||||
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import com.ruoyi.cai.domain.User;
|
||||
import com.ruoyi.cai.dto.proxy.BindUserListDTO;
|
||||
import com.ruoyi.cai.dto.proxy.OrderListDTO;
|
||||
import com.ruoyi.cai.dto.proxy.ProxyTotalDTO;
|
||||
import com.ruoyi.cai.mapper.ConsumeLogMapper;
|
||||
import com.ruoyi.cai.mapper.UserInviteMapper;
|
||||
import com.ruoyi.cai.service.UserService;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.math.BigDecimal;
|
||||
|
||||
@Component
|
||||
public class ProxyUserManager {
|
||||
|
||||
@Autowired
|
||||
private UserService userService;
|
||||
@Resource
|
||||
private ConsumeLogMapper consumeLogMapper;
|
||||
@Resource
|
||||
private UserInviteMapper userInviteMapper;
|
||||
|
||||
public IPage<OrderListDTO> orderLogList(String usercode,PageQuery pageQuery, OrderListDTO query){
|
||||
User user = getUser(usercode);
|
||||
return consumeLogMapper.selectProxyUserOrderPage(pageQuery.build(),user.getUsercode(), query);
|
||||
}
|
||||
|
||||
public IPage<BindUserListDTO> bindUserList(String userCode, PageQuery pageQuery, BindUserListDTO query) {
|
||||
User user = getUser(userCode);
|
||||
return userInviteMapper.selectProxyBindUserPage(pageQuery.build(),user.getId(),query);
|
||||
}
|
||||
|
||||
public ProxyTotalDTO total(String userCode) {
|
||||
User user = getUser(userCode);
|
||||
BigDecimal priceSum = consumeLogMapper.sumProxyUserOrder(user.getUsercode());
|
||||
Long userCount = userInviteMapper.countProxyBindUser(user.getId());
|
||||
ProxyTotalDTO proxyTotalDTO = new ProxyTotalDTO();
|
||||
proxyTotalDTO.setBindUserCount(userCount == null ? 0 : userCount);
|
||||
proxyTotalDTO.setPriceSum(priceSum == null ? BigDecimal.ZERO : priceSum);
|
||||
return proxyTotalDTO;
|
||||
}
|
||||
|
||||
|
||||
private User getUser(String usercode){
|
||||
User user = userService.getByUserCode(usercode);
|
||||
if(user == null){
|
||||
throw new RuntimeException("您的后台账户未绑定APP账户,请联系管理员操作");
|
||||
}
|
||||
return user;
|
||||
}
|
||||
}
|
||||
@@ -1,7 +1,12 @@
|
||||
package com.ruoyi.cai.mapper;
|
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import com.ruoyi.cai.domain.ConsumeLog;
|
||||
import com.ruoyi.cai.dto.proxy.OrderListDTO;
|
||||
import org.apache.ibatis.annotations.Param;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
/**
|
||||
* 消费记录Mapper接口
|
||||
@@ -10,5 +15,9 @@ import com.ruoyi.cai.domain.ConsumeLog;
|
||||
* @date 2023-12-24
|
||||
*/
|
||||
public interface ConsumeLogMapper extends BaseMapper<ConsumeLog> {
|
||||
IPage<OrderListDTO> selectProxyUserOrderPage(@Param("page") IPage<OrderListDTO> page,
|
||||
@Param("proxyUserCode") String proxyUserCode,
|
||||
@Param("query") OrderListDTO query);
|
||||
|
||||
BigDecimal sumProxyUserOrder(@Param("userCode") String userCode);
|
||||
}
|
||||
|
||||
@@ -1,11 +1,13 @@
|
||||
package com.ruoyi.cai.mapper;
|
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.ruoyi.cai.domain.UserInvite;
|
||||
import com.ruoyi.cai.dto.admin.vo.UserInviteAdminVo;
|
||||
import com.ruoyi.cai.dto.app.dto.InviteCountDTO;
|
||||
import com.ruoyi.cai.dto.app.vo.user.UserListVo;
|
||||
import com.ruoyi.cai.dto.proxy.BindUserListDTO;
|
||||
import org.apache.ibatis.annotations.Param;
|
||||
|
||||
/**
|
||||
@@ -24,4 +26,8 @@ public interface UserInviteMapper extends BaseMapper<UserInvite> {
|
||||
Page<UserInviteAdminVo> pageAdmin(@Param("build") Page<Object> build, @Param("bo") UserInviteAdminVo bo);
|
||||
|
||||
void incsCoinTotal(@Param("id") Long id, @Param("amount") Long amount);
|
||||
|
||||
IPage<BindUserListDTO> selectProxyBindUserPage(Page<Object> build, @Param("userId") Long userId, @Param("query") BindUserListDTO query);
|
||||
|
||||
Long countProxyBindUser(@Param("userId") Long userId);
|
||||
}
|
||||
|
||||
@@ -4,41 +4,33 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="com.ruoyi.cai.mapper.ConsumeLogMapper">
|
||||
|
||||
<resultMap type="com.ruoyi.cai.domain.ConsumeLog" id="CaiConsumeLogResult">
|
||||
<result property="id" column="id"/>
|
||||
<result property="type" column="type"/>
|
||||
<result property="sourceBusinessId" column="source_business_id"/>
|
||||
<result property="amount" column="amount"/>
|
||||
<result property="anchorAmount" column="anchor_amount"/>
|
||||
<result property="oneAmount" column="one_amount"/>
|
||||
<result property="twoAmount" column="two_amount"/>
|
||||
<result property="platformAmount" column="platform_amount"/>
|
||||
<result property="sourceUserId" column="source_user_id"/>
|
||||
<result property="sourceUsercode" column="source_usercode"/>
|
||||
<result property="sourcePhone" column="source_phone"/>
|
||||
<result property="targetUserId" column="target_user_id"/>
|
||||
<result property="targetUsercode" column="target_usercode"/>
|
||||
<result property="targetPhone" column="target_phone"/>
|
||||
<result property="oneUserId" column="one_user_id"/>
|
||||
<result property="oneUsercode" column="one_usercode"/>
|
||||
<result property="onePhone" column="one_phone"/>
|
||||
<result property="oneRate" column="one_rate"/>
|
||||
<result property="oneIsUnion" column="one_is_union"/>
|
||||
<result property="twoUserId" column="two_user_id"/>
|
||||
<result property="twoUsercode" column="two_usercode"/>
|
||||
<result property="twoPhone" column="two_phone"/>
|
||||
<result property="twoRate" column="two_rate"/>
|
||||
<result property="twoIsUnion" column="two_is_union"/>
|
||||
<result property="calculateStatus" column="calculate_status"/>
|
||||
<result property="status" column="status"/>
|
||||
<result property="admin" column="admin"/>
|
||||
<result property="adminId" column="admin_id"/>
|
||||
<result property="adminName" column="admin_name"/>
|
||||
<result property="opId" column="op_id"/>
|
||||
<result property="opName" column="op_name"/>
|
||||
<result property="opCreate" column="op_create"/>
|
||||
<result property="createTime" column="create_time"/>
|
||||
</resultMap>
|
||||
|
||||
<select id="selectProxyUserOrderPage" resultType="com.ruoyi.cai.dto.proxy.OrderListDTO">
|
||||
select
|
||||
t2.price, t2.recharge_name, t2.order_no,t3.nickname, t3.avatar,t3.usercode,
|
||||
t2.pay_time
|
||||
from cai_consume_log t1
|
||||
join cai_recharge_order t2 on t1.trace_id = t2.trace_id
|
||||
left join cai_user t3 on t2.user_id = t3.id
|
||||
where t1.type = 1 and t1.one_user_id = #{proxyUserCode} and t1.`status` = 1
|
||||
<if test="query.usercode != null and query.usercode != ''">
|
||||
and t3.usercode = #{query.usercode}
|
||||
</if>
|
||||
<if test="query.payTimeMin != null ">
|
||||
and t2.pay_time >= #{query.payTimeMin}
|
||||
</if>
|
||||
<if test="query.payTimeMax != null">
|
||||
<![CDATA[
|
||||
and t2.pay_time <= #{query.payTimeMax}
|
||||
]]>
|
||||
</if>
|
||||
order by t2.pay_time desc
|
||||
</select>
|
||||
|
||||
<select id="sumProxyUserOrder" resultType="java.math.BigDecimal">
|
||||
select
|
||||
sum(t2.price)
|
||||
from cai_consume_log t1
|
||||
join cai_recharge_order t2 on t1.trace_id = t2.trace_id
|
||||
where t1.type = 1 and t1.one_user_id = #{userCode} and t1.`status` = 1
|
||||
</select>
|
||||
</mapper>
|
||||
|
||||
@@ -56,5 +56,33 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
order by t1.create_time desc
|
||||
</select>
|
||||
|
||||
<select id="selectProxyBindUserPage" resultType="com.ruoyi.cai.dto.proxy.BindUserListDTO">
|
||||
select
|
||||
t2.usercode, t2.nickname,t2.avatar,t1.create_time as invite_time,t2.gender
|
||||
from cai_user_invite t1
|
||||
left join cai_user t2 on t1.user_id = t2.id
|
||||
where t1.invite_id = #{userId}
|
||||
<if test="query.usercode != null and query.usercode != ''">
|
||||
and t2.usercode = #{query.usercode}
|
||||
</if>
|
||||
<if test="query.nickname != null and query.nickname != ''">
|
||||
and t2.nickname like concat('%',#{query.nickname},'%')
|
||||
</if>
|
||||
<if test="query.inviteTimeMin != null ">
|
||||
and t1.create_time >= #{query.inviteTimeMin}
|
||||
</if>
|
||||
<if test="query.inviteTimeMax != null">
|
||||
<![CDATA[
|
||||
and t1.create_time <= #{query.inviteTimeMax}
|
||||
]]>
|
||||
</if>
|
||||
order by t1.create_time desc
|
||||
</select>
|
||||
|
||||
<select id="countProxyBindUser" resultType="java.lang.Long">
|
||||
select
|
||||
count(1)
|
||||
from cai_user_invite t1
|
||||
where t1.invite_id = #{userId}
|
||||
</select>
|
||||
</mapper>
|
||||
|
||||
Reference in New Issue
Block a user