例項演示使用RDIFramework.NET 框架的工作流元件進行業務流程的定義—請假申請流程-WinForm
例項演示使用RDIFramework.NET 框架的工作流元件
進行業務流程的定義—請假申請流程-WinForm
參考文章:
RDIFramework.NET工作流程元件是以RDIFramework.NET框架為支撐,根據我們多年的專案經驗和專案實踐,結合國內各大工作流產品的特點研發的一套流程管理元件。該元件不僅考慮到從零搭建業務系統,也考慮到與現有業務系統的整合。從零搭建系統我們可以使用RDIFramework.NET框架以基礎,來快速搭建業務系統。與現有系統的整合,我們的流程引擎提供了豐富的功能介面,供三方業務系統呼叫,並提供元件的全部原始碼方便使用者進行整合。RDIFramework.NET工作流程元件採用SOA架構模式,流程引擎支援WCF方式訪問。支援B/S、C/S系統,同時支援SQLServer、ORACLE等主流資料庫。
RDIFramework.NET━工作流元件主要涵蓋工作流的設計與定義、流程例項的發起與執行、業務流程的監控與管理、工作流元件與業務系統的整合與協作等內容。
一、請假流程業務說明
員工請假流程在企業各大資訊化系統中基本都會涉及到,本文我將向大家展示使用RDIFramework.NET工作流元件來自定義員工請假流程。目前的請假業務流程要求是這樣的:
員工請假首先要提交至請假人所在部門的“部分經理”審批,如果請假天數小於等於3天則“部門經理”有權直接審批,否則需要提交至“分公司總經理”審批。
二、請假申請流程定義
請假申請業務流程我們已經清晰,現在我們使用RDIFramework.NET框架進行請假申請的定義。最終提供的請假流程如下圖所示:
三、請假申請業務表單開發
現在請假申請的整個流程的定義我們算完成了,下面我們就開始開發請假表單,表單開發非常簡單,我們可以按常規的開發表單的方式進行開發,再載入到框架下即可。開發表單前我們需要在資料庫中建立請假單這個資料表。同時表中需要包含以下四個欄位:WorkFlowId(工作流主鍵)、WorkFlowInsId(工作流例項主鍵)、WorkTaskId(工作任務主鍵)、WorkTaskInsId(工作任務例項主鍵)。如下圖所示:
表定義好了,現在我們就要進行業務表單的開發了,開啟VS,開發請假申請表單,如下圖所示:
再編寫表單程式碼,在程式碼中可以自由實現表單的業務邏輯,非常的靈活。同時流程的業務表單只需要繼承自我們已經實現的基類(FrmBaseBizeForm)即可,再過載相應的方法。下面給了整個請假申請的業務表單實現程式碼以供參考,如下所示:
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 [email protected]"; 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 [email protected]";//先刪除原有資料 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工作流部分的介紹文件。表單在框架中定義好後,我們再在請假申請各任務節點對錶單進行繫結,需要說明的是,我們是以主表單以基礎進行繫結的,這就代表一個任務節點可以擁有多個表單,這對複雜的業務非常有用。下面看下請假流程中部門經理對錶單的繫結如下圖所示,在“表單名”後面的按鈕“...”就可以開啟選擇我們已經定義的主表單,來作為當前任務節點的表單列表。
五、請假申請演示
請假申請是每個登入系統的人都應該可以使用的業務流程,因此我們把“請假申請”的啟動節點的處理才指定為“所有人”,這就代表只要能登入系統,就可以使用“請假申請”流程。如下圖所示:
開啟“日常業務”功能模組,可以看到當前使用者可以使用的業務流程,如下圖所示:
在“可用業務”中選擇“行政部”,右側列出所選節點當前使用者有許可權啟動的所有業務流程,我們選擇“員工請假流程”,單擊“開始任務”,開啟啟動任務主介面,如下圖所示。假設請假4天,則應由當前使用者所在部門經理審批的同時還需要分公司總經理審批。
單擊提交後,流程提交到部門經理“wikstone”處,以wikstone使用者登入,在未認領任務介面,可以看到請假申請已經提交給“部門經理處了,如下圖所示:
RDIFramework.NET工作流元件約定所有任務提交後都會進入對方未認領任務列表,這樣做的好處是:如果當前提交後想反悔,只要對方沒有認領,就可以撤回任務。選擇“認領任務”後,進行待辦任務窗體,如下圖所示:
選擇一條待辦任務後,我們可以“處理任務”,放棄對當前任務的認領、檢視當前任務的執行流程圖,當前任務的“處理記錄”等。我們選擇“處理任務”按鈕,對當前任務進行處理,如下圖所示:
在“處理任務”主介面,我們可以做很多的操作,具體可以參考RDIFramework.NET工作流元件的相關說明,這兒就不一一闡述了。填寫好審批意見後,單擊“提交”按鈕,即可根據流程定義(當前請假天數大於3天)提交到“分公司總經理”處審批。下面我們以分公司總經理“lsx”的使用者登入系統,可以看到請假申請已經提交到了分公司總經理處。如下圖所示:
按同樣方式進行任務處理,再提交,流程就可以回到流程啟動使用者了。我們以流程啟動者登入進來看下,檢視下審批列表,如下圖所示:
同時我們可以檢視流程執行情況,如下圖所示:
至此,整個請假申請業務流程完成,當前在流程流轉的過程中還有很多操作,比如:任務的回退、授權、指派、召回等都可以輕易實現。