CRM: 新增 CRM 分页查询工具类,实现通用构造 crm 数据类型数据分页查询条件

This commit is contained in:
puhui999 2023-12-05 15:03:22 +08:00
parent b2621c8891
commit 78165f2161
2 changed files with 69 additions and 1 deletions

View File

@ -17,7 +17,8 @@ import java.util.Arrays;
public enum CrmSceneEnum implements IntArrayValuable {
OWNER(1, "我负责的"),
FOLLOW(2, "我关注的");
FOLLOW(2, "我关注的"),
SUBORDINATE(3, "下属负责的");
public static final int[] ARRAYS = Arrays.stream(values()).mapToInt(CrmSceneEnum::getType).toArray();
@ -38,6 +39,10 @@ public enum CrmSceneEnum implements IntArrayValuable {
return ObjUtil.equal(FOLLOW.getType(), type);
}
public static boolean isSubordinate(Integer type) {
return ObjUtil.equal(SUBORDINATE.getType(), type);
}
@Override
public int[] array() {
return ARRAYS;

View File

@ -0,0 +1,63 @@
package cn.iocoder.yudao.module.crm.util;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.ObjUtil;
import cn.iocoder.yudao.module.crm.dal.dataobject.concerned.CrmConcernedDO;
import cn.iocoder.yudao.module.crm.dal.dataobject.permission.CrmPermissionDO;
import cn.iocoder.yudao.module.crm.enums.common.CrmBizTypeEnum;
import cn.iocoder.yudao.module.crm.enums.common.CrmSceneEnum;
import cn.iocoder.yudao.module.crm.framework.vo.CrmBasePageReqVO;
import com.baomidou.mybatisplus.core.toolkit.support.SFunction;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import javax.annotation.Nullable;
import java.util.Collection;
/**
* CRM 分页查询工具类
*
* @author HUIHUI
*/
public class CrmQueryPageUtils {
/**
* 构造 crm 数据类型数据分页查询条件
*
* @param queryMapper 连表查询对象
* @param reqVO 查询条件
* @param userId 用户编号
* @param bizType 数据类型 {@link CrmBizTypeEnum}
* @param bizId 数据编号
* @param subordinateIds 下属用户编号可为空
*/
public static <T extends MPJLambdaWrapper<?>, V extends CrmBasePageReqVO, S> void builderQuery(T queryMapper, V reqVO, Long userId,
Integer bizType, SFunction<S, ?> bizId,
@Nullable Collection<Long> subordinateIds,
Boolean isAdmin) {
// 构建数据权限连表条件
if (ObjUtil.notEqual(isAdmin, Boolean.TRUE)) { // 管理员不需要数据权限
queryMapper.innerJoin(CrmPermissionDO.class, on ->
on.eq(CrmPermissionDO::getBizType, bizType).eq(CrmPermissionDO::getBizId, bizId)
.eq(CrmPermissionDO::getUserId, userId));
}
if (ObjUtil.equal(reqVO.getPool(), Boolean.TRUE)) { // 情况一公海
queryMapper.isNull("owner_user_id");
} else { // 情况二不是公海
queryMapper.isNotNull("owner_user_id");
}
// 场景数据过滤
if (CrmSceneEnum.isOwner(reqVO.getSceneType())) { // 场景一我负责的数据
queryMapper.eq("owner_user_id", userId);
}
if (CrmSceneEnum.isFollow(reqVO.getSceneType())) { // 场景二我关注的数据
queryMapper.innerJoin(CrmConcernedDO.class, on ->
on.eq(CrmConcernedDO::getBizType, bizType).eq(CrmConcernedDO::getBizId, bizId)
.eq(CrmConcernedDO::getUserId, userId));
}
// TODO puhui999: 这里有一个疑问如果下属负责的数据权限中没有自己的话还能看吗
if (CrmSceneEnum.isSubordinate(reqVO.getSceneType()) && CollUtil.isNotEmpty(subordinateIds)) { // 场景三下属负责的数据
queryMapper.in("owner_user_id", subordinateIds);
}
}
}