实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  RDIFramework.NET工作流程组件是以RDIFramework.NET框架为支撑,根据我们多年的项目经验和项目实践,结合国内各大工作流产品的特点研发的一套流程管理组件。该组件不仅考虑到从零搭建业务系统,也考虑到与现有业务系统的整合。从零搭建系统我们可以使用RDIFramework.NET框架以基础,来快速搭建业务系统。与现有系统的整合,我们的流程引擎提供了丰富的功能接口,供三方业务系统调用,并提供组件的全部源码方便用户进行整合。RDIFramework.NET工作流程组件采用SOA架构模式,流程引擎支持WCF方式访问。支持B/S、C/S系统,同时支持SQLServer、ORACLE等主流数据库。

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  RDIFramework.NET━工作流组件主要涵盖工作流的设计与定义、流程实例的发起与运行、业务流程的监控与管理、工作流组件与业务系统的集成与协作等内容。

  一、请假流程业务说明

    员工请假流程在企业各大信息化系统中基本都会涉及到,本文我将向大家展示使用RDIFramework.NET工作流组件来自定义员工请假流程。目前的请假业务流程要求是这样的:

    员工请假首先要提交至请假人所在部门的“部分经理”审批,如果请假天数小于等于3天则“部门经理”有权直接审批,否则需要提交至“分公司总经理”审批。

  二、请假申请流程定义

  请假申请业务流程我们已经清晰,现在我们使用RDIFramework.NET框架进行请假申请的定义。最终提供的请假流程如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  三、请假申请业务表单开发

  现在请假申请的整个流程的定义我们算完成了,下面我们就开始开发请假表单,表单开发非常简单,我们可以按常规的开发表单的方式进行开发,再加载到框架下即可。开发表单前我们需要在数据库中建立请假单这个数据表。同时表中需要包含以下四个字段:WorkFlowId(工作流主键)、WorkFlowInsId(工作流实例主键)、WorkTaskId(工作任务主键)、WorkTaskInsId(工作任务实例主键)。如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  表定义好了,现在我们就要进行业务表单的开发了,打开VS,开发请假申请表单,如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  再编写表单代码,在代码中可以*实现表单的业务逻辑,非常的灵活。同时流程的业务表单只需要继承自我们已经实现的基类(FrmBaseBizeForm)即可,再重载相应的方法。下面给了整个请假申请的业务表单实现代码以供参考,如下所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
using System;
using System.Data;
  
namespace RDIFramework.WorkFlow
{
    using RDIFramework.BizLogic;
    using RDIFramework.Utilities;
    using RDIFramework.WinForm.Utilities;
  
    /// <summary>
    /// 请假申请
    /// </summary>
    public partial class FrmQingJia : FrmBaseBizeForm
    {
        public FrmQingJia()
        {
            InitializeComponent();
        }
  
        private void FrmQingJia_Load(object sender, EventArgs e)
        {
            base.Form_Load();
            this.SetControlState();
            this.ShowEntity();
        }
  
        public override void SetControlState()
        {
            if (!string.IsNullOrEmpty(this.PageState))
            {
                this.pnlTool.Enabled = this.PageState != WorkConst.STATE_VIEW;
            }
              
            if (!string.IsNullOrEmpty(this.CtrlState))
            {
                gbMain.Enabled = btnSave.Enabled = this.CtrlState != "查看";
            }
            else
            {
                gbMain.Enabled = btnSave.Enabled = false;
            }
        }
  
