如何在运行中,动态创建单据体字段

背景:动态表单界面上的单据体表格,要动态的创建一些字段,并填写字段的值。
案例:
图一,界面初始状态
20150721 00动态创建列01.png 





图二,动态构建单据体字段之后
20150721 00动态创建列02.png 

插件代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.ComponentModel;
using Kingdee.BOS;
using Kingdee.BOS.Util;
using Kingdee.BOS.Core;
using Kingdee.BOS.Core.Metadata;
using Kingdee.BOS.Core.Metadata.ControlElement;
using Kingdee.BOS.Core.Metadata.FieldElement;
using Kingdee.BOS.Core.Metadata.EntityElement;
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;
namespace JDSample.FormPlugIn.DynamicForm
{
    /// <summary>
    /// 演示如何动态构建表单上单据体的列
    /// </summary>
    /// <remarks>
    /// 示例界面要求:
    /// 1. 菜单 : 开始构建列 tbBuild
    /// 2. 整数字段:指定构建列数 F_JD_ColCount
    /// 3. 单据体表格:列表 FList
    /// 
    /// 演示过程:
    /// 1. 用户点击"开始构建列"菜单;
    /// 2. 清除单据体表格列,根据指定的列数,重新生成单据体表格列,并填充数据
    /// </remarks>
    [Description("演示如何动态构建表单上单据体的列")]
    public class S150517DynamicCreateColsEdit : AbstractDynamicFormPlugIn
    {
        /// <summary>
        /// 元数据
        /// </summary>
        private BusinessInfo _currInfo = null;
        /// <summary>
        /// 界面布局
        /// </summary>
        private LayoutInfo _currLayout = null;
        /// <summary>
        /// 初始化界面元数据时触发此事件
        /// </summary>
        /// <param name="e"></param>
        /// <remarks>
        /// 通常在此事件中,修改界面元数据;
        /// 本示例,在此事件中,把界面元数据复制到本地,避免与其他实例公用元数据,造成串账
        /// </remarks>
        public override void OnSetBusinessInfo(SetBusinessInfoArgs e)
        {
            // 复制界面元数据到本地变量
            FormMetadata currMeta = (FormMetadata)ObjectUtils.CreateCopy(
                this.View.OpenParameter.FormMetaData);
            _currInfo = currMeta.BusinessInfo;
            _currLayout = currMeta.GetLayoutInfo();
            // 用本地的元数据,替换动态表单引擎持有的元数据
            e.BusinessInfo = _currInfo;
            e.BillBusinessInfo = _currInfo;
        }
        /// <summary>
        /// 初始化界面元数据时触发此事件
        /// </summary>
        /// <param name="e"></param>
        /// <remarks>
        /// 通常在此事件中,修改界面元数据;
        /// 本示例,在此事件中,把界面元数据复制到本地,避免与其他实例公用元数据,造成串账
        /// </remarks>
        public override void OnSetLayoutInfo(SetLayoutInfoArgs e)
        {
            e.LayoutInfo = _currLayout;
            e.BillLayoutInfo = _currLayout;
        }
        /// <summary>
        /// 菜单点击事件
        /// </summary>
        /// <param name="e"></param>
        /// <remarks>
        /// 在此事件中,拦截用户点击"重新构建列"菜单,重新构建单据体表格
        /// </remarks>
        public override void AfterBarItemClick(AfterBarItemClickEventArgs e)
        {
            if (e.BarItemKey.EqualsIgnoreCase("tbBuild"))
            {
                int colCount = Convert.ToInt32(this.Model.GetValue("F_JD_ColCount"));
                // 修改元数据
                this.ReBuildFields(colCount);
                // 根据新的元数据,重构单据体表格列
                EntryGrid grid = this.View.GetControl<EntryGrid>("FList");
                grid.SetAllowLayoutSetting(false);  // 列按照索引显示
                EntityAppearance listAppearance = _currLayout.GetEntityAppearance("FList");
                grid.CreateDyanmicList(listAppearance);
                
                // 填充数据
                this.SetData();
                this.Model.SetValue("F_JD_ColCount", colCount);
                // 下达一个指令
                this.View.SendDynamicFormAction(this.View);
            }
        }
        /// <summary>
        /// 在单据体元数据中,重新构建字段。字段数量由参数决定
        /// </summary>
        /// <param name="fieldCount"></param>
        private void ReBuildFields(int fieldCount)
        {
            // 获取单据体表格的元数据及外观
            Entity entity = _currInfo.GetEntity("FList");
            EntityAppearance entityApp = _currLayout.GetEntityAppearance("FList");
            // 清除全部字段
            int oldCount = entity.Fields.Count;
            for(int i = oldCount - 1; i >= 0; i--)
            {
                Field fld = entity.Fields[ i ];
                _currInfo.Remove(fld);
                Appearance fldApp = _currLayout.GetAppearance(fld.Key);
                _currLayout.Remove(fldApp);
            }
            // 重新添加字段
            for (int i = 1; i <= fieldCount; i++)
            {
                // 构建文本字段
                TextField fld = new TextField();
                fld.Key = string.Format("F{0}", i);
                fld.Name = new LocaleValue(string.Format("字段{0}", i));
                fld.PropertyName = fld.Key;
                fld.EntityKey = "FList";
                fld.Entity = entity;
                _currInfo.Add(fld);
                TextFieldAppearance fldApp = new TextFieldAppearance();
                fldApp.Key = fld.Key;
                fldApp.Caption = fld.Name;
                fldApp.EntityKey = fld.EntityKey;
                fldApp.Width = new LocaleValue("150");
                fldApp.LabelWidth = new LocaleValue("80");
                fldApp.Tabindex = i;
                fldApp.Field = fld;
                _currLayout.Add(fldApp);
            }
        }
        /// <summary>
        /// 为单据体创建一行数据
        /// </summary>
        private void SetData()
        {
            // 使用最新的元数据,重新界面数据包
            _currInfo.GetDynamicObjectType(true);
            this.Model.CreateNewData();
            
            foreach (Field fld in _currInfo.GetEntity("FList").Fields)
            {
                this.Model.SetValue(fld.Key, string.Format("{0}的值", fld.Name.ToString()),0);
            }
        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值