二开案例.表单插件.单选辅助资料

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

二开案例.表单插件.单选辅助资料

【应用场景】

在界面上显示并使用单选辅助资料列表字段。

单选辅助资料列表字段是一种特殊的基础资料字段,其数据源只能绑定自系统中已存在的辅助资料类型,其界面操作方式及插件控制方式和基础资料字段基本相同。



【案例演示】

采购订单,新增单选辅助资料列表字段,显示国家,编写表单插件,点击菜单后给单选辅助资料列表字段赋值。



【实现步骤】

<1>编写表单插件,代码如下。

using Kingdee.BOS.Core.DynamicForm.PlugIn;

using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;

using Kingdee.BOS.Core.Metadata.FieldElement;

using Kingdee.BOS.Core.SqlBuilder;

using Kingdee.BOS.ServiceHelper;

using Kingdee.BOS.Util;

using System;

using System.ComponentModel;


namespace Jac.XkDemo.BOS.Business.PlugIn

{

    /// <summary>

    /// 【表单插件】单选辅助资料

    /// </summary>

    [Description("【表单插件】单选辅助资料"), HotUpdate]

    public class AssistantFieldFormPlugIn : AbstractDynamicFormPlugIn

    {

        public override void BarItemClick(BarItemClickEventArgs e)

        {

            base.BarItemClick(e);

            var fieldKey = "F_Jac_Assistant_Country";

            var assistantField = (AssistantField)this.View.BillBusinessInfo.GetField(fieldKey);

            if (e.BarItemKey.Equals("tbSetValue1", StringComparison.OrdinalIgnoreCase))

            {

                // 方案1:用辅助资料内码赋值

                // 设置国家为中国

                var id = "46a524cf-5797-4e46-bd0a-7203fc426d9c";

                var dynamicObj = BusinessDataServiceHelper.LoadSingle(this.Context, id, assistantField.RefFormDynamicObjectType);

                this.Model.SetValue(fieldKey, dynamicObj);

                this.View.ShowMessage("设置成功!");

                return;

            }


            if (e.BarItemKey.Equals("tbSetValue2", StringComparison.OrdinalIgnoreCase))

            {

                // 方案2:用辅助资料编码赋值

                // 设置国家为美国

                var number = "America";

                var queryBuilderParemeter = new QueryBuilderParemeter();

                queryBuilderParemeter.FormId = "BOS_ASSISTANTDATA_SELECT";

                queryBuilderParemeter.FilterClauseWihtKey = string.Format("FNumber ='{0}'", number);

                var dynamicObjs = BusinessDataServiceHelper.LoadFromCache(this.Context, assistantField.RefFormDynamicObjectType, queryBuilderParemeter);

                this.Model.SetValue(fieldKey, dynamicObjs[0]);

                this.View.ShowMessage("设置成功!");

                return;

            }

        }

    }

}


/*

 * 

 * 

-- 辅助资料查询

SELECT a.FID AS 辅助资料类型内码,c.FNAME AS 辅助资料类型名称,a.FENTRYID AS 辅助资料内码,a.FNUMBER AS 辅助资料编码,b.FDATAVALUE AS 辅助资料名称,* 

FROM T_BAS_ASSISTANTDATAENTRY a

LEFT JOIN T_BAS_ASSISTANTDATAENTRY_L b ON a.FENTRYID=b.FENTRYID AND b.FLOCALEID=2052

LEFT JOIN T_BAS_ASSISTANTDATA_L c ON a.FID=c.FID AND c.FLOCALEID=2052

WHERE a.FID='8a6e30f0-2c26-4639-aff5-76749daa355e'

 *

 *  

 */



<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。


<3>BOSIDE扩展采购订单,添加一个单选辅助资料列表字段,辅助资料类型设置为[国家],添加菜单子项,注册表单插件,保存元数据,开发完毕。



【功能验证】

现在可以登录业务站点,打开采购订单编辑界面,尝试使用一下单选辅助资料列表字段啦。

打开辅助资料列表给字段赋值:

插件通过辅助资料内码赋值:

插件通过辅助资料编码赋值:

---------------------------------------------------------------------------------------------------------













【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696

二开案例.表单插件.单选辅助资料

【应用场景】在界面上显示并使用单选辅助资料列表字段。单选辅助资料列表字段是一种特殊的基础资料字段,其数据源只能绑定自系统中已存在的...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息