辅助资料扩展字段筛选二开使用案例
一、【需求问题】
其它出库单:想针对其它出库的领用发生部门/成本中心和用途(辅助资料)进行归纳汇总;期望:当选择部门A时,用途中仅能选择部门A对应的用途;当选择部门B时,用途中仅能选择部门B对应的用途
二、【功能分析】
BOS中辅助资料字段,无法设置过滤,当前需求只能通过二开表单插件处理
【实现】
1、扩展辅助资料,添加基础资料字段,绑定"部门"
2、表单插件重写BeforeF7Select、BeforeSetItemValueByNumber事件,触发辅助资料查询时,加入部门的值,进行过滤辅助资料
3、注册表单插件
相关表
T_BAS_ASSISTANTDATA 辅助资料
T_BAS_ASSISTANTDATA_L 辅助资料多语言
T_BAS_ASSISTANTDATAENTRY 辅助资料分录
T_BAS_ASSISTANTDATAENTRY_L 辅助资料多语言
select * from T_BAS_ASSISTANTDATA where FID = '005056a3024ca51d11e428fb8c41a25d' --辅助资料 select * from T_BAS_ASSISTANTDATA_L where FNAME = '等级'--辅助资料多语言 select * from T_BAS_ASSISTANTDATAENTRY where FID = '005056a3024ca51d11e428fb8c41a25d'--辅助资料分录 select * from T_BAS_ASSISTANTDATAENTRY_L where FENTRYID in ('005056a3024ca51d11e428fbd7c96188', '005056a3024ca51d11e428fbdf11d074','005056a3024ca51d11e428fbecefddef','005056a3024ca51d11e428fbf3700759') --辅助资料多语言
#coding:utf-8 import clr clr.AddReference("System") clr.AddReference("Kingdee.BOS") clr.AddReference("Kingdee.BOS.Core") from System import * from System import StringComparison from Kingdee.BOS.Core.DynamicForm import * from Kingdee.BOS.Core.DynamicForm.PlugIn.Args import * def BeforeF7Select(e): if e.FieldKey.Equals("FClassAssistant", StringComparison.OrdinalIgnoreCase): depObj = this.View.Model.GetValue("FDeptId") if depObj is not None: # 通过"部门"过滤"辅助资料" e.ListFilterParameter.Filter = " FDeptId = " + str(depObj["Id"]) def BeforeSetItemValueByNumber(e): if e.BaseDataFieldKey.Equals("FClassAssistant", StringComparison.OrdinalIgnoreCase): depObj = this.View.Model.GetValue("FDeptId") if depObj is not None: # 通过"部门"过滤"辅助资料" e.Filter = " FDeptId = " + str(depObj["Id"])
1、未填写部门,显示全部辅助资料
2、按选择部门筛选
参考
辅助资料扩展字段筛选二开使用案例
一、【需求问题】其它出库单:想针对其它出库的领用发生部门/成本中心和用途(辅助资料)进行归纳汇总;期望:当选择部门A时,用途中仅能选...
点击下载文档
上一篇:采购管理-货源管理说明下一篇:订单变更时强制价目表定价的一种情况
本文2024-09-16 19:04:54发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-26271.html
您需要登录后才可以发表评论, 登录登录 或者 注册
最新文档
热门文章