        public override void ShowEntity()
        {
            string sql = "select * from testQingjia where workflowinsId=@workflowinsId";
            var sqlBuilder = new SQLBuilder(this.WorkFlowDbProvider);
            sqlBuilder.BeginSelect("testQingjia");
            sqlBuilder.SetWhere("workflowinsId", WorkFlowInsId);
            DataTable dt = sqlBuilder.EndSelect();
            if (dt != null && dt.Rows.Count > 0)//判断是否有数据,有数据读取数据库中的值
            {
                txtUserId.Text = dt.Rows[0]["userid"].ToString();
                txtUserName.Text = dt.Rows[0]["userName"].ToString();
                txtDuty.Text = dt.Rows[0]["dutyCaption"].ToString();
                txtDepartment.Text = dt.Rows[0]["archCaption"].ToString();
                dtBeginTime.Text = dt.Rows[0]["beginTime"].ToString();
                dtEndTime.Text = dt.Rows[0]["endTime"].ToString();
                txtDays.Text = dt.Rows[0]["Days"].ToString();
                txtQingJia.Text = dt.Rows[0]["QingJia"].ToString();
                cboQingJiaType.Text = dt.Rows[0]["QingJiaType"].ToString();
            }
            else//如果没有数据,初始化默认值
            {
                txtUserId.Text = UserId;
                txtUserName.Text = UserName;
                txtDuty.Text = DutyCaption;
                txtDepartment.Text = ArchCaption;
                dtBeginTime.Text = DateTime.Now.ToShortDateString();
                dtEndTime.Text = DateTime.Now.ToShortDateString();
            }
        }
  
        public override void SaveFormData(bool isDraft)
        {
            base.SaveFormData(isDraft);
            var sqlBuilder = new SQLBuilder(this.WorkFlowDbProvider);
            string sql = "DELETE TESTQINGJIA WHERE WORKFLOWINSID=@WORKFLOWINSID";//先删除原有数据
            sqlBuilder.BeginDelete("testQingjia");
            sqlBuilder.SetWhere("WORKFLOWINSID", WorkFlowInsId);
            sqlBuilder.EndDelete();
  
  
            sqlBuilder.BeginInsert("testQingjia");
            sqlBuilder.SetValue("WorkFlowId", WorkFlowId);
            sqlBuilder.SetValue("WorkTaskId", WorkTaskId);
            sqlBuilder.SetValue("WorkFlowInsId", WorkFlowInsId);
            sqlBuilder.SetValue("WorkTaskInsId", WorkTaskInsId);
            sqlBuilder.SetValue("ID", BusinessLogic.NewGuid());
            sqlBuilder.SetValue("userId", txtUserId.Text);
            sqlBuilder.SetValue("userName", txtUserName.Text);
            sqlBuilder.SetValue("dutyCaption", txtDuty.Text);
            sqlBuilder.SetValue("archCaption", txtDepartment.Text);
            if (this.WorkFlowDbProvider.CurrentDbType == CurrentDbType.Oracle)
            {
                sqlBuilder.SetValue("BeginTime", !string.IsNullOrEmpty(dtBeginTime.Text) ? BusinessLogic.GetOracleDateFormat(DateTimeHelper.ToDate(dtBeginTime.Text)) : BusinessLogic.ConvertToDateToString(dtBeginTime.Text));
                sqlBuilder.SetValue("EndTime", !string.IsNullOrEmpty(dtEndTime.Text) ? BusinessLogic.GetOracleDateFormat(DateTimeHelper.ToDate(dtEndTime.Text)) : BusinessLogic.ConvertToDateToString(dtEndTime.Text));
            }
            else
            {
                sqlBuilder.SetValue("BeginTime", BusinessLogic.ConvertToDateToString(dtBeginTime.Text));
                sqlBuilder.SetValue("EndTime", BusinessLogic.ConvertToDateToString(dtEndTime.Text));
            }
            sqlBuilder.SetValue("Days", txtDays.Text);
            sqlBuilder.SetValue("QingJiaType", BusinessLogic.ConvertToString(cboQingJiaType.SelectedItem));
            sqlBuilder.SetValue("QingJia", txtQingJia.Text);
            sqlBuilder.EndInsert();
        }
  
