470 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			C#
		
	
	
	
			
		
		
	
	
			470 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			C#
		
	
	
	
| using BLL;
 | |
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Data;
 | |
| using System.Data.SqlClient;
 | |
| using System.Linq;
 | |
| 
 | |
| namespace FineUIPro.Web.Controls
 | |
| {
 | |
|     public partial class FlowOperateControl : System.Web.UI.UserControl
 | |
|     {
 | |
|         #region 定义项
 | |
|         /// <summary>
 | |
|         /// 单据ID
 | |
|         /// </summary>
 | |
|         public string DataId
 | |
|         {
 | |
|             get;
 | |
|             set;
 | |
|         }
 | |
|         /// <summary>
 | |
|         /// 菜单ID
 | |
|         /// </summary>
 | |
|         public string MenuId
 | |
|         {
 | |
|             get;
 | |
|             set;
 | |
|         }
 | |
|         /// <summary>
 | |
|         /// 项目ID
 | |
|         /// </summary>
 | |
|         public string ProjectId
 | |
|         {
 | |
|             get;
 | |
|             set;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// 单位iID
 | |
|         /// </summary>
 | |
|         public string UnitId
 | |
|         {
 | |
|             get;
 | |
|             set;
 | |
|         }
 | |
|         /// <summary>
 | |
|         /// 下一步骤
 | |
|         /// </summary>
 | |
|         public string NextStep
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 if (!string.IsNullOrEmpty(this.rblFlowOperate.SelectedValue))
 | |
|                 {
 | |
|                     return this.rblFlowOperate.SelectedValue;
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     return null;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// 下一步办理人
 | |
|         /// </summary>
 | |
|         public string NextPerson
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return this.drpPerson.SelectedValue;
 | |
|             }
 | |
|         }
 | |
|         #endregion
 | |
| 
 | |
|         #region 定义页面项
 | |
|         /// <summary>
 | |
|         /// 单据ID
 | |
|         /// </summary>
 | |
|         public string getDataId
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return (string)ViewState["getDataId"];
 | |
|             }
 | |
|             set
 | |
|             {
 | |
|                 ViewState["getDataId"] = value;
 | |
|             }
 | |
|         }
 | |
|         public string geProjectId
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return (string)ViewState["geProjectId"];
 | |
|             }
 | |
|             set
 | |
|             {
 | |
|                 ViewState["geProjectId"] = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// 菜单ID
 | |
|         /// </summary>
 | |
|         public string getMenuId
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return (string)ViewState["getMenuId"];
 | |
|             }
 | |
|             set
 | |
|             {
 | |
|                 ViewState["getMenuId"] = value;
 | |
|             }
 | |
|         }
 | |
|         #endregion
 | |
| 
 | |
|         #region 加载页面
 | |
|         /// <summary>
 | |
|         /// 加载页面
 | |
|         /// </summary>
 | |
|         /// <param name="sender"></param>
 | |
|         /// <param name="e"></param>
 | |
|         protected void Page_Load(object sender, EventArgs e)
 | |
