工作流服务插件-自定义流转条件
## 工作流服务插件-自定义流转条件
1. 用户如何配置自定义条件
本例以配置“发起员工所属组织”作为自定义条件,用户可以在条件项中选择基础资料组织“集团本部”,作为参数传入条件插件中解析条件真假;若发起员工的组织是“集团本部”,则流转到“集团本部”这个节点:
![1.webp](https://wenku.my7c.com/download?fileName=0100a0c55760c5be46ab96d057e5c06501e7.webp)
2. 开发者如何实现自定义条件插件
2.1. 条件插件基类
Kingdee.BOS.Workflow.Kernel.Condition. AbstractConditionExecutorPlugIn
引用组件Kingdee.BOS.Workflow.Kernel.dll,开发者编写的条件执行类需要继承该基类。
2.2. 方法Execute
方法说明:条件执行的核心方法。
C#定义
public virtual void Execute(MapStateContext flowSateContext,
List<CustomizeConditionRow> customizeConditionList)
备注:插件中覆写此方法,自行实现条件计算,并将条件计算结果传回流程引擎即可。
| 插件基类 | AbstractConditionExecutorPlugIn |
| ---------------------- | ------------------------------------------------------------ |
| 所在组件 | Kingdee.BOS.Workflow.Kernel.dll |
| 条件执行方法 | void Execute(MapStateContext flowSateContext, List<CustomizeConditionRow> customizeConditionList) |
| 方法参数说明: | |
| flowSateContext | 流程上下文。可以获取BOS上下文、单据FormId、单据实体对象等。比如:// 示例,如何获取BOS上下文等数据:var context = flowSateContext.MapContext.BOSContext; // 获取BOS上下文var formId = flowSateContext.MapContext.BillFormId; // 获取单据FormIdvar data = flowSateContext.MapContext.BillDataObject; // 获取单据实体对象var originatorId = flowSateContext.MapContext.MapInstance.OriginatorId; // 获取流程发起人用户IDvar originatorPostId = flowSateContext.MapContext.MapInstance.OriginatorPostId; // 获取流程发起人岗位ID |
| customizeConditionList | 传入用户在连线上配置的自定义条件集合。可以根据每行条件的conditionRow.ConditionKey属性,获得用户在条件项中配置的基础资料ID,再计算该条件是否满足,计算结果通过conditionRow.ConditionResult传回流程引擎。 |
2.3. 示例插件代码
以下示例插件,举例说明如何解析“发起员工所属组织”连线条件,示例未经测试仅供参考思路。到K/3 Cloud安装目录的WebSite\Bin子目录,引用如下基本组件(其他组件按需引用):
Kingdee.BOS.dll
Kingdee.BOS.Core.dll
Kingdee.BOS.DataEntity.dll
Kingdee.BOS.ServiceHelper.dll
Kingdee.BOS.Workflow.Kernel.dll
Kingdee.BOS.Workflow.ServiceHelper.dll
```
using Kingdee.BOS.Condition;
using Kingdee.BOS.Core.Metadata;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.ServiceHelper;
using Kingdee.BOS.Workflow.Kernel;
using Kingdee.BOS.Workflow.Kernel.Condition;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Demo.Workflow.PlugIn.CustomizeCondition
{
/// <summary>
/// 以发起员工所属组织作为条件(本插件仅作为参考示例,未经测试)
/// </summary>
public class CustomizeConditionStaffOrg : AbstractConditionExecutorPlugIn
{
public override void Execute(MapStateContext flowSateContext, List<CustomizeConditionRow> customizeConditionList)
{
var context =flowSateContext.MapContext.BOSContext; // 获取BOS上下文
var originatorId =flowSateContext.MapContext.MapInstance.OriginatorId; // 获取流程发起人用户ID
foreach (CustomizeConditionRow conditionRow in customizeConditionList)
{
// TODO 此处根据conditionRow.ConditionKey获得每行自定义条件项中基础资料ID,本例中即为组织ID;并计算条件真假,计算结果通过conditionRow.ConditionResult传回流程引擎
// 获取发起人员工
long senderStaffId =Kingdee.BOS.Workflow.ServiceHelper.EntrustServiceHelper.GetStaffByUserId(context,originatorId);
FormMetadata senderStaffMeta = MetaDataServiceHelper.Load(context, "BD_Empinfo") as FormMetadata;
DynamicObject senderStaff = BusinessDataServiceHelper.LoadSingle(context,senderStaffId, senderStaffMeta.BusinessInfo.GetDynamicObjectType());
// 判断发起人员工所属组织,是否符合自定义条件中的组织要求
string senderStaffOrgId = Convert.ToString(senderStaff["UseOrgId_Id"]);
conditionRow.ConditionResult= (senderStaffOrgId == conditionRow.ConditionKey);
}
}
}
}
```
3. 开发者如何注册自定义条件插件
开发好自定义条件插件后,需要注册到数据表T_WF_ConditionType中。用户才能在流程连线的自定义条件设置界面,使用新的条件类型。
例如注册“员工所属组织”条件插件:
该条件类型的编码假定为WfConditionDemo;
该条件类型对应的基础资料组织FormID是ORG_Organizations;
条件插件格式是命名空间+类名, +组件名称,比如:
Demo.Workflow.PlugIn.CustomizeCondition.CustomizeConditionStaffOrg,Demo.Workflow.PlugIn
则在BOS设计器中导入如下KSQL:
DELETE T_WF_ConditionType WHERE FID = '200001';
INSERT INTO T_WF_ConditionType(FID,FNUMBER,FCREATORID,FCREATEDATE,FMODIFIERID,FMODIFYDATE,FDOCUMENTSTATUS,FFORBIDSTATUS,FOBJECTTYPEID,FPARSECLASS)
VALUES (200001,N'WfConditionDemo',16394,{ts'2017-04-27 10:08:12'},16394,{ts'2017-04-27 10:08:12'},'C','A','ORG_Organizations',N'Demo.Workflow.PlugIn.CustomizeCondition.CustomizeConditionStaffOrg,Demo.Workflow.PlugIn') ;
DELETE T_WF_ConditionType_L WHERE FID = '200001' AND FLOCALEID = 2052;
INSERT INTO T_WF_ConditionType_L(FPKID,FID,FLOCALEID,FNAME,FDESCRIPTION) VALUES(100001,200001,2052,N'以员工所属组织作为条件',N' ') ;
工作流服务插件-自定义流转条件
## 工作流服务插件-自定义流转条件1. 用户如何配置自定义条件 本例以配置“发起员工所属组织”作为自定义条件,用户可以在条件项中...
点击下载文档
本文2024-09-16 17:14:04发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-14394.html
您需要登录后才可以发表评论, 登录登录 或者 注册
最新文档
热门文章