diff --git a/CCFlow/CCFlow/DataUser/API/Controllers/APIController.cs b/CCFlow/CCFlow/DataUser/API/Controllers/APIController.cs index b87b3e0e..7224ab3a 100644 --- a/CCFlow/CCFlow/DataUser/API/Controllers/APIController.cs +++ b/CCFlow/CCFlow/DataUser/API/Controllers/APIController.cs @@ -1779,7 +1779,7 @@ namespace CCFlow.DataUser.API.Controllers if (BP.Difference.SystemConfig.CCBPMRunModel == CCBPMRunModel.SAAS) wfSql = " AND a.OrgNo='" + WebUser.OrgNo + "'"; - ps.SQL = "SELECT count(b.WorkID) as Num FROM WF_Generworkflow a JOIN WF_GenerWorkerList b ON a.WorkID=b.WorkID WHERE b.FK_Emp=" + dbstr + "FK_Emp AND b.IsPass=0 AND a.WFState <> 0 " + wfSql; + ps.SQL = "SELECT count(b.WorkID) as Num FROM WF_Generworkflow a JOIN WF_GenerWorkerList b ON a.WorkID=b.WorkID WHERE b.FK_Emp=" + dbstr + "FK_Emp AND b.IsPass=0 AND a.WFState > 1 " + wfSql; ps.Add("FK_Emp", UserNo); int nums = DBAccess.RunSQLReturnValInt(ps); return Return_Info(200, "查询成功", "EmpWorksNums:" + nums); diff --git a/CCFlow/Components/BP.Demo/DoEvnFlow.cs b/CCFlow/Components/BP.Demo/DoEvnFlow.cs index 5f38dee8..7f457f9f 100644 --- a/CCFlow/Components/BP.Demo/DoEvnFlow.cs +++ b/CCFlow/Components/BP.Demo/DoEvnFlow.cs @@ -13,15 +13,22 @@ namespace BP.Demo public class DoEvnFlow : BP.WF.FlowEventBase { public override string FlowMark { - get {return "021,002"; } + get {return "021,002,060"; } } public override string FlowOverAfter() { try { GenerWorkFlow gwf = new GenerWorkFlow(this.WorkID); - string pTable1 = BP.DA.DBAccess.RunSQLReturnString("SELECT PTable FROM WF_FLOW WHERE No = " + gwf.FlowNo);//当前触发流程存储表 + string pTable1 = BP.DA.DBAccess.RunSQLReturnString("SELECT PTable FROM WF_FLOW WHERE No = " + gwf.FlowNo);//当前触发流程存储表 DataTable BFParas = BP.DA.DBAccess.RunSQLReturnTable("SELECT LCBH,BFOID,FLOWENDERRDT FROM " + pTable1 + " WHERE OID='" + this.WorkID + "'");//要同步表的数据 + if (BFParas.Rows[0][0].ToString() == "") { + return ""; + } + if (BFParas.Rows[0][1].ToString() == "") + { + return ""; + } string pTable2 = BP.DA.DBAccess.RunSQLReturnString("SELECT PTable FROM WF_FLOW WHERE No = " + BFParas.Rows[0][0]); if (gwf.FlowNo == "021") { diff --git a/CCFlow/Components/BP.WF/HttpHandler/WF_MyView.cs b/CCFlow/Components/BP.WF/HttpHandler/WF_MyView.cs index e0cc9cdb..8570a7b8 100644 --- a/CCFlow/Components/BP.WF/HttpHandler/WF_MyView.cs +++ b/CCFlow/Components/BP.WF/HttpHandler/WF_MyView.cs @@ -275,9 +275,15 @@ namespace BP.WF.HttpHandler //BKGY 撤销发送 sql = "SELECT WorkID,FK_Emp,FK_Node,IsPass From WF_GenerWorkerlist WHERE WorkID=" + this.WorkID +" And FK_Node='"+ gwf.NodeID+"'"; DataTable dtt = DBAccess.RunSQLReturnTable(sql); - - - if(nd.HisCancelRole == BP.WF.CancelRole.OnlyNextStep && dtt.Rows[0][3].ToString().Equals("0")) + bool isCanShowUnSend = true; + foreach (DataRow item in dtt.Rows) { + if (item["IsPass"].ToString() == "0") { + isCanShowUnSend = false; + break; + } + } + + if(nd.HisCancelRole == BP.WF.CancelRole.OnlyNextStep && isCanShowUnSend) if (dtt.Rows.Count > 0 || powers.Contains("FlowDataUnSend") == true) { dr = dt.NewRow();