        private bool CheckInput()
        {
            if (string.IsNullOrEmpty(BusinessLogic.ConvertToString(cboQingJiaType.SelectedItem)))
            {
                MessageBoxHelper.ShowWarningMsg("请选择请假类型!");
                cboQingJiaType.Focus();
                return false;
            }
  
            if (string.IsNullOrEmpty(txtDays.Text))
            {
                MessageBoxHelper.ShowWarningMsg("请假天数不能为空!");
                txtDays.Focus();
                return false;
            }
  
            if(!MathHelper.IsDecimal(txtDays.Text))
            {
                MessageBoxHelper.ShowWarningMsg("请假天数必须为数值型!");
                txtDays.Focus();
                return false;
            }
  
            if (string.IsNullOrEmpty(txtQingJia.Text))
            {
                MessageBoxHelper.ShowWarningMsg("请假事由不能为空!");
                txtQingJia.Focus();
                return false;
            }
  
            return true;
        }
  
        private void btnSave_Click(object sender, EventArgs e)
        {
            if (!CheckInput())
            {
                return;
            }
  
            this.SaveFormData(false);
            MessageBoxHelper.ShowSuccessMsg("保存成功!");
        }
    }
}

  四、表单与业务流程的绑定

  表单开发完成后,我们需要在RDIFramework.NET框架中对表单进行绑定,如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  具体各项的说明可以参考RDIFramework.NET工作流部分的介绍文档。表单在框架中定义好后,我们再在请假申请各任务节点对表单进行绑定,需要说明的是,我们是以主表单以基础进行绑定的,这就代表一个任务节点可以拥有多个表单,这对复杂的业务非常有用。下面看下请假流程中部门经理对表单的绑定如下图所示,在“表单名”后面的按钮“...”就可以打开选择我们已经定义的主表单,来作为当前任务节点的表单列表。

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  五、请假申请演示

  请假申请是每个登录系统的人都应该可以使用的业务流程,因此我们把“请假申请”的启动节点的处理才指定为“所有人”,这就代表只要能登录系统,就可以使用“请假申请”流程。如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  打开“日常业务”功能模块,可以看到当前用户可以使用的业务流程,如下图所示:

  实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  在“可用业务”中选择“行政部”,右侧列出所选节点当前用户有权限启动的所有业务流程,我们选择“员工请假流程”,单击“开始任务”,打开启动任务主界面,如下图所示。假设请假4天,则应由当前用户所在部门经理审批的同时还需要分公司总经理审批。

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  单击提交后,流程提交到部门经理“wikstone”处,以wikstone用户登录,在未认领任务界面,可以看到请假申请已经提交给“部门经理处了,如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  RDIFramework.NET工作流组件约定所有任务提交后都会进入对方未认领任务列表,这样做的好处是:如果当前提交后想反悔,只要对方没有认领,就可以撤回任务。选择“认领任务”后,进行待办任务窗体,如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  选择一条待办任务后,我们可以“处理任务”,放弃对当前任务的认领、查看当前任务的执行流程图,当前任务的“处理记录”等。我们选择“处理任务”按钮,对当前任务进行处理,如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  在“处理任务”主界面,我们可以做很多的操作,具体可以参考RDIFramework.NET工作流组件的相关说明,这儿就不一一阐述了。填写好审批意见后,单击“提交”按钮,即可根据流程定义(当前请假天数大于3天)提交到“分公司总经理”处审批。下面我们以分公司总经理“lsx”的用户登录系统,可以看到请假申请已经提交到了分公司总经理处。如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

   按同样方式进行任务处理,再提交,流程就可以回到流程启动用户了。我们以流程启动者登录进来看下,查看下审批列表,如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  同时我们可以查看流程执行情况,如下图所示:

实例演示如何使用RDIFramework.NET 框架的工作流组件进行业务流程的定义—请假申请流程-WinForm

  至此,整个请假申请业务流程完成,当前在流程流转的过程中还有很多操作,比如:任务的回退、授权、指派、召回等都可以轻易实现。 



本文转自yonghu86 51CTO博客,原文链接:http://blog.51cto.com/yonghu/1618530,如需转载请自行联系原作者

上一篇:Linux SendMail 使用外部SMTP服务发送邮件


下一篇:EXCH-POP3互通邮件测试笔记04——EXCH2010邮件服务器搭建及内部邮件收发