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

【应用场景】
单据数据包已创建已保存后,将某些字段的值重置为缺省值。
【案例演示】
采购订单,单据头的供应商字段,明细信息的某一行的物料编码字段,恢复缺省值。

【实现步骤】
<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(二开案例.单据插件.字段恢复缺省值
【应用场景】单据数据包已创建已保存后,将某些字段的值重置为缺省值。【案例演示】采购订单,单据头的供应商字段,明细信息的某一行的物料...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