|         {
 | |
|             if (!IsPostBack)
 | |
|             {       
 | |
|                 this.getDataId = this.DataId;
 | |
|                 this.getMenuId = this.MenuId;
 | |
|                 this.geProjectId = this.ProjectId;
 | |
|                 BLL.UserService.InitFlowOperateControlUserDropDownList(this.drpPerson, this.ProjectId,this.UnitId, true);
 | |
|                 this.GroupPanel1.TitleToolTip += BLL.MenuFlowOperateService.GetFlowOperateName(this.getMenuId);
 | |
|                 this.txtAuditFlowName.Text = "审核/审批";
 | |
|                 var flowOperate = Funs.DB.Sys_FlowOperate.FirstOrDefault(x => x.DataId == this.getDataId && x.State == BLL.Const.State_2 && x.IsClosed == true);
 | |
|                 if (flowOperate != null)
 | |
|                 {
 | |
|                     this.GroupPanel1.Hidden = true;
 | |
|                     this.GroupPanel2.Collapsed = false;
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     var sysSet4 = BLL.ConstValue.drpConstItemList(BLL.ConstValue.Group_MenuFlowOperate).FirstOrDefault();
 | |
|                     if (sysSet4 != null && sysSet4.ConstValue == "1")
 | |
|                     {
 | |
|                         ///取当前单据审核步骤
 | |
|                         int nextSortIndex = 1;
 | |
|                         var maxFlowOperate = Funs.DB.Sys_FlowOperate.Where(x => x.DataId == this.getDataId && x.IsClosed == false).Max(x => x.SortIndex);
 | |
|                         if (maxFlowOperate != null)
 | |
|                         {
 | |
|                             nextSortIndex = maxFlowOperate.Value;
 | |
|                         }
 | |
|                         else
 | |
|                         {
 | |
|                             this.txtAuditFlowName.Text = "编制单据";
 | |
|                         }
 | |
| 
 | |
|                         var nextMenuFlowOperate = Funs.DB.Sys_MenuFlowOperate.FirstOrDefault(x => x.MenuId == this.getMenuId && x.FlowStep == nextSortIndex);
 | |
|                         if (nextMenuFlowOperate != null)
 | |
|                         {
 | |
|                             this.rblFlowOperate.Enabled = false;
 | |
|                             this.txtAuditFlowName.Text = nextMenuFlowOperate.AuditFlowName;
 | |
|                             this.drpPerson.Items.Clear();
 | |
|                             UserService.InitUserProjectIdRoleIdDropDownList(this.drpPerson, this.ProjectId, nextMenuFlowOperate.RoleId, true);
 | |
|                             if (nextMenuFlowOperate.IsFlowEnd == true)
 | |
|                             {
 | |
|                                 this.rblFlowOperate.SelectedValue = Const.State_2;
 | |
|                                 this.SetFlowOperateEnd();
 | |
|                             }
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|                 
 | |
|                 //if (string.IsNullOrEmpty(this.ProjectId))
 | |
|                 //{
 | |
|                 //    this.IsFileCabinetA.Hidden = true;
 | |
|                 //}
 | |
| 
 | |
|                 this.BindGrid();
 | |
|             }
 | |
|         }
 | |
|         #endregion
 | |
| 
 | |
|         #region 流程列表绑定数据
 | |
|         /// <summary>
 | |
|         /// 流程列表绑定数据
 | |
|         /// </summary>
 | |
|         private void BindGrid()
 | |
|         {
 | |
|             DataTable getDataTable = new DataTable();
 | |
|             if (!string.IsNullOrEmpty(this.getDataId))
 | |
|             {
 | |
|                 string strSql = @"SELECT FlowOperateId,MenuId,DataId,SortIndex,AuditFlowName,OperaterId,Users.UserName AS OperaterName,OperaterTime,Opinion,IsClosed "
 | |
|                     + @" FROM dbo.Sys_FlowOperate LEFT JOIN Sys_User AS Users ON OperaterId = Users.UserId"
 | |
|                     + @" WHERE IsClosed = 1 AND DataId=@DataId ORDER BY SortIndex DESC";
 | |
|                 List<SqlParameter> listStr = new List<SqlParameter>();
 | |
|                 listStr.Add(new SqlParameter("@DataId", this.getDataId));
 | |
|                 SqlParameter[] parameter = listStr.ToArray();
 | |
|                 getDataTable = SQLHelper.GetDataTableRunText(strSql, parameter);
 | |
|             }
 | |
| 
 | |
|             Grid1.DataSource = getDataTable;
 | |
|             Grid1.DataBind();
 | |
|         }
 | |
|         #endregion
 | |
| 
 | |
|         #region 下拉联动事件
 | |
|         /// <summary>
 | |
|         ///  处理方式下拉事件
 | |
|         /// </summary>
 | |
|         /// <param name="sender"></param>
 | |
|         /// <param name="e"></param>
 | |
|         protected void rblFlowOperate_SelectedIndexChanged(object sender, EventArgs e)
 | |
|         {
 | |
|             this.SetFlowOperateEnd();
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// 设置审核完成状态事件
 | |
|         /// </summary>
 | |
|         private void SetFlowOperateEnd()
 | |
|         {
 | |
|             if (this.rblFlowOperate.SelectedValue == BLL.Const.State_2)
 | |
|             {
 | |
|                 this.txtAuditFlowName.Text = "审核完成";
 | |
|                 this.drpPerson.SelectedValue = Const._Null;
 | |
|                 this.drpPerson.Hidden = true;
 | |
|                // this.IsFileCabinetA.Hidden = false;
 | |
|                 //var codeTemplateRule = Funs.DB.Sys_CodeTemplateRule.FirstOrDefault(x => x.MenuId == this.getMenuId && x.IsFileCabinetA == true);
 | |
|                 //if (codeTemplateRule != null)
 | |
|                 //{
 | |
|                 //    this.IsFileCabinetA.Checked = true;
 | |
|                 //}
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 ///取当前单据审核步骤
 | |
|                 int nextSortIndex = 1;
 | |
|                 var maxFlowOperate = Funs.DB.Sys_FlowOperate.Where(x => x.DataId == this.getDataId).Max(x => x.SortIndex);
 | |
|                 if (maxFlowOperate != null)
 | |
|                 {
 | |
|                     nextSortIndex = maxFlowOperate.Value + 1;
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     this.txtAuditFlowName.Text = "编制单据";
 | |
|                 }
 | |
| 
 | |
|                 var nextMenuFlowOperate = Funs.DB.Sys_MenuFlowOperate.FirstOrDefault(x => x.MenuId == this.getMenuId && x.FlowStep == nextSortIndex);
 | |
|                 if (nextMenuFlowOperate != null && nextMenuFlowOperate.IsFlowEnd != true)
 | |
|                 {
 | |
|                     this.txtAuditFlowName.Text = nextMenuFlowOperate.AuditFlowName;
 | |
|                     this.drpPerson.Items.Clear();
 | |
|                     BLL.UserService.InitUserProjectIdRoleIdDropDownList(this.drpPerson, this.geProjectId, nextMenuFlowOperate.RoleId, true);     
 | |
|                     this.drpPerson.Hidden = false;
 | |
| 
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     this.drpPerson.Hidden = true;
 | |
|                 }
 | |
| 
 | |
|                 //this.IsFileCabinetA.Hidden = true;
 | |
|                 //this.IsFileCabinetA.Checked = false;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// 得到角色名称字符串
 | |
|         /// </summary>
 | |
|         /// <param name="bigType"></param>
 | |
|         /// <returns></returns>
 | |
|         protected string ConvertRole(string roleIds)
 | |
|         {
 | |
|             return BLL.RoleService.getRoleNamesRoleIds(roleIds);
 | |
|         }
 | |
|         #endregion
 | |
| 
 | |
|         #region 组面板 折叠展开事件
 | |
|         /// <summary>
 | |
|         /// 组面板 折叠展开事件
 | |
|         /// </summary>
 | |
|         /// <param name="sender"></param>
 | |
|         /// <param name="e"></param>
 | |
|         protected void GroupPanel_Collapse(object sender, EventArgs e)
 | |
|         {
 | |
|             if (this.GroupPanel1.Collapsed)
 | |
|             {
 | |
|                 this.GroupPanel2.Collapsed = false;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// 组面板 折叠展开事件
 | |
|         /// </summary>
 | |
|         /// <param name="sender"></param>
 | |
|         /// <param name="e"></param>
 | |
|         protected void GroupPanel2_Collapse(object sender, EventArgs e)
 | |
|         {
 | |
|             if (this.GroupPanel2.Collapsed)
 | |
|             {
 | |
|                 this.GroupPanel1.Collapsed = false;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// 组面板 折叠展开事件
 | |
|         /// </summary>
 | |
|         /// <param name="sender"></param>
 | |
|         /// <param name="e"></param>
 | |
|         protected void GroupPanel_Expand(object sender, EventArgs e)
 | |
|         {
 | |
|             if (this.GroupPanel1.Expanded)
 | |
|             {
 | |
|                 this.GroupPanel2.Expanded = false;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// 组面板 折叠展开事件
 | |
|         /// </summary>
 | |
|         /// <param name="sender"></param>
 | |
|         /// <param name="e"></param>
 | |
|         protected void GroupPanel2_Expand(object sender, EventArgs e)
 | |
|         {
 | |
|             if (this.GroupPanel2.Expanded)
 | |
|             {
 | |
|                 this.GroupPanel1.Expanded = false;
 | |
|             }
 | |
|         }
 | |
|         #endregion
 | |
| 
 | |
|         #region 保存数据
 | |
|         /// <summary>
 | |
|         /// 保存数据
 | |
|         /// </summary>
 | |
|         /// <param name="menuId">菜单id</param>
 | |
|         /// <param name="dataId">主键id</param>
 | |
|         /// <param name="isClosed">是否关闭这步流程</param>
 | |
|         /// <param name="content">单据内容</param>
 | |
|         /// <param name="url">路径</param>
 | |
|         public void btnSaveData(string projectId, string menuId, string dataId, bool isClosed, string content, string url)
 | |
|         {
 | |
|             Model.Sys_FlowOperate newFlowOperate = new Model.Sys_FlowOperate
 | |
|             {
 | |
|                 MenuId = this.getMenuId,
 | |
|                 DataId = dataId,
 | |
|                 OperaterId = ((Model.Sys_User)Session["CurrUser"]).UserId,
 | |
|                 State = this.rblFlowOperate.SelectedValue,
 | |
|                 IsClosed = isClosed,
 | |
|                 Opinion = this.txtOpinions.Text.Trim(),
 | |
|                 ProjectId = string.IsNullOrEmpty(projectId) ? null : projectId,
 | |
|                 Url = url
 | |
|             };
 | |
|             var user = BLL.UserService.GetUserByUserId(newFlowOperate.OperaterId);
 | |
|             if (user != null)
 | |
|             {
 | |
|                 var roles = BLL.RoleService.GetRoleByRoleId(user.RoleId);
 | |
|                 if (roles != null && !string.IsNullOrEmpty(roles.RoleName))
 | |
|                 {
 | |
|                     newFlowOperate.AuditFlowName = "[" + roles.RoleName + "]";
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     newFlowOperate.AuditFlowName = "[" + user.UserName + "]" ;
 | |
|                 }
 | |
| 
 | |
|                 newFlowOperate.AuditFlowName += this.txtAuditFlowName.Text;
 | |
|             }
 | |
| 
 | |
|             var updateFlowOperate = from x in Funs.DB.Sys_FlowOperate
 | |
|                                     where x.DataId == newFlowOperate.DataId && (x.IsClosed == false || !x.IsClosed.HasValue)
 | |
|                                     select x;
 | |
|             if (updateFlowOperate.Count() > 0)
 | |
|             {
 | |
|                 foreach (var item in updateFlowOperate)
 | |
|                 {
 | |
|                     item.OperaterId = newFlowOperate.OperaterId;
 | |
|                     item.OperaterTime = System.DateTime.Now;
 | |
|                     item.State = newFlowOperate.State;
 | |
|                     item.Opinion = newFlowOperate.Opinion;
 | |
|                     item.AuditFlowName = this.txtAuditFlowName.Text;
 | |
|                     item.IsClosed = newFlowOperate.IsClosed;
 | |
|                     Funs.DB.SubmitChanges();
 | |
|                 }
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 int maxSortIndex = 1;
 | |
|                 var flowSet = Funs.DB.Sys_FlowOperate.Where(x => x.DataId == newFlowOperate.DataId);
 | |
|                 var sortIndex = flowSet.Select(x => x.SortIndex).Max();
 | |
|                 if (sortIndex.HasValue)
 | |
|                 {
 | |
|                     maxSortIndex = sortIndex.Value + 1;
 | |
|                 }
 | |
|                 newFlowOperate.FlowOperateId = SQLHelper.GetNewID(typeof(Model.Sys_FlowOperate));
 | |
|                 newFlowOperate.SortIndex = maxSortIndex;
 | |
|                 newFlowOperate.OperaterTime = System.DateTime.Now;
 | |
|                 newFlowOperate.AuditFlowName = this.txtAuditFlowName.Text;                
 | |
|                 Funs.DB.Sys_FlowOperate.InsertOnSubmit(newFlowOperate);
 | |
|                 Funs.DB.SubmitChanges();
 | |
|             }
 | |
| 
 | |
|             if (newFlowOperate.IsClosed == true)
 | |
|             {
 | |
|                 var updateNoClosedFlowOperate = from x in Funs.DB.Sys_FlowOperate
 | |
|                                         where x.DataId == newFlowOperate.DataId && (x.IsClosed == false || !x.IsClosed.HasValue)
 | |
|                                         select x;
 | |
|                 if (updateNoClosedFlowOperate.Count() > 0)
 | |
|                 {
 | |
|                     foreach (var itemClosed in updateNoClosedFlowOperate)
 | |
|                     {
 | |
|                         itemClosed.IsClosed = true;
 | |
|                         Funs.DB.SubmitChanges();
 | |
|                     }
 | |
|                 }
 | |
| 
 | |
|                 if (newFlowOperate.State != BLL.Const.State_2) ///未审核完成的时 增加下一步办理
 | |
|                 {
 | |
|                     int maxSortIndex = 1;
 | |
|                     var flowSet = Funs.DB.Sys_FlowOperate.Where(x => x.DataId == newFlowOperate.DataId);
 | |
|                     var sortIndex = flowSet.Select(x => x.SortIndex).Max();
 | |
|                     if (sortIndex.HasValue)
 | |
|                     {
 | |
|                         maxSortIndex = sortIndex.Value + 1;
 | |
|                     }
 | |
| 
 | |
|                     Model.Sys_FlowOperate newNextFlowOperate = new Model.Sys_FlowOperate
 | |
|                     {
 | |
|                         FlowOperateId = SQLHelper.GetNewID(typeof(Model.Sys_FlowOperate)),
 | |
|                         MenuId = newFlowOperate.MenuId,
 | |
|                         DataId = newFlowOperate.DataId,
 | |
|                         ProjectId = newFlowOperate.ProjectId,
 | |
|                         Url = newFlowOperate.Url,
 | |
|                         SortIndex = maxSortIndex,
 | |
|                         OperaterTime = System.DateTime.Now
 | |
|                     };
 | |
|                     if (this.drpPerson.SelectedValue != BLL.Const._Null)
 | |
|                     {
 | |
|                         newNextFlowOperate.OperaterId = this.drpPerson.SelectedValue;
 | |
|                     }
 | |
|                     else
 | |
|                     {
 | |
|                         newNextFlowOperate.OperaterId = newFlowOperate.OperaterId;
 | |
|                     }
 | |
|                     var operaterUsers = BLL.UserService.GetUserByUserId(newNextFlowOperate.OperaterId);
 | |
|                     if (operaterUsers != null)
 | |
|                     {
 | |
|                         var operaterRoles = BLL.RoleService.GetRoleByRoleId(operaterUsers.RoleId);
 | |
|                         if (operaterRoles != null && !string.IsNullOrEmpty(operaterRoles.RoleName))
 | |
|                         {
 | |
|                             newNextFlowOperate.AuditFlowName = "[" + operaterRoles.RoleName + "]" ;
 | |
|                         }
 | |
|                         else
 | |
|                         {
 | |
|                             newNextFlowOperate.AuditFlowName = "[" + operaterUsers.UserName + "]" ;
 | |
|                         }
 | |
| 
 | |
|                         newNextFlowOperate.AuditFlowName += this.txtAuditFlowName.Text;
 | |
|                     }
 | |
|                     newNextFlowOperate.IsClosed = false;
 | |
|                     newNextFlowOperate.State = BLL.Const.State_1;
 | |
|                     Funs.DB.Sys_FlowOperate.InsertOnSubmit(newNextFlowOperate);
 | |
|                     Funs.DB.SubmitChanges();
 | |
|                 }                
 | |
|             }
 | |
|         }
 | |
|         #endregion
 | |
|     }
 | |
| } |