判断单据或分录是否下推过

一、说明
判断单据是否下推过,主要是通过判断关联节点表中是否存在相应的数据,由于关联节点表存在归档,压缩,所以判断起来比较复杂,故一般通过调用接口来判断
判断整张单据是否下推过
判断分录是否下推过
二、判断是否下推过的代码类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Kingdee.BOS.Core.Metadata;
using Kingdee.BOS.Core.Metadata.EntityElement;
using Kingdee.BOS.Core.DependencyRules;
using Kingdee.BOS.ServiceHelper;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.Util;
using Kingdee.BOS.Core.DynamicForm;
namespace Kingdee.BOS.TestPlugIn.Common
{
public class BillLinkUtil
{
/// <summary>
/// 判断整单是否下推过
/// </summary>
/// <param name="ctx"></param>
/// <param name="bInfo"></param>
/// <param name="dynObj">整单数据包</param>
/// <returns></returns>
public bool BillIsPush(Context ctx, BusinessInfo bInfo, DynamicObject dynObj)
{
var linkEntity = bInfo.GetForm().LinkSet.LinkEntitys[0];
var parentEntity = bInfo.GetEntity(linkEntity.ParentEntityKey);
DynamicObject parentObj = null;//关联主实体数据包
//关联主实体是单据头,绝大部分关联主实体为单据体,少部分为单据头
if (parentEntity is HeadEntity)
{
parentObj = dynObj;
}
else
{
var entryDynObjs = parentEntity.DynamicProperty.GetValue(dynObj) as DynamicObjectCollection;
parentObj = entryDynObjs[0];
}
var isLink = this.IsLinkByInterface(ctx, bInfo, parentEntity, parentObj);
return isLink;
}
/// <summary>
/// 判断每行分录是否下推过
/// </summary>
/// <param name="ctx"></param>
/// <param name="bInfo"></param>
/// <param name="dynObj"></param>
public void EntryIsPush(Context ctx, BusinessInfo bInfo, DynamicObject dynObj)
{
var linkEntity = bInfo.GetForm().LinkSet.LinkEntitys[0];
var parentEntity = bInfo.GetEntity(linkEntity.ParentEntityKey);
var entryDynObjs = parentEntity.DynamicProperty.GetValue(dynObj) as DynamicObjectCollection;
//判断每行分录是否下推而来
foreach (var entryObj in entryDynObjs)
{
var isPush = this.IsLinkByInterf判断单据或分录是否下推过
一、说明判断单据是否下推过,主要是通过判断关联节点表中是否存在相应的数据,由于关联节点表存在归档,压缩,所以判断起来比较复杂,故一...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



