WikeFlow官网:www.wikesoft.com
WikeFlow学习版演示地址:workflow.wikesoft.com
WikeFlow学习版源代码下载:https://gitee.com/wikesoft/WorkFlow
WikeFlow2.0演示地址:workflow2.wikesoft.com
WikeFlow2.0帮助文档:WikeFlow2.0-帮助文档
定义一个流程,并指定该流程的唯一Key值 。通过流程定义的Key值 ,在创建实例的时候,通过指定Key值 ,能找到创建的是什么流程。如何创建流程,请查看《如何创建流程》
流程定义要指定业务程序集和业务类名(命名空间.类名,该类要实现IWorkFlowService),
该业务类要实现两部分功能
1、该业务类自己本身的业务功能(增、删、改、查或其它业务操作);
2、IWorkFlowService的六个接口的实现,这六个接口可以完成业务系统和工作流的交互功能。
当流程执行相关操作的时候,流程引擎自动调用业务类实现的IWorkFlowService方法,达到你的业务代码与WikeFlow2的系统交互功能。IWorkFlowService接口说明,请查看《关于IWorkFlowService》
演示用例的请假申请的业务程序集是WikeSoft.Enterprise,业务类名是WikeSoft.Enterprise.AppServices.HolidayApplyService
请假申请业务类HolidayApplyService代码截图如下图:
示例:HolidayService实现IWorkFlowServer的BeforeExecNextEvent接口
代码解释:
1、当申请人提交,将状态修改为审核中
2、驳回到申请人,将状态修改为未审核
3、流程结束,将状态修改为已审核
4、动作标记(ActionSign):是执行该动作的一个标记,通过该标记,你的业务系统能知道流程执行的什么操作,你的业务系统要处理什么逻辑。
/// <summary> /// 流程节点审批前事件 /// </summary> /// <param name="invokeMember">参数</param> /// <returns>WorkFlowMessage,如果Code= Fail,会中断流程引擎</returns> public WorkFlowMessage BeforeExecNextEvent(InvokeMember invokeMember) { WorkFlowMessage workFlowMessage = new InstanceMessage(); try { using (var context = new WikeDbContext()) { var data = context.Holidays.FirstOrDefault(c => c.INSTANCEID == invokeMember.InstanceId); if (data != null) { if (invokeMember.ActionSign == "start") { data.AUDITSTATE = "审核中"; } if (invokeMember.ActionSign == "reject_to_start") { data.AUDITSTATE = "未审核"; } if (invokeMember.ActionSign == "finish") { data.AUDITSTATE = "已审核 "; } context.Holidays.AddOrUpdate(data); context.SaveChanges(); } } } catch (Exception ex) { workFlowMessage.Code = CodeEum.Fail; workFlowMessage.Message = ex.Message; } return workFlowMessage; }