二开案例.表单插件.加载多类别基础资料引用数据包
【应用场景】
多类别基础资料字段的数据包是一个精简数据包,仅包含基础资料的内码、编码、名称等简单属性,有时候,需要基于多类别基础资料列表字段配置的引用属性,加载多类别基础资料引用数据包。
【案例演示】
采购订单,加载多类别基础资料引用数据包。
【实现步骤】
<1>编写表单插件,代码如下。
using Kingdee.BOS.Core.DynamicForm.PlugIn; using Kingdee.BOS.Core.DynamicForm.PlugIn.Args; using Kingdee.BOS.Core.Metadata.EntityElement; using Kingdee.BOS.Core.Metadata.FieldElement; using Kingdee.BOS.Orm.DataEntity; using Kingdee.BOS.ServiceFacade; using Kingdee.BOS.ServiceHelper; using Kingdee.BOS.Util; using System.ComponentModel; using System.Text; namespace Jac.XkDemo.BOS.Business.PlugIn { /// <summary> /// 【表单插件】加载多类别基础资料引用数据包 /// </summary> [Description("【表单插件】加载多类别基础资料引用数据包"), HotUpdate] public class GetDynamicObjectByItemClassFieldFormPlugIn : AbstractDynamicFormPlugIn { /// <summary> /// 多类别基础资料字段标识 /// </summary> const string FieldKey = "F_Jac_Item"; public override void BarItemClick(BarItemClickEventArgs e) { base.BarItemClick(e); // TODO if (e.BarItemKey == "test") { // 多类别基础资料字段 var itemClassField = (ItemClassField)this.View.BillBusinessInfo.GetField(FieldKey); // 多类别基础资料列表字段 var itemClassType = (ItemClassTypeField)itemClassField.ControlField; //检索行,单据头:0; 单据体从0开始; var activeRow = this.View.Model.DataObject; var rowIndex = 0; if (itemClassField.Entity is EntryEntity) { this.View.Model.TryGetEntryCurrentRow(FieldKey, out activeRow, out rowIndex); } //获取 运行时实际指向的基础资料数据包 var itemClassDynamicObject = (DynamicObject)itemClassField.GetFieldValue(activeRow); if (itemClassDynamicObject == null) { return; } var itemClassTypeValue = (string)this.View.Model.GetValue(itemClassType, rowIndex); if (itemClassTypeValue == null) { return; } var itemClassTypeName = itemClassType.GetRefBaseData(itemClassTypeValue).Caption; // 获取运行时实际指向的基础资料的LookUpObject对象 var lookupObject = itemClassField.GetRealLookUpObject(this.View.Model, activeRow); // 获取运行时实际指向的基础资料基础资料 BaseDataField baseDataField; if (!itemClassType.DicBaseData.TryGetValue(lookupObject.FormId, out baseDataField) || baseDataField == null) { return; } // 获取基础资料内码 var itemId = itemClassField.RefFormDynamicObjectType.PrimaryKey.GetValue(itemClassDynamicObject); // 获取运行时实际指向的基础资料的引用数据包 var itemClassRefDynamicObject = BusinessDataServiceHelper.LoadSingle(this.View.Context, itemId, baseDataField.RefFormDynamicObjectType); this.View.ShowMessage(string.Format("当前选中的【{0}】的引用数据包:\r\n{1}\r\n多类别基础资料字段的数据包:\r\n{2}", itemClassTypeName, DynamicObjectToJson(itemClassRefDynamicObject), DynamicObjectToJson(itemClassDynamicObject))); } } private static string DynamicObjectToJson(object obj) { var jsonSerializerProxy = new JsonSerializerProxy(Encoding.UTF8, false); var jsonData = jsonSerializerProxy.Serialize(obj); return jsonData; } } }
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,新增多类别基础资料列表字段和多类别基础资料字段,菜单集合新增一个test菜单,注册表单插件,保存元数据,开发完毕。
【功能验证】
<1>登录业务站点,打开采购订单新增界面,选择某个客户后,点击菜单test,效果如下图。
通过上图,可以观察两个数据包的差异。
---------------------------------------------------------------------------------------------------------
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.表单插件.加载多类别基础资料引用数据包
【应用场景】多类别基础资料字段的数据包是一个精简数据包,仅包含基础资料的内码、编码、名称等简单属性,有时候,需要基于多类别基础资料...
点击下载文档
本文2024-09-23 03:58:13发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-162263.html
您需要登录后才可以发表评论, 登录登录 或者 注册
最新文档
热门文章