二开案例.表单插件.加载多类别基础资料引用数据包

栏目:云星空知识作者:金蝶来源:金蝶云社区发布:2024-09-23浏览:1

二开案例.表单插件.加载多类别基础资料引用数据包

【应用场景】

多类别基础资料字段的数据包是一个精简数据包,仅包含基础资料的内码、编码、名称等简单属性,有时候,需要基于多类别基础资料列表字段配置的引用属性,加载多类别基础资料引用数据包。



【案例演示】

采购订单,加载多类别基础资料引用数据包。

上传图片



【实现步骤】

<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

二开案例.表单插件.加载多类别基础资料引用数据包

【应用场景】多类别基础资料字段的数据包是一个精简数据包,仅包含基础资料的内码、编码、名称等简单属性,有时候,需要基于多类别基础资料...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息