二开案例.表单插件.获取多选辅助资料名称和编码

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

二开案例.表单插件.获取多选辅助资料名称和编码

【应用场景】

<1>获取多选辅助资料名称和编码。

<2>通过添加冗余字段存储多选辅助资料的名称和编码,变通实现多选辅助资料的列表查询功能。

【案例演示】采购订单,新增多选辅助资料字段,新增文本字段存储多选辅助资料字段的多个辅助资料的名称和编码,并实现列表查询多选辅助资料数据的功能。

【实现步骤】

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

using Kingdee.BOS;

using Kingdee.BOS.Core.DynamicForm.PlugIn;

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

using Kingdee.BOS.Core.Metadata.FieldElement;

using Kingdee.BOS.Orm.DataEntity;

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 GetMulAssistantNameFormPlugIn : AbstractDynamicFormPlugIn

    {

        public override void DataChanged(DataChangedEventArgs e)

        {

            base.DataChanged(e);

            if (e.Field.Key.Equals("F_Jac_MulAssistant", StringComparison.OrdinalIgnoreCase))

            {

                // 获取多选辅助资料数据包集合

                var objs = this.Model.GetValue(e.Field.Key) as DynamicObjectCollection;

                // 获取多选辅助资料的名称

                var assistantName = GettMulAssistantName((MulAssistantField)e.Field, objs);

                this.Model.SetValue("F_Jac_MulLangText", assistantName);

                // 获取多选辅助资料的编码

                var assistantNumber = GettMulAssistantNumber((MulAssistantField)e.Field, objs);

                this.Model.SetValue("F_Jac_Text", assistantNumber);

            }

        }


        /// <summary>

        /// 获取多选辅助资料的名称(多个名称用分号分割)

        /// </summary>

        /// <param name="field"></param>

        /// <param name="objs"></param>

        /// <returns></returns>

        private LocaleValue GettMulAssistantName(MulAssistantField field, DynamicObjectCollection objs)

        {

            var lv = new LocaleValue();

            if (objs == null | objs.Count == 0)

            {

                return lv;

            }


            foreach (var obj in objs)

            {

                var assistant = obj[field.PropertyName] as DynamicObject;

                if (assistant != null)

                {

                    var name = (LocaleValue)assistant["FDataValue"];

                    lv.Merger(name, ";");

                }

            }


            return lv;

        }


        /// <summary>

        /// 获取多选辅助资料的编码(多个编码用分号分割)

        /// </summary>

        /// <param name="field"></param>

        /// <param name="objs"></param>

        /// <returns></returns>

        private string GettMulAssistantNumber(MulAssistantField field, DynamicObjectCollection objs)

        {

            var lv = new LocaleValue();

            if (objs == null | objs.Count == 0)

            {

                return string.Empty;

            }


            var list = new List<string>();

            foreach (var obj in objs)

            {

                var assistant = obj[field.PropertyName] as DynamicObject;

                if (assistant != null)

                {

                    list.Add((string)assistant["FNumber"]);

                }

            }


            return string.Join(";", list);

        }

    }

}


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


<3>BOSIDE扩展采购订单,新增多选辅助资料资料,多语言文本字段,文本字段,注册表单插件,保存元数据,开发完毕。


现在可以登录业务站点,打开采购订单新增界面,录入多选辅助资料后,即可自动获取该多选辅助资料的名称和编码集合啦。

列表查询多选辅助资料:



【知识点】

<1>辅助资料类型,对应元数据是[BOS_ASSISTANTDATA_DETAIL],但是多选辅助资料字段对应的元数据是[BOS_ASSISTANTDATA_SELECT]。

<2>多选辅助资料在数据包中的数据结构如下图所示,获取多选辅助资料的某个字段的值可参考如下数据包结构进行取值。














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

二开案例.表单插件.获取多选辅助资料名称和编码

【应用场景】<1>获取多选辅助资料名称和编码。<2>通过添加冗余字段存储多选辅助资料的名称和编码,变通实现多选辅助资料的列表查询功能。【...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息