分享过滤条件中增加一个自定义过滤变量插件代码
2014-08-27 11:29
816 查看
// 以下代码示例演示过滤条件中增加一个自定义过滤变量,例如预算部门 // 另外还需要在t_mdl_filtercondition,t_mdl_filtercondition_l中增加相应记录,例如 /*--插入配置过滤条件<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /> DELETE FROM T_MDL_FILTERCONDITION WHERE FID=1000001; INSERT INTO T_MDL_FILTERCONDITION(FID,FCONDITIONTYPEID,FSEQ,FOPERATE,FINPUTCTLTYPE,FDATASOURCETYPE,FDATAFIELDINDEX,FVALUE,FINPUT,FCLASSNAME) VALUES (1000001, 1000001,1,'=',0,0,0,'ISNULL',0,'XXApp.Core.BuggetDeptFilter.CurrBuggetDeptFilter,XXApp.Core') ; --插入配置过滤条件多语言 DELETE FROM T_MDL_FILTERCONDITION_L WHERE FID=1000001; INSERT INTO T_MDL_FILTERCONDITION_L(FPKID,FID,FLOCALEID,FNAME,FDATASOURCE,FTOOLTIP) VALUES (1000001,1000001,2052,N'当前预算部门',null,null) ; */ using System; using System.Collections.Generic; using System.Linq; using System.Text; using Kingdee.BOS.Core.CommonFilter.ConditionVariableAnalysis; using Kingdee.BOS.Core.CommonFilter; using System.ComponentModel; using Kingdee.BOS.App.Data; namespace XXApp.Core.BuggetDeptFilter { /// <summary> /// 当前用户根据预算部门进行过滤 /// </summary> [Description("当前用户根据预算部门进行过滤")] public class CurrBuggetDeptFilter : AbstractVariableAnalysisPlugin { public override string GetVariableFilter(ConditionVariableContext ctx) { StringBuilder sb = new StringBuilder(); // 获取当前登录用户所在的部门 sb.AppendFormat("select staff.FDEPTID "); sb.AppendFormat(" from t_bd_staff staff "); sb.AppendFormat(" inner join t_sec_user suser on staff.fpersonid=suser.FLINKOBJECT "); sb.AppendFormat(" inner join V_BD_CONTACTOBJECT vcon on vcon.fid=suser.FLINKOBJECT and vcon.ftype=1 "); sb.AppendFormat(" where suser.fuserid={0} ", ctx.Context.UserId); // 获取部门对应的预算部门内码 string strSelect = string.Format(@"select fdeptid from t_bd_department where fdeptid IN ({0}) and FISBUDGET=1 union all select FBudgetDept from t_bd_department where fdeptid IN ({0}) and FISBUDGET=0", sb.ToString()); long currDeptId = DBUtils.ExecuteScalar<long>(ctx.Context, strSelect, 0, null); // 当前用户没有关联职员 if (currDeptId <= 0) { return "1=1"; } // 取出当前预算部门的名称 string strSql = string.Format(@"SELECT FNAME FROM T_BD_DEPARTMENT_L WHERE FDEPTID={0} AND FLOCALEID={1}", currDeptId, ctx.Context.UserLocale.LCID); string strName = DBUtils.ExecuteScalar<string>(ctx.Context, strSql, string.Empty, null); return string.Format("{0} {1} '{2}'", ctx.FieldName , ctx.Operater, strName); } } }
相关文章推荐
- 分享过滤条件中增加一个自定义过滤变量插件代码
- 分享一个Eclipse代码配色教程与颜色主题插件
- magento add product attribute set sql 通过插件的sql部分,给产品增加一个属性代码
- jiathis分享插件,一个页面中分享多个分享代码
- 分享一个自定义的 console 类,让你不再纠结JS中的调试代码的兼容
- 分享一个很好用的验证码插件代码
- 整合Spring MVC,mybatis,hibernate,freemarker框架实现的自定义注解Validator验证机制实现对敏感词过滤的代码分享
- 分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
- 整合Spring MVC,mybatis,hibernate,freemarker框架实现的自定义注解Validator验证机制实现对敏感词过滤的代码分享
- 分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
- 一个为扩展过的自定义DataGridiew控件提供多行表头重绘所需的TreeNode和Columns代码,以满足列自动增加的功能。大家看看帮忙优化下
- 分享一个轻量级的代码高亮插件-jshighlight
- 整合Spring MVC,mybatis,hibernate,freemarker框架实现的自定义注解Validator验证机制实现对敏感词过滤的代码分享
- 代码实现listUI界面增加新条件过滤
- 分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
- 在看官方的例子时候由一个grid实例,在每一行之前有个加号,展开可以显示内容,在实际应用中还是非常有用的,照搬例子的代码,发现老是提示对象不存在,查阅资料后发现是没有加载插件,这里和大家分享下Ext.grid.RowExpander插件的使用,
- 在EtherCAT开发板上基础上增加一个自定义的变量mytest
- 分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
- 分享一个课自动整理代码的KEIL插件
- 为CKEditor在线编辑器增加一个自定义插件