二开案例.服务插件.反审核时获取工作流流程状态

【应用场景】
反审核时获取工作流流程状态。
反审核有以下两种执行场景:
<1>流程管理中心,终止且反审核(流程相关)。

<2>流程处理人在待办任务处理界面终止流程时,自动反审核(流程相关)。

<3>已审核单据,执行反审核。

【案例演示】
采购订单,反审核时获取工作流流程状态。
【实现步骤】
<1>编写服务插件,代码如下。
using Kingdee.BOS.App.Data;
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Util;
using System;
using System.ComponentModel;
using System.Linq;
namespace Jac.XkDemo.BOS.App.PlugIn
{
/// <summary>
/// 【服务插件】反审核时获取工作流流程状态
/// </summary>
[Description("【服务插件】反审核时获取工作流流程状态"), HotUpdate]
public class GetStatusOperationServicePlugIn : AbstractOperationServicePlugIn
{
public override void BeforeExecuteOperationTransaction(BeforeExecuteOperationTransaction e)
{
base.BeforeExecuteOperationTransaction(e);
if (this.FormOperation.OperationId != 26)
{
return;
}
#region 方案1
string[] ProcInstIds;
if (this.Option.TryGetVariableValue("ProcInstIds", out ProcInstIds) && ProcInstIds != null && ProcInstIds.Length > 0)
{
// 当前单据的流程实例还在运行中
// TODO
e.Cancel = true;
e.CancelMessage = "流程运行中,禁止反审核!";
return;
}
return;
#endregion
#region 方案2
var ids = e.SelectedRows.Select(o => "'" + o.DataEntity[0] + "'").ToArray();
if (ids.Length == 0)
{
return;
}
// 查询当前单据的流程是否还在运行中
var sql = string.Format(@"SELECT DISTINCT b.FKEYVALUE,a.FPROCINSTID FROM T_WF_PROCINST a
JOIN T_WF_PIBIMAP b ON a.FPROCINSTID=b.FPROCINST二开案例.服务插件.反审核时获取工作流流程状态
【应用场景】 反审核时获取工作流流程状态。反审核有以下两种执行场景:<1>流程管理中心,终止且反审核(流程相关)。<2>流程处理人在待办...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



