using System; using System.Collections.Generic; using BP.DA; using System.Data; using BP.En; using BP.WF.Template; using BP.Web; using BP.Port; using BP.Sys; namespace BP.WF { /// /// 计算未来处理人 /// public class FullSA { /// /// 工作Node. /// public WorkNode HisCurrWorkNode = null; /// /// 自动计算未来处理人(该方法在发送成功后执行.) /// /// 当前的节点 /// /// public FullSA(WorkNode currWorkNode) { //如果当前不需要计算未来处理人. if (currWorkNode.HisFlow.IsFullSA == false && currWorkNode.IsSkip == false) return; //如果到达最后一个节点,就不处理了。 if (currWorkNode.HisNode.IsEndNode) return; //初始化一些变量. this.HisCurrWorkNode = currWorkNode; Node currND = currWorkNode.HisNode; Int64 workid = currWorkNode.HisWork.OID; //查询出来所有的节点. Nodes nds =currWorkNode.HisFlow.HisNodes; // 开始节点需要特殊处理》 /* 如果启用了要计算未来的处理人 */ SelectAccper sa = new SelectAccper(); Node toNode = currWorkNode.JumpToNode; //首先要清除以前的计算,重新计算。 if (toNode != null) DBAccess.RunSQL("Delete From WF_SelectAccper Where WorkID=" + workid + " AND FK_Node !=" + toNode.NodeID); else DBAccess.RunSQL("Delete From WF_SelectAccper Where WorkID=" + workid); //求出已经路过的节点. DataTable dt = DBAccess.RunSQLReturnTable("SELECT FK_Node FROM WF_GenerWorkerList WHERE WorkID=" + BP.Difference.SystemConfig.AppCenterDBVarStr + "WorkID", "WorkID", workid); string passedNodeIDs = ""; foreach (DataRow item in dt.Rows) { passedNodeIDs += item[0].ToString() + ","; } //遍历当前的节点。 foreach (Node item in nds) { if (item.IsStartNode == true) continue; //如果已经包含了,就说明该节点已经经过了,就不处理了。 if (passedNodeIDs.Contains(item.NodeID + ",") == true) continue; //如果按照角色计算(默认的第一个规则.) if (item.HisDeliveryWay == DeliveryWay.ByStation) { // string sql = "SELECT No, Name FROM Port_Emp WHERE No IN (SELECT A.FK_Emp FROM " + BP.WF.Glo.EmpStation + " A, WF_NodeStation B WHERE A.FK_Station=B.FK_Station AND B.FK_Node=" + item.NodeID + ")"; string sql = "SELECT DISTINCT a." + BP.Sys.Base.Glo.UserNo + ", a.Name FROM Port_Emp A, Port_DeptEmpStation B, WF_NodeStation C "; // WHERE No IN (SELECT A.FK_Emp FROM " + BP.WF.Glo.EmpStation + " A, WF_NodeStation B WHERE A.FK_Station=B.FK_Station AND B.FK_Node=" + item.NodeID + ")"; sql += " WHERE A." + BP.Sys.Base.Glo.UserNoWhitOutAS + "=B.FK_Emp AND B.FK_Station=C.FK_Station AND C.FK_Node=" + item.NodeID; dt = DBAccess.RunSQLReturnTable(sql); if (dt.Rows.Count ==0) continue; foreach(DataRow dr in dt.Rows){ string no = dr[0].ToString(); string name = dr[1].ToString(); sa = new SelectAccper(); sa.FK_Emp = no; sa.EmpName = name; sa.FK_Node = item.NodeID; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); } continue; } //按照绑定的部门计算 if (item.HisDeliveryWay == DeliveryWay.ByDept) { string dbStr = BP.Difference.SystemConfig.AppCenterDBVarStr; Paras ps = new Paras(); ps.Add("FK_Node", item.NodeID); ps.Add("WorkID", currWorkNode.HisWork.OID); ps.SQL = "SELECT DISTINCT FK_Emp,IDX FROM WF_SelectAccper WHERE FK_Node=" + dbStr + "FK_Node AND WorkID=" + dbStr + "WorkID AND AccType=0 ORDER BY IDX"; dt = DBAccess.RunSQLReturnTable(ps); continue; } #region 仅按组织计算 if (item.HisDeliveryWay == DeliveryWay.ByTeamOnly) { string sql = "SELECT DISTINCT c." + BP.Sys.Base.Glo.UserNo + ",c.Name FROM Port_TeamEmp A, WF_NodeTeam B, Port_Emp C WHERE A.FK_Emp=C." + BP.Sys.Base.Glo.UserNoWhitOutAS + " AND A.FK_Team=B.FK_Team AND B.FK_Node=" + BP.Difference.SystemConfig.AppCenterDBVarStr + "FK_Node ORDER BY C." + BP.Sys.Base.Glo.UserNoWhitOutAS; Paras ps = new Paras(); ps.Add("FK_Node", item.NodeID); ps.SQL = sql; dt = DBAccess.RunSQLReturnTable(ps); if (dt.Rows.Count == 0) throw new Exception("err@节点绑定的仅按照 用户组 计算,没有找到人员:" + item.Name + " SQL=" + ps.SQLNoPara); foreach (DataRow dr in dt.Rows) { string no = dr[0].ToString(); string name = dr[1].ToString(); sa = new SelectAccper(); sa.FK_Emp = no; sa.EmpName = name; sa.FK_Node = item.NodeID; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); } } #endregion #region 本组织计算 if (item.HisDeliveryWay == DeliveryWay.ByTeamOrgOnly) { string sql = "SELECT DISTINCT c." + BP.Sys.Base.Glo.UserNo + ",c.Name FROM Port_TeamEmp A, WF_NodeTeam B, Port_Emp C WHERE A.FK_Emp=C." + BP.Sys.Base.Glo.UserNoWhitOutAS + " AND A.FK_Team=B.FK_Team AND B.FK_Node=" + BP.Difference.SystemConfig.AppCenterDBVarStr + "FK_Node AND C.OrgNo=" + BP.Difference.SystemConfig.AppCenterDBVarStr + "OrgNo ORDER BY C." + BP.Sys.Base.Glo.UserNoWhitOutAS; Paras ps = new Paras(); ps.Add("FK_Node", item.NodeID); ps.Add("OrgNo", BP.Web.WebUser.OrgNo); ps.SQL = sql; dt = DBAccess.RunSQLReturnTable(ps); if (dt.Rows.Count == 0) throw new Exception("err@节点绑定的仅按照 用户组 ByTeamOrgOnly,没有找到人员:" + item.Name + " SQL=" + ps.SQLNoPara); foreach (DataRow dr in dt.Rows) { string no = dr[0].ToString(); string name = dr[1].ToString(); sa = new SelectAccper(); sa.FK_Emp = no; sa.EmpName = name; sa.FK_Node = item.NodeID; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); } } #endregion #region 本组织计算 if (item.HisDeliveryWay == DeliveryWay.ByTeamDeptOnly) { string sql = "SELECT DISTINCT A.FK_Emp AS No,c.Name FROM Port_TeamEmp A, WF_NodeTeam B, Port_Emp C WHERE A.FK_Emp=C.No AND A.FK_Team=B.FK_Team AND B.FK_Node=" + BP.Difference.SystemConfig.AppCenterDBVarStr + "FK_Node AND C.FK_Dept=" + BP.Difference.SystemConfig.AppCenterDBVarStr + "FK_Dept ORDER BY A.FK_Emp"; Paras ps = new Paras(); ps.Add("FK_Node", item.NodeID); ps.Add("FK_Dept", BP.Web.WebUser.FK_Dept); ps.SQL = sql; dt = DBAccess.RunSQLReturnTable(ps); if (dt.Rows.Count == 0) throw new Exception("err@节点绑定的仅按照 用户组 ByTeamDeptOnly,没有找到人员:" + item.Name + " SQL=" + ps.SQLNoPara); foreach (DataRow dr in dt.Rows) { string no = dr[0].ToString(); string name = dr[1].ToString(); sa = new SelectAccper(); sa.FK_Emp = no; sa.EmpName = name; sa.FK_Node = item.NodeID; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); } } #endregion #region 2019-09-25 byzhoupeng, 仅按角色计算 if (item.HisDeliveryWay == DeliveryWay.ByStationOnly) { string sql = "SELECT DISTINCT c." + BP.Sys.Base.Glo.UserNo + ",c.Name FROM Port_DeptEmpStation A, WF_NodeStation B, Port_Emp C WHERE A.FK_Emp=C." + BP.Sys.Base.Glo.UserNoWhitOutAS + " AND A.FK_Station=B.FK_Station AND B.FK_Node=" + BP.Difference.SystemConfig.AppCenterDBVarStr + "FK_Node ORDER BY C."+ BP.Sys.Base.Glo.UserNoWhitOutAS; Paras ps = new Paras(); ps.Add("FK_Node", item.NodeID); ps.SQL = sql; dt = DBAccess.RunSQLReturnTable(ps); if (dt.Rows.Count == 0) throw new Exception("err@节点绑定的仅按照角色计算,没有找到人员:"+item.Name +" SQL="+ps.SQLNoPara); foreach (DataRow dr in dt.Rows) { string no = dr[0].ToString(); string name = dr[1].ToString(); sa = new SelectAccper(); sa.FK_Emp = no; sa.EmpName = name; sa.FK_Node = item.NodeID; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); } } #endregion //处理与指定节点相同的人员. if (item.HisDeliveryWay == DeliveryWay.BySpecNodeEmp && item.DeliveryParas == currND.NodeID.ToString()) { sa.FK_Emp = WebUser.No; sa.FK_Node = item.NodeID; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.EmpName = WebUser.Name; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); continue; } //处理绑定的节点人员.. if (item.HisDeliveryWay == DeliveryWay.ByBindEmp) { NodeEmps nes = new NodeEmps(); nes.Retrieve(NodeEmpAttr.FK_Node, item.NodeID); foreach (NodeEmp ne in nes) { sa.FK_Emp = ne.FK_Emp; sa.FK_Node = item.NodeID; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.EmpName = ne.FK_EmpT; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); } } //按照节点的 角色与部门的交集计算. #region 按部门与角色的交集计算. if (item.HisDeliveryWay == DeliveryWay.ByDeptAndStation) { string dbStr = BP.Difference.SystemConfig.AppCenterDBVarStr; string sql = string.Empty; //added by liuxc,2015.6.30. //区别集成与BPM模式 sql = "SELECT DISTINCT pdes.FK_Emp AS No" + " FROM Port_DeptEmpStation pdes" + " INNER JOIN WF_NodeDept wnd" + " ON wnd.FK_Dept = pdes.FK_Dept" + " AND wnd.FK_Node = " + item.NodeID + " INNER JOIN WF_NodeStation wns" + " ON wns.FK_Station = pdes.FK_Station" + " AND wnd.FK_Node =" + item.NodeID + " ORDER BY" + " pdes.FK_Emp"; dt = DBAccess.RunSQLReturnTable(sql); foreach (DataRow dr in dt.Rows) { Emp emp = new Emp(dr[0].ToString()); sa.FK_Emp = emp.UserID; sa.FK_Node = item.NodeID; sa.DeptName = emp.FK_DeptText; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.EmpName = emp.Name; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); } } #endregion 按部门与角色的交集计算. } //预制当前节点到达节点的数据。 Nodes toNDs = currND.HisToNodes; foreach (Node item in toNDs) { if (item.HisDeliveryWay == DeliveryWay.ByStation || item.HisDeliveryWay == DeliveryWay.FindSpecDeptEmpsInStationlist) { /*如果按照角色访问*/ #region 最后判断 - 按照角色来执行。 string dbStr = BP.Difference.SystemConfig.AppCenterDBVarStr; string sql = ""; Paras ps = new Paras(); /* 如果执行节点 与 接受节点角色集合不一致 */ /* 没有查询到的情况下, 先按照本部门计算。*/ switch (BP.Difference.SystemConfig.AppCenterDBType) { case DBType.MySQL: case DBType.MSSQL: sql = "select DISTINCT x." + BP.Sys.Base.Glo.UserNo + " from Port_Emp x inner join (select FK_Emp from Port_DeptEmpStation a inner join WF_NodeStation b "; sql += " on a.FK_Station=b.FK_Station where FK_Node=" + dbStr + "FK_Node) as y on x." + BP.Sys.Base.Glo.UserNoWhitOutAS + "=y.FK_Emp inner join Port_DeptEmp z on"; sql += " x." + BP.Sys.Base.Glo.UserNoWhitOutAS + "=z.FK_Emp where z.FK_Dept =" + dbStr + "FK_Dept order by x."+ BP.Sys.Base.Glo.UserNoWhitOutAS; break; default: sql = "SELECT DISTINCT " + BP.Sys.Base.Glo.UserNo + " FROM Port_Emp WHERE " + BP.Sys.Base.Glo.UserNoWhitOutAS + " IN " + "(SELECT FK_Emp FROM Port_DeptEmpStation WHERE FK_Station IN (SELECT FK_Station FROM WF_NodeStation WHERE FK_Node=" + dbStr + "FK_Node) )" + " AND " + BP.Sys.Base.Glo.UserNoWhitOutAS + " IN " + "(SELECT FK_Emp FROM Port_DeptEmp WHERE FK_Dept =" + dbStr + "FK_Dept)"; sql += " ORDER BY "+ BP.Sys.Base.Glo.UserNoWhitOutAS; break; } ps = new Paras(); ps.SQL = sql; ps.Add("FK_Node", item.NodeID); ps.Add("FK_Dept", WebUser.FK_Dept); dt = DBAccess.RunSQLReturnTable(ps); foreach (DataRow dr in dt.Rows) { Emp emp = new Emp(dr[0].ToString()); sa.FK_Emp = emp.UserID; sa.FK_Node = item.NodeID; sa.DeptName = emp.FK_DeptText; sa.WorkID = workid; sa.Info = "无"; sa.AccType = 0; sa.EmpName = emp.Name; sa.ResetPK(); if (sa.IsExits) continue; //计算接受任务时间与应该完成任务时间. InitDT(sa, item); sa.Insert(); } #endregion 按照角色来执行。 } } } /// /// 计算两个时间点. /// /// /// private void InitDT(SelectAccper sa, Node nd) { //计算上一个时间的发送点. if (this.LastTimeDot == null) { Paras ps = new Paras(); ps.SQL = "SELECT SDT FROM WF_GenerWorkerlist WHERE WorkID=" + ps.DBStr + "WorkID AND FK_Node=" + ps.DBStr + "FK_Node"; ps.Add("WorkID", this.HisCurrWorkNode.WorkID); ps.Add("FK_Node", nd.NodeID); DataTable dt = DBAccess.RunSQLReturnTable(ps); foreach (DataRow dr in dt.Rows) { this.LastTimeDot = dr[0].ToString(); break; } } //上一个节点的发送时间点或者 到期的时间点,就是当前节点的接受任务的时间。 sa.PlanADT = this.LastTimeDot; //计算当前节点的应该完成日期。 DateTime dtOfShould = Glo.AddDayHoursSpan(this.LastTimeDot, nd.TimeLimit, nd.TimeLimitHH, nd.TimeLimitMM, nd.TWay); sa.PlanSDT = dtOfShould.ToString(DataType.SysDatatimeFormatCN); //给最后的时间点复制. this.LastTimeDot = sa.PlanSDT; } /// /// 当前节点应该完成的日期. /// private string LastTimeDot = null; } }