前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >k3cloud单据插件

k3cloud单据插件

作者头像
py3study
发布2020-01-08 16:49:54
8120
发布2020-01-08 16:49:54
举报
文章被收录于专栏:python3python3

命名空间

Kingdee.BOS.Core.Bill.PlugIn

继承体系 System.Object Kingdee.BOS.Core.DynamicForm.PlugIn.AbstractDynamicFormPlugIn Kingdee.BOS.Core.Bill.PlugIn.AbstractBillPlugIn Kingdee.BOS.Core.Base.PlugIn.AbstractBasePlugIn 接口

IBillViewPlugIn

单据视图的插件接口,继承自IDynamicFromViewPlugIn,扩展了初始化接口和单据转换接口。

Name

Description

OnBillInitialize

单据页面初始化事件

OnGetConvertRule

选单/下推过程, 确定单据转换规则

OnShowConvertOpForm

选单过程,展示可选源单据;捕获此事件,调整可选的单据类型

OnShowTrackResult

上/下查过程,获得上/下查结果;捕获此事件,调整上/下查结果

OnBillInitialize

单据初始化插件,在OnInitialize后调用。OnInitialize是继承自动态表单的方法,主要应用在动态表单中已介绍。 OnBillInitialize中主要是加载单据参数BillOpenParameter,该参数继承自DynamicFormOpenParameter。

可以在OpenParameter增加自定义参数。例如:

获取参数,设置单据的显示标题,初始化状态变量。

C#

public override void OnBillInitialize(BillInitializeEventArgs e){//取参数_billTypeId = this.View.OpenParameter.GetCustomParameter("FBillTypeId");//设置单据标题this.View.SetFormTitle(this.View.BillBusinessInfo.GetForm().Name);//获取当前操作状态_curOperationStatus = e.Paramter.Status;base.OnBillInitialize(e);}

调用方传递CustomParameter方法如下:

C#

BillOpenParameter billParam = new BillOpenParameter();billParam.FormId = K3.Core.SCM.SCMFormIdConst.BD_SerialMainFile;billParam.SyncCallBackAction = true;billParam.ParentPageId = this.View.PageId;billParam.PageId = Kingdee.BOS.Util.SequentialGuid.NewGuid().ToString();billParam.Status = stats;billParam..CustomParams.Add("FBillTypeId", this.BillTypeId);this.View.ShowForm(billParam);

IBillModelPlugIn

单据模型的插件接口,继承自IDynamicFromModelPlugIn,提供单据特殊操作。

Name

Description

AfterCopyData

复制单据完毕后事件

AfterLoadData

业务对象加载后的扩展接口

AfterSave

调用应用服务保存成功后触发

AfterSetStatus

设置单据状态后调用

AfterSubmit

调用应用服务提交成功后触发

BeforeSave

调用应用服务器,提交数据保存前触发

BeforeSetStatus

设置单据状态前调用

BeforeSubmit

调用应用服务器,提交前触发

CopyData

复制单据

LoadData

加载业务对象扩展接口

SaveBillFailed

调用应用服务保存失败,出错时触发

VerifyImportData

数据导入校验

BeforeSave

单据保存前插件。单据内置保存操作,自动将修改数据保存到数据库。插件BeforeSave可以在保存前对单据数据进行处理。通常处理有两个:

数据校验;

计算和更新数据;

在BOS平台当客户端发起请求,到web服务器后,领域模型框架调用运行时,加载插件运行。用户执行操作时,运行时调用操作服务进行数据模型的操作。而插件中调用服务也是先向服务框架请求服务。

通常应用都是在业务保存前进行数据校验,校验通过后,调用保存服务保存,在大多数系统中都是这样应用。在BOS平台中,架构设计上支持集成服务,所有操作都是设计有服务接口,二次开发可以很容易将所有操作发布成服务供外部系统调用。这样对外部系统来说,调用服务保存将会很容易。但如何保证数据的正确性?大部分设计是由外部系统保证,但对复杂业务系统来说,外部系统很难保证每个业务数据的正确性,甚至用大量访问系统来获取验证数据。为此,BOS平台在操作上提供了校验服务,这样在系统内部通过插件调用服务前会自动执行校验服务。而外部系统访问的是BOS操作发布的服务本身也带有校验。

因此建议将数据校验按业务逻辑分开成两类,一类是界面输入校验,如字符、数字类型、格式化和表达式校验等,可以在插件保存前进行校验;而数据业务的校验,如库存校验信用检查等,通过校验服务校验。

校验方法如下:

1. 优先通过IDE配置校验数据,如输入格式,最大最小值限定;

2. 操作控制类校验在表单的操作前插件检查;

3. 业务控制类校验在表单校验服务校验。

该事件中可以通过设置参数的Cancel终止保存操作。

下面例子是保存前更新数据(信用评分单据保存设置信用等级标准)。

代码语言:javascript
复制
public override void BeforeSave(BeforeSaveEventArgs e){DynamicObject doGradeScheme = this.Model.GetValue("FScheme") as DynamicObject;decimal deSumScore = Convert.ToDecimal(this.Model.GetValue("FSumScore")); int iGradeSchemeId = Convert.ToInt32(doGradeScheme["Id"]); // 保存前判断当前信用评分表的综合得分属于哪一个信用等级标准DynamicObjectCollection docGrades = CreditServiceHelper.GetCreditGrades(this.Context, 0, iGradeSchemeId);for (int i = 0; i < docGrades.Count(); i++){DynamicObject doGrade = docGrades;decimal deScoreFrom = Convert.ToDecimal(doGrade["FSCOREFROM"]);decimal deScoreTo = Convert.ToDecimal(doGrade["FSCORETO"]);if(deSumScore >= deScoreFrom && deSumScore <= deScoreTo){this.View.Model.SetValue("FGrade", Convert.ToInt32(doGrade["FID"]));this.View.Model.SetValue("FSuggestion", doGrade["FDESCRIPTION"]);}}}

AfterSave

单据保存后插件。主要用于保存后界面的控制、控件的显示以及不需要事务保证的其他数据更新。

BeforeSubmit(提交前)和AfterSubmit(提交后)事件与保存类似,不再做介绍。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-08-31 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档