From 78165f2161ddbdf631c0052c1b0c4ea327121f84 Mon Sep 17 00:00:00 2001 From: puhui999 Date: Tue, 5 Dec 2023 15:03:22 +0800 Subject: [PATCH] =?UTF-8?q?CRM:=20=E6=96=B0=E5=A2=9E=20CRM=20=E5=88=86?= =?UTF-8?q?=E9=A1=B5=E6=9F=A5=E8=AF=A2=E5=B7=A5=E5=85=B7=E7=B1=BB=EF=BC=8C?= =?UTF-8?q?=E5=AE=9E=E7=8E=B0=E9=80=9A=E7=94=A8=E6=9E=84=E9=80=A0=20crm=20?= =?UTF-8?q?=E6=95=B0=E6=8D=AE=E7=B1=BB=E5=9E=8B=E6=95=B0=E6=8D=AE=E5=88=86?= =?UTF-8?q?=E9=A1=B5=E6=9F=A5=E8=AF=A2=E6=9D=A1=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../module/crm/enums/common/CrmSceneEnum.java | 7 ++- .../module/crm/util/CrmQueryPageUtils.java | 63 +++++++++++++++++++ 2 files changed, 69 insertions(+), 1 deletion(-) create mode 100644 yudao-module-crm/yudao-module-crm-biz/src/main/java/cn/iocoder/yudao/module/crm/util/CrmQueryPageUtils.java diff --git a/yudao-module-crm/yudao-module-crm-api/src/main/java/cn/iocoder/yudao/module/crm/enums/common/CrmSceneEnum.java b/yudao-module-crm/yudao-module-crm-api/src/main/java/cn/iocoder/yudao/module/crm/enums/common/CrmSceneEnum.java index 7263a2313..aaa3775fd 100644 --- a/yudao-module-crm/yudao-module-crm-api/src/main/java/cn/iocoder/yudao/module/crm/enums/common/CrmSceneEnum.java +++ b/yudao-module-crm/yudao-module-crm-api/src/main/java/cn/iocoder/yudao/module/crm/enums/common/CrmSceneEnum.java @@ -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; diff --git a/yudao-module-crm/yudao-module-crm-biz/src/main/java/cn/iocoder/yudao/module/crm/util/CrmQueryPageUtils.java b/yudao-module-crm/yudao-module-crm-biz/src/main/java/cn/iocoder/yudao/module/crm/util/CrmQueryPageUtils.java new file mode 100644 index 000000000..432ab7a20 --- /dev/null +++ b/yudao-module-crm/yudao-module-crm-biz/src/main/java/cn/iocoder/yudao/module/crm/util/CrmQueryPageUtils.java @@ -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 , V extends CrmBasePageReqVO, S> void builderQuery(T queryMapper, V reqVO, Long userId, + Integer bizType, SFunction bizId, + @Nullable Collection 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); + } + } + +}