二开案例.表单插件.获取业务对象的字段集合

【应用场景】获取业务对象的字段集合并填充到下拉列表中。
【案例演示】采购订单,新增一个基础资料字段,用于显示当前账套的所有单据和基础资料业务对象,再新增一个下拉列表字段,用于显示当前基础资料字段选中的业务对象的字段的集合。

【实现步骤】
<1>编写表单插件,代码如下。
using Kingdee.BOS;
using Kingdee.BOS.Core.DynamicForm;
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.DynamicForm.PlugIn.ControlModel;
using Kingdee.BOS.Core.Metadata;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.ServiceHelper;
using Kingdee.BOS.Util;
using System;
using System.Collections.Generic;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【表单插件】获取业务对象的字段集合
/// </summary>
[Description("【表单插件】获取业务对象的字段集合"), HotUpdate]
public class GetFieldListByFormIdFormPlugIn : AbstractDynamicFormPlugIn
{
public override void DataChanged(DataChangedEventArgs e)
{
base.DataChanged(e);
if (e.Field.Key.Equals("F_Jac_Base", StringComparison.OrdinalIgnoreCase))
{
// 获取业务对象标识
var formId = string.Empty;
var value = (DynamicObject)this.Model.GetValue(e.Field);
if (value != null)
{
formId = value["Id"].ToString();
}
// 绑定下拉列表字段
BindComboField(this.View, "F_Jac_Combo", formId);
}
}
/// <summary>
/// 绑定下拉列表字段
/// </summary>
/// <param name="view"></param>
/// <param name="comboFieldKey"></param>
/// <param name="formId"></param>
private static void BindComboField(IDynamicFormView view, string comboFieldKey, string formId)
{
var enumList = GetEnumItems(view.Context, formId);
var comboList = view.GetFieldEditor<ComboFieldEditor>(comboFieldKey, 0);
if (comboList != null)
{
comboList.SetComboItems(enumList);
}
}
/// <summary>
/// 从数据库读取指定枚举类型并转换成枚举项集合
/// </summary>
/// <param name="ctx"></param>
/// <param name="formId">业务对象标识</param>
/// <returns></returns>
private static List<EnumItem> GetEnumItems(Context ctx, string formId)
{
var enumList = new List<EnumItem>();
if (string.IsNullOrWhiteSpace(formId))
{
return enumList;
}
// 获取业务对象的运行时的元数据
var metadata = MetaDataServiceH
二开案例.表单插件.获取业务对象的字段集合
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。



