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

【应用场景】
某些特定场景下的列表查询,希望能取消组织隔离。
【风险提醒】
因为数据规则的产生非常复杂,此案例中的处理方式对多组织下的数据规则做了简化处理,会导致列表查询原有的数据规则权限控制失效,您务必知晓此风险并谨慎使用。
【案例演示】
采购订单列表查询,强制取消组织隔离。

【实现步骤】
<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格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



