二开案例.单据插件.字段恢复缺省值

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

二开案例.单据插件.字段恢复缺省值

【应用场景】

单据数据包已创建已保存后,将某些字段的值重置为缺省值。



【案例演示】

采购订单,单据头的供应商字段,明细信息的某一行的物料编码字段,恢复缺省值。

上传图片


【实现步骤】

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

using Kingdee.BOS.Core.Bill.PlugIn;
using Kingdee.BOS.Core.DynamicForm;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Util;
using System.ComponentModel;
using System.Linq;
using System.Reflection;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
    /// <summary>
    /// 【单据插件】字段恢复缺省值
    /// </summary>
    [Description("【单据插件】字段恢复缺省值"), HotUpdate]
    public class FieldResetDefaultValueBillPlugIn : AbstractBillPlugIn
    {
        public override void BarItemClick(BarItemClickEventArgs e)
        {
            base.BarItemClick(e);
            if (e.BarItemKey.EqualsIgnoreCase("test"))
            {
                ResetDefaultValue(this.View, "FSupplierId");// 处理单据头字段
                ResetDefaultValue(this.View, "FMaterialId", 1);// 处理单据体字段
            }
        }
        public static void ResetDefaultValue(IDynamicFormView view, string fieldKey, int rowIndex = 0)
        {
            if (view == null)
            {
                return;
            }
            var field = view.BillBusinessInfo.GetField(fieldKey);
            if (field == null)
            {
                return;
            }
            // 重新绑定默认值
            var calculator = view.GetService<IDefaultValueCalculator>();
            if (calculator == null)
            {
                return;
            }
            var entityObj = view.Model.GetEntityDataObject(field.Entity, rowIndex);
            calculator.Initialize(view.Model);
            if (rowIndex == 0)// 单据头
            {
                // 先清空已有的数据
                view.Model.SetValue(fieldKey, null);
                calculator.ApplyFieldValue(field, entityObj, field.DefValue, true);
            }
            else// 单据体未开放接口,使用反射实现
            {
                var methods = typeof(AbstractDefaultValueCalculator).GetMethods(BindingFlags.Instance | BindingFlags.NonPublic);
                var methodApplyFieldValue = methods.FirstOrDefault(o => o.Name == "ApplyFieldValue" && o.GetParameters().Length == 5);
                if (methodApplyFieldValue != null)
                {
                    // 先清空已有的数据
                    view.Model.SetValue(fieldKey, null, rowIndex);
                    methodApplyFieldValue.Invoke(calculator, new object[] { field, entityObj, field.DefValue, true, rowIndex });
                }
            }
        }
    }
}


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

上传图片


<3>BOSIDE扩展采购订单,菜单集合新增一个test菜单,供应商字段和物料编码字段设置缺省值,注册表单插件,保存元数据,开发完毕。

上传图片

上传图片



【功能验证】

<1>登录业务站点,打开采购订单编辑界面,点击菜单test,供应商字段和物料编码字段的数据会被重置为缺省值。

上传图片

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













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

二开案例.单据插件.字段恢复缺省值

【应用场景】单据数据包已创建已保存后,将某些字段的值重置为缺省值。【案例演示】采购订单,单据头的供应商字段,明细信息的某一行的物料...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息