电脑桌面
添加蚂蚁七词文库到电脑桌面
安装后可以在桌面快捷访问

二开案例.列表插件.列表查询使用所有组织

来源:金蝶云社区作者:金蝶2024-09-233

二开案例.列表插件.列表查询使用所有组织

【应用场景】

某些特定场景下的列表查询,希望能取消组织隔离。


【风险提醒】

因为数据规则的产生非常复杂,此案例中的处理方式对多组织下的数据规则做了简化处理,会导致列表查询原有的数据规则权限控制失效,您务必知晓此风险并谨慎使用。


【案例演示】

采购订单列表查询,强制取消组织隔离。



【实现步骤】

<1>编写列表插件,代码如下。

using Kingdee.BOS.App.Data;
using Kingdee.BOS.Core.List.PlugIn;
using Kingdee.BOS.Core.List.PlugIn.Args;
using Kingdee.BOS.Util;
using System;
using System.ComponentModel;
using System.Linq;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
    /// <summary>
    /// 【列表插件】列表查询使用所有组织
    /// </summary>
    [Description("【列表插件】列表查询使用所有组织"), HotUpdate]
    public class ListQueryUseAllOrgListPlugIn : AbstractListPlugIn
    {
        public override void AfterCreateSqlBuilderParameter(SqlBuilderParameterArgs e)
        {
            base.AfterCreateSqlBuilderParameter(e);
            var listQueryUseAllOrg = this.View.OpenParameter.GetCustomParameter("ListQueryUseAllOrg");
            if (listQueryUseAllOrg == null || !Convert.ToBoolean(listQueryUseAllOrg))
            {
                // 打开列表时,如果未在ShowParameter中指定了参数ListQueryUseAllOrg=true,则不执行下面的特殊的过滤逻辑
                // 设置参数示例:showParameter.CustomParams.Add("ListQueryUseAllOrg", "true");
                return;
            }
            /*方案1:直接禁用组织隔离特性*/
            //e.sqlBuilderParameter.IsIsolationOrg = false;
            //e.sqlBuilderParameter. IsolationOrgList.Clear();
            //e.sqlBuilderParameter.IsEnabledDetialDRForList = false;
            //e.sqlBuilderParameter.DataRuleFilterString = string.Empty;
            //e.sqlBuilderParameter.DynamicFilterExpression = string.Empty;
            //e.sqlBuilderParameter.SqlParams4DataRule.Clear();
            /*方案2:按指定的组织过滤数据*/
            // 先获取组织信息
            var

二开案例.列表插件.列表查询使用所有组织

【应用场景】某些特定场景下的列表查询,希望能取消组织隔离。【风险提醒】因为数据规则的产生非常复杂,此案例中的处理方式对多组织下的数...
点击下载文档文档为doc格式

声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。

已经是第一篇
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息
QQ群
  • 答案:my7c点击这里加入QQ群
支持邮箱
微信
  • 微信