本道工序汇报并转移到下道工序后,下道工序如何设置自动开工

【应用场景】
本道工序汇报并转移到下道工序后,下道工序如何设置自动开工
【实现步骤】
<1>编写表单插件,需要继承工序转移单的审核插件,代码如下。
using System.Collections.Generic;
using System.Linq;
using Kingdee.BOS;
using Kingdee.BOS.App.Data;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.K3.Core.MFG.EnumConst;
using Kingdee.K3.MFG.App;
using Kingdee.K3.Core.MFG.EntityHelper;
namespace Kingdee.K3.MFG.SFC.App.ServicePlugIn.OptTransfer
{
public class Class1:Audit
{
public override void AfterExecuteOperationTransaction(AfterExecuteOperationTransaction e)
{
base.AfterExecuteOperationTransaction(e);
foreach (DynamicObject otBillInfo in e.DataEntitys)
{
long srcOPId = otBillInfo.GetDynamicObjectItemValue<long>(CONST_SFC_OperationTransfer.CONST_FBillHead.ORM_SrcOptPlanId);
if (srcOPId == 0) continue;
//转入工序计划分录未达到开工态(创建、计划、计划确认、下达)时,执行至开工
long inOperId = otBillInfo.GetDynamicObjectItemValue<long>("InOperId");
bool isStart = IsNeedStartByOplan(inOperId);
if (isStart)
{
UpdateOperStatusSqlToThree(this.Context, new List<long>() { inOperId });
}
}
}
/// <summary>
/// 获取工序计划的行状态
/// </summary>
/// <param name="oplanId"></param>
/// <returns></returns>
private bool IsNeedStartByOplan(long oplanId)
{
if (oplanId <= 0)
return false;
string strSql = @"select FOPERSTATUS from T_SFC_OPERPLANNINGDETAIL where fdetailid=@Id";
List<SqlParam> sqlParams = new List<SqlParam>
{
new SqlParam("@Id", KDDbType.Int64, oplanId)
};
long status = AppServiceContext.DBService.ExecuteScalar(this.Context, strSql, 0, sqlParams.ToArray());
List<long> needUpdatestatuss = new List<long>() { 0, 1, 2, 3 };
return needUpd本道工序汇报并转移到下道工序后,下道工序如何设置自动开工
【应用场景】本道工序汇报并转移到下道工序后,下道工序如何设置自动开工【实现步骤】<1>编写表单插件,需要继承工序转移单的审核插件,代码...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



