實(shí)例演示使用RDIFramework.NET 框架的工作流組件
創(chuàng)新互聯(lián)公司擁有十年成都網(wǎng)站建設(shè)工作經(jīng)驗(yàn),為各大企業(yè)提供成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)服務(wù),對(duì)于網(wǎng)頁(yè)設(shè)計(jì)、PC網(wǎng)站建設(shè)(電腦版網(wǎng)站建設(shè))、重慶App定制開發(fā)、wap網(wǎng)站建設(shè)(手機(jī)版網(wǎng)站建設(shè))、程序開發(fā)、網(wǎng)站優(yōu)化(SEO優(yōu)化)、微網(wǎng)站、域名注冊(cè)等,憑借多年來在互聯(lián)網(wǎng)的打拼,我們?cè)诨ヂ?lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)積累了很多網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)絡(luò)營(yíng)銷經(jīng)驗(yàn),集策劃、開發(fā)、設(shè)計(jì)、營(yíng)銷、管理等網(wǎng)站化運(yùn)作于一體,具備承接各種規(guī)模類型的網(wǎng)站建設(shè)項(xiàng)目的能力。
進(jìn)行業(yè)務(wù)流程的定義—請(qǐng)假申請(qǐng)流程-Web
參考文章:
RDIFramework.NET — 基于.NET的快速信息化系統(tǒng)開發(fā)框架 — 系列目錄
RDIFramework.NET ━ .NET快速信息化系統(tǒng)開發(fā)框架 ━ 工作流程組件介紹
RDIFramework.NET ━ .NET快速信息化系統(tǒng)開發(fā)框架 ━ 工作流程組件Web業(yè)務(wù)平臺(tái)
RDIFramework.NET ━ .NET快速信息化系統(tǒng)開發(fā)框架 ━ 工作流程組件WinForm業(yè)務(wù)平臺(tái)
實(shí)例演示使用RDIFramework.NET 框架的工作流組件進(jìn)行業(yè)務(wù)流程的定義-請(qǐng)假申請(qǐng)流程-WinForm
RDIFramework.NET工作流程組件是以RDIFramework.NET框架為支撐,根據(jù)我們多年的項(xiàng)目經(jīng)驗(yàn)和項(xiàng)目實(shí)踐,結(jié)合國(guó)內(nèi)各大工作流產(chǎn)品的特點(diǎn)研發(fā)的一套流程管理組件。該組件不僅考慮到從零搭建業(yè)務(wù)系統(tǒng),也考慮到與現(xiàn)有業(yè)務(wù)系統(tǒng)的整合。從零搭建系統(tǒng)我們可以使用RDIFramework.NET框架以基礎(chǔ),來快速搭建業(yè)務(wù)系統(tǒng)。與現(xiàn)有系統(tǒng)的整合,我們的流程引擎提供了豐富的功能接口,供三方業(yè)務(wù)系統(tǒng)調(diào)用,并提供組件的全部源碼方便用戶進(jìn)行整合。RDIFramework.NET工作流程組件采用SOA架構(gòu)模式,流程引擎支持WCF方式訪問。支持B/S、C/S系統(tǒng),同時(shí)支持SQLServer、ORACLE等主流數(shù)據(jù)庫(kù)。
RDIFramework.NET━工作流組件主要涵蓋工作流的設(shè)計(jì)與定義、流程實(shí)例的發(fā)起與運(yùn)行、業(yè)務(wù)流程的監(jiān)控與管理、工作流組件與業(yè)務(wù)系統(tǒng)的集成與協(xié)作等內(nèi)容。
員工請(qǐng)假流程在企業(yè)各大信息化系統(tǒng)中基本都會(huì)涉及到,本文我將向大家展示使用RDIFramework.NET工作流組件來自定義員工請(qǐng)假流程。目前的請(qǐng)假業(yè)務(wù)流程要求是這樣的:
員工請(qǐng)假首先要提交至請(qǐng)假人所在部門的“部分經(jīng)理”審批,如果請(qǐng)假天數(shù)小于等于3天則“部門經(jīng)理”有權(quán)直接審批,否則需要提交至“分公司總經(jīng)理”審批。
請(qǐng)假申請(qǐng)業(yè)務(wù)流程我們已經(jīng)清晰,現(xiàn)在我們使用RDIFramework.NET框架進(jìn)行請(qǐng)假申請(qǐng)的定義。最終提供的請(qǐng)假流程如下圖所示:
現(xiàn)在請(qǐng)假申請(qǐng)的整個(gè)流程的定義我們算完成了,下面我們就開始開發(fā)請(qǐng)假表單,表單開發(fā)非常簡(jiǎn)單,我們可以按常規(guī)的開發(fā)表單的方式進(jìn)行開發(fā),再加載到框架下即可。開發(fā)表單前我們需要在數(shù)據(jù)庫(kù)中建立請(qǐng)假單這個(gè)數(shù)據(jù)表。同時(shí)表中需要包含以下四個(gè)字段:WorkFlowId(工作流主鍵)、WorkFlowInsId(工作流實(shí)例主鍵)、WorkTaskId(工作任務(wù)主鍵)、WorkTaskInsId(工作任務(wù)實(shí)例主鍵)。如下圖所示:
表定義好了,現(xiàn)在我們就要進(jìn)行業(yè)務(wù)表單的開發(fā)了,業(yè)務(wù)表單是指在流程中使用的表單,表單文件的界面一般分2種類型:編輯界面和查詢界面,編輯界面是指新建和修改信息的界面;查詢界面是指查詢表單數(shù)據(jù)的界面,二者的區(qū)別是前者有輸入?yún)^(qū)后者沒有輸入?yún)^(qū)。二者也可以在同一個(gè)表單中實(shí)現(xiàn),通過設(shè)置表單的狀態(tài)(查看、修改、新建)來控制頁(yè)面的可編輯性。表單的樣式、設(shè)計(jì)可以根據(jù)自己的偏好進(jìn)行設(shè)置,沒有特殊要求。只要與其他模塊協(xié)調(diào)一至即可。
打開VS,開發(fā)請(qǐng)假申請(qǐng)表單(說明一下,開發(fā)的方式有很多種,這兒只是為了方便說明,做得簡(jiǎn)單一些,可以自己擴(kuò)展),如下圖所示:
再編寫表單代碼,在代碼中可以自由實(shí)現(xiàn)表單的業(yè)務(wù)邏輯,非常的靈活。同時(shí)流程的業(yè)務(wù)表單只需要繼承自我們已經(jīng)實(shí)現(xiàn)的基類(BaseUserControl)即可,再重載相應(yīng)的方法。下面給了整個(gè)請(qǐng)假申請(qǐng)的業(yè)務(wù)表單實(shí)現(xiàn)代碼以供參考,如下所示:
using System; using System.Data; namespace RDIFramework.WebApp.BizModules { using RDIFramework.BizLogic; using RDIFramework.Utilities; public partial class UCQingJia : BaseUserControl { protected void Page_Load(object sender, EventArgs e) { base.Page_Load(); if (!IsPostBack) { InitData(); } } /// <summary> /// 表單數(shù)據(jù)展現(xiàn),考慮表單退回重新處理和保存草稿的情況 /// /// </summary> private void InitData() { 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)//判斷是否有數(shù)據(jù),有數(shù)據(jù)讀取數(shù)據(jù)庫(kù)中的值 { lbUserId.Text = dt.Rows[0]["userid"].ToString(); lbUserName.Text = dt.Rows[0]["userName"].ToString(); lbDutyCaption.Text = dt.Rows[0]["dutyCaption"].ToString(); lbArchCaption.Text = dt.Rows[0]["archCaption"].ToString(); tbxStartTime.Value = dt.Rows[0]["beginTime"].ToString(); tbxEndTime.Value = dt.Rows[0]["endTime"].ToString(); tbxDays.Text = dt.Rows[0]["Days"].ToString(); tbxQingjia.Text = dt.Rows[0]["QingJia"].ToString(); dplType.Text = dt.Rows[0]["QingJiaType"].ToString(); } else//如果沒有數(shù)據(jù),初始化默認(rèn)值 { lbUserId.Text = UserId; lbUserName.Text = UserName; lbDutyCaption.Text = DutyCaption; lbArchCaption.Text = ArchCaption; tbxStartTime.Value = DateTime.Now.ToShortDateString(); tbxEndTime.Value = DateTime.Now.ToShortDateString(); } } /// <summary> /// 表單數(shù)據(jù)提交,避免重復(fù)提交 /// </summary> public override void SaveUserControl(bool IsDraft) { base.SaveUserControl(IsDraft); var sqlBuilder = new SQLBuilder(this.WorkFlowDbProvider); string sql = "DELETE TESTQINGJIA WHERE WORKFLOWINSID=@WORKFLOWINSID";//先刪除原有數(shù)據(jù) 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", lbUserId.Text); sqlBuilder.SetValue("userName", lbUserName.Text); sqlBuilder.SetValue("dutyCaption", lbDutyCaption.Text); sqlBuilder.SetValue("archCaption", lbArchCaption.Text); if (this.WorkFlowDbProvider.CurrentDbType == CurrentDbType.Oracle) { sqlBuilder.SetValue("BeginTime", !string.IsNullOrEmpty(tbxStartTime.Value) ? BusinessLogic.GetOracleDateFormat(DateTimeHelper.ToDate(tbxStartTime.Value)) : BusinessLogic.ConvertToDateToString(tbxStartTime.Value)); sqlBuilder.SetValue("EndTime", !string.IsNullOrEmpty(tbxEndTime.Value) ? BusinessLogic.GetOracleDateFormat(DateTimeHelper.ToDate(tbxEndTime.Value)) : BusinessLogic.ConvertToDateToString(tbxEndTime.Value)); } else { sqlBuilder.SetValue("BeginTime", BusinessLogic.ConvertToDateToString(tbxStartTime.Value)); sqlBuilder.SetValue("EndTime", BusinessLogic.ConvertToDateToString(tbxEndTime.Value)); } sqlBuilder.SetValue("Days", tbxDays.Text); sqlBuilder.SetValue("QingJiaType", BusinessLogic.ConvertToString(dplType.SelectedItem.Text)); sqlBuilder.SetValue("QingJia", tbxQingjia.Text); sqlBuilder.EndInsert(); } } }
表單開發(fā)完成后,我們需要在RDIFramework.NET框架中對(duì)表單進(jìn)行綁定,如下圖所示:
具體各項(xiàng)的說明可以參考RDIFramework.NET工作流部分的介紹文檔。
也可以在Web的業(yè)務(wù)平臺(tái)中的“用戶表單管理”模塊進(jìn)行設(shè)置,如下圖所示:
在上圖中,我已經(jīng)定義好了“表假單”子表單,我們點(diǎn)擊“修改子表單”,看下設(shè)置,如下圖所示:
在“修改子表單”界面的“位置:”設(shè)置,就是我們開發(fā)的業(yè)務(wù)表單發(fā)布到IIS下的相對(duì)地址,按這樣設(shè)置后,框架就可以自動(dòng)加載進(jìn)來了。
有時(shí)我們的業(yè)務(wù)可能會(huì)比較復(fù)雜,會(huì)涉及不至一個(gè)業(yè)務(wù)表單,我們的工作流組件充分的考慮到了這種情況。因此我們是以主表單(可包含多個(gè)子表單)來與各任務(wù)節(jié)點(diǎn)進(jìn)行關(guān)聯(lián)的。比如:我們?cè)诎l(fā)起請(qǐng)假申請(qǐng)時(shí),會(huì)需要填寫請(qǐng)假單表單,還會(huì)上傳一些附件(附件表單我們可以做成公用表單),這時(shí)配置如下所示:
表單在框架中定義好后,我們?cè)僭谡?qǐng)假申請(qǐng)各任務(wù)節(jié)點(diǎn)對(duì)表單進(jìn)行綁定,需要說明的是,我們是以主表單以基礎(chǔ)進(jìn)行綁定的,這就代表一個(gè)任務(wù)節(jié)點(diǎn)可以擁有多個(gè)表單,這對(duì)復(fù)雜的業(yè)務(wù)非常有用。下面看下請(qǐng)假流程中部門經(jīng)理對(duì)表單的綁定如下圖所示,在“表單名”后面的按鈕“...”就可以打開選擇我們已經(jīng)定義的主表單,來作為當(dāng)前任務(wù)節(jié)點(diǎn)的表單列表。
五、請(qǐng)假申請(qǐng)演示
請(qǐng)假申請(qǐng)是每個(gè)登錄系統(tǒng)的人都應(yīng)該可以使用的業(yè)務(wù)流程,因此我們把“請(qǐng)假申請(qǐng)”的啟動(dòng)節(jié)點(diǎn)的處理人指定為“所有人”,這就代表只要能登錄系統(tǒng),就可以使用“請(qǐng)假申請(qǐng)”流程。如下圖所示:
打開“日常業(yè)務(wù)”功能模塊,可以看到當(dāng)前用戶可以使用的業(yè)務(wù)流程,如下圖所示:
在“可用業(yè)務(wù)”中選擇“行政部”,右側(cè)列出所選節(jié)點(diǎn)當(dāng)前用戶有權(quán)限啟動(dòng)的所有業(yè)務(wù)流程,我們選擇“員工請(qǐng)假流程”,單擊“開始任務(wù)”,打開啟動(dòng)任務(wù)主界面,如下圖所示。假設(shè)請(qǐng)假5天,則應(yīng)由當(dāng)前用戶所在部門經(jīng)理審批的同時(shí)還需要分公司總經(jīng)理審批。
單擊提交后,流程提交到部門經(jīng)理“wikstone”處,以wikstone用戶登錄,在未認(rèn)領(lǐng)任務(wù)界面,可以看到請(qǐng)假申請(qǐng)已經(jīng)提交給“部門經(jīng)理處了,如下圖所示:
RDIFramework.NET工作流組件約定所有任務(wù)提交后都會(huì)進(jìn)入對(duì)方未認(rèn)領(lǐng)任務(wù)列表,這樣做的好處是:如果當(dāng)前提交后想反悔,只要對(duì)方?jīng)]有認(rèn)領(lǐng),就可以撤回任務(wù)。選擇“認(rèn)領(lǐng)任務(wù)”后,進(jìn)行待辦任務(wù)窗體,如下圖所示:
選擇一條待辦任務(wù)后,我們可以“處理任務(wù)”,放棄對(duì)當(dāng)前任務(wù)的認(rèn)領(lǐng)、查看當(dāng)前任務(wù)的執(zhí)行流程圖,當(dāng)前任務(wù)的“處理記錄”等。我們選擇“處理任務(wù)”按鈕,對(duì)當(dāng)前任務(wù)進(jìn)行處理,如下圖所示:
在“處理任務(wù)”主界面,我們可以做很多的操作,具體可以參考RDIFramework.NET工作流組件的相關(guān)說明,這兒就不一一闡述了。
填寫好審批意見后,單擊“提交”按鈕,即可根據(jù)流程定義(當(dāng)前請(qǐng)假天數(shù)大于3天)提交到“分公司總經(jīng)理”處審批。下面我們以分公司總經(jīng)理“chenp”的用戶登錄系統(tǒng),可以看到請(qǐng)假申請(qǐng)已經(jīng)提交到了分公司總經(jīng)理處。如下圖所示:
按同樣方式進(jìn)行任務(wù)處理,再提交,流程就可以回到流程啟動(dòng)用戶了。我們以流程啟動(dòng)者登錄進(jìn)來看下,查看下審批列表,如下圖所示:
同時(shí)我們可以查看流程執(zhí)行情況,如下圖所示:
同樣,我們可以查看流程的處理記錄,如下圖所示。
在我參與的任務(wù)界面可以查看我所參與的所有任務(wù)的情況,如下圖所示:
至此,整個(gè)請(qǐng)假申請(qǐng)業(yè)務(wù)流程完成,當(dāng)前在流程流轉(zhuǎn)的過程中還有很多操作,比如:任務(wù)的回退、授權(quán)、指派、召回等都可以輕易實(shí)現(xiàn)。
作者: EricHu
出處:http://www.cnblogs.com/huyong/
Email:406590790@qq.com
QQ交流:406590790
QQ群:237326100
框架博客:http://yonghu.blog.51cto.com/ http://www.cnblogs.com/huyong
RDIFramework.NET,基于.NET的快速信息化系統(tǒng)開發(fā)、整合框架,給用戶和開發(fā)者最佳的.Net框架部署方案。
關(guān)于作者:高級(jí)工程師、信息系統(tǒng)項(xiàng)目管理師、DBA。專注于微軟平臺(tái)項(xiàng)目架構(gòu)、管理和企業(yè)解決方案,多年項(xiàng)目開發(fā)與管理經(jīng)驗(yàn),曾多次組織并開發(fā)多個(gè)大型項(xiàng)目,在面向?qū)ο蟆⒚嫦蚍?wù)以及數(shù)據(jù)庫(kù)領(lǐng)域有一定的造詣。現(xiàn)主要從事基于 RDIFramework.NET 框架的技術(shù)開發(fā)、咨詢工作,主要服務(wù)于金融、醫(yī)療衛(wèi)生、鐵路、電信、物流、物聯(lián)網(wǎng)、制造、零售等行業(yè)。
如有問題或建議,請(qǐng)多多賜教!
本文版權(quán)歸作者和CNBLOGS博客共有,歡迎轉(zhuǎn)載,但未經(jīng)作者同意必須保留此段聲明,且在文章頁(yè)面明顯位置給出原文連接,如有問題,可以通過郵箱或QQ 聯(lián)系我,非常感謝。
分享題目:實(shí)例演示使用RDIFramework.NET框架的工作流組件進(jìn)行業(yè)務(wù)流程的定義—請(qǐng)假申請(qǐng)流程-Web
當(dāng)前網(wǎng)址:http://chinadenli.net/article10/gjdjgo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供python、網(wǎng)站制作、App設(shè)計(jì)、定制開發(fā)、網(wǎng)站導(dǎo)航、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)