单据内实现套打所选分录
【应用场景】
目前仅列表支持套打所选分录,本帖指导通过二开表单插件实现单据或基础资料内套打所选分录
【注意事项】
该实现方案涉及到二开表单插件
【实现步骤】
<1>编写表单插件,代码如下。
public override void OnPrepareNotePrintQueryParam(PrepareNotePrintQueryParamEventArgs e) { base.OnPrepareNotePrintQueryParam(e); NotePrintSelectRows(e); } private void NotePrintSelectRows(PrepareNotePrintQueryParamEventArgs e) { if (e.NotePrintTplId.EqualsIgnoreCase("adfb2ec4-bfd2-4eae-8b21-8c68f05eb620")) { int[] rowIndexs = this.View.GetControl<EntryGrid>("FEntity").GetSelectedRows(); Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity"); List<string> pkIds = new List<string>(); foreach (int rowIndex in rowIndexs) { DynamicObject rowObj = this.Model.GetEntityDataObject(entity, rowIndex); string pkId = rowObj["Id"].ToString(); if (!pkId.IsNullOrEmptyOrWhiteSpace() && pkId != "0") { pkIds.Add(pkId); } } if (pkIds.Count == 0) { e.QueryParameter.FilterClauseWihtKey = e.QueryParameter.FilterClauseWihtKey.JoinFilterString("1<>1"); } else { e.QueryParameter.FilterClauseWihtKey = e.QueryParameter.FilterClauseWihtKey.JoinFilterString( String.Format("FEntryID in ({0})", String.Join(",", pkIds)) );//FEntryID分录内码标识 } } }
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE单据,注册表单插件,保存元数据,开发完毕。
【功能验证】
<1>选中三行分录
<2>套打预览
【金蝶云星空BOS二次开发案例演示】
https://vip.kingdee.com/article/94751030918525696
单据内实现套打所选分录
【应用场景】目前仅列表支持套打所选分录,本帖指导通过二开表单插件实现单据或基础资料内套打所选分录【注意事项】该实现方案涉及到二开表...
点击下载文档
本文2024-09-23 04:09:31发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-163513.html
您需要登录后才可以发表评论, 登录登录 或者 注册
最新文档
热门文章