using Kingdee.BOS; using Kingdee.BOS.App; using Kingdee.BOS.App.Data; using Kingdee.BOS.Contracts; using Kingdee.BOS.Core.DynamicForm; using Kingdee.BOS.Core.DynamicForm.Operation; using Kingdee.BOS.Core.DynamicForm.PlugIn; using Kingdee.BOS.Core.DynamicForm.PlugIn.Args; using Kingdee.BOS.Core.List; using Kingdee.BOS.Core.List.PlugIn; using Kingdee.BOS.Core.Metadata; using Kingdee.BOS.Core.Metadata.ConvertElement; using Kingdee.BOS.Core.Metadata.ConvertElement.ServiceArgs; using Kingdee.BOS.Log; using Kingdee.BOS.Orm; using Kingdee.BOS.Orm.DataEntity; using Kingdee.BOS.ServiceHelper; using Kingdee.BOS.Util; using Newtonsoft.Json.Linq; using Pilot_KD_Parino.Common; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Linq; namespace Pilot_KD_Parino.Sal_Order { [Description("下推生成销售出库单及联动生成其他单的插件"), HotUpdate] public class PushSaleOutBillPlugIn : AbstractDynamicFormPlugIn // AbstractListPlugIn { long sScrId = 0; string sScrBillNo = ""; public override void AfterBarItemClick(AfterBarItemClickEventArgs e) { base.AfterBarItemClick(e); long sOutId = 0;//珠海分布式调出单单号内码 string sOutBillNo = "";//珠海分布式调出单单号 bool flag = true; string sBillNo = ""; long sEntryId = 0; long slevel = 2; long sId = 0; //this.View.ShowMessage("669977"); if (e.BarItemKey.Equals("tbPushSalOut111", StringComparison.OrdinalIgnoreCase)) { var FEntity = this.View.Model.DataObject; var fid = FEntity.GetPrimaryKeyValue(); //var json = JsonUtil.Serialize(FEntity); //var row = JsonHelper.ToObject(json); //Logger.Error("FEntity",json,new Exception()); var id = FEntity["id"]; var FSALEORGID = FEntity["SaleOrgId"]; sBillNo = FEntity["BillNo"].ToString();//发货通知单号 var detailList = (FEntity["SAL_DELIVERYNOTICEENTRY"]); //sId = row.Id;//发货通知单ID //sEntryId = row.SAL_DELIVERYNOTICEENTRY Convert.ToInt64(row.EntryPrimaryKeyValue);//发货通知单ID //string sSql = "select FID from T_SAL_DELIVERYNOTICEENTRY where FID= " + sId + " and FENTRYID= " + sEntryId + " and abs(FBaseUnitQty) > abs(FBASEJOINOUTQTY) "; //sSql = String.Format(@"/*dialect*/" + sSql); //var dt = DBServiceHelper.ExecuteDynamicObject(this.Context, sSql); if (detailList!=null) { string getSourceSql = "select FID from T_SAL_DELIVERYNOTICE where FBILLNO='" + sBillNo + "'"; IOperationResult result = Invoke("SAL_DELIVERYNOTICE", "PUR_ReceiveBill", getSourceSql, "7cd93c259999489c97798063f2f7bd70"); } //this.View.ShowMessage("就是这个按钮"+ id); //ListSelectedRowCollection rows =new ListSelectedRowCollection(); //List pkIds = new List(); //List pkEntryIds = new List(); //if (rows.Count <= 0) //{ // this.View.ShowMessage("请选择对应的发货通知单!!!"); // return; //} //foreach (var row in rows) //{ // sBillNo = row.BillNo.ToString();//发货通知单号 // sId = Convert.ToInt64(row.PrimaryKeyValue);//发货通知单ID // sEntryId = Convert.ToInt64(row.EntryPrimaryKeyValue);//发货通知单ID // string sSql = "select FID from T_SAL_DELIVERYNOTICEENTRY where FID= " + sId + " and FENTRYID= " + sEntryId + " and abs(FBaseUnitQty) > abs(FBASEJOINOUTQTY) "; // sSql = String.Format(@"/*dialect*/" + sSql); // var dt = DBServiceHelper.ExecuteDynamicObject(this.Context, sSql); // if (dt.Count > 0) // { // string getSourceSql = "select FID from T_SAL_DELIVERYNOTICE where FBILLNO='" + sBillNo + "'"; // IOperationResult result = Invoke("SAL_DELIVERYNOTICE", "SAL_OUTSTOCK", getSourceSql, "ad0779a4685a43a08f08d2e42d7bf3e9"); // } //}//进入下一个循环生成下一个系列的分布式调出单 //if (flag) //{ // this.View.ShowMessage("生成对应系列的分布式调出单完成!!!"); //} } } private IOperationResult Invoke(string source, string target, string getSourceSql, string sargetBillTypeId) { try { IOperationResult result = new OperationResult(); //获取单据转换规则 ConvertRuleElement ruleElement = ServiceHelper.GetService().GetConvertRules(this.Context, source, target).FirstOrDefault(); //如下代码 直接通过查询数据库获取单据转换源单数据 ListSelectedRowCollection rows = new ListSelectedRowCollection(); int i = 0; using (IDataReader reader = DBUtils.ExecuteReader(this.Context, getSourceSql)) { while (reader.Read()) { ListSelectedRow row = new ListSelectedRow(reader["FID"].ToString(), string.Empty, i++, source); rows.Add(row); } } PushArgs pushArgs = new PushArgs(ruleElement, rows.ToArray()); pushArgs.TargetBillTypeId = sargetBillTypeId;//单据类型 //转换生成目标单 ConvertOperationResult convertResult = ServiceHelper.GetService().Push(this.Context, pushArgs); ////合并转换操作结果 //result.MergeResult(convertResult); ////目标单据数据集合 DynamicObject[] destObjs = convertResult.TargetDataEntities.Select(r => r.DataEntity).ToArray(); //根据实际情况,处理目标单据数据 //destObjs[0]["Date"] = Convert.ToDateTime(sDate); DynamicObjectCollection col_FEntityDetail; var sdsas= JsonHelper.ToJson(destObjs); Logger.Error("目标单据数据集合", sdsas, new Exception ()); this.View.ShowMessage("好了好了,就是这个按钮"); //return result; ////if (target == "SAL_OUTSTOCK")//销售出库 ////{ //col_FEntityDetail = destObjs[0]["SAL_OUTSTOCKENTRY"] as DynamicObjectCollection; ////} ////else ////{//销售退货 //// col_FEntityDetail = destObjs[0]["SAL_RETURNSTOCKENTRY"] as DynamicObjectCollection; ////} //#region //long sStockOrgID = 0; //sStockOrgID = Convert.ToInt64(destObjs[0]["StockOrgId_Id"]); //foreach (var item in col_FEntityDetail) //{ // //item["KeeperID_Id"] = item["OwnerID_Id"];//保管者 // string sStockSql = "select FOrgStockId from v_BusinessOrgId where FORGID= " + sStockOrgID + " "; // sStockSql = String.Format(@"/*dialect*/" + sStockSql); // var dt = DBServiceHelper.ExecuteDynamicObject(this.Context, sStockSql); // //if (dt.Count > 0 && Convert.ToInt64(dt[0]["FOrgStockId"]) != 0) // if (dt.Count > 0) // { // //var targetBillMeta = ServiceHelper.GetService().Load(this.Context, target) as FormMetadata; // //BusinessInfo info = targetBillMeta.BusinessInfo; // //BaseDataField stockFld = info.GetField("FStockId") as BaseDataField; // //long stockId = Convert.ToInt64(dt[0]["FOrgStockId"]); // //IViewService viewService = ServiceHelper.GetService(); // //DynamicObject[] stockObjs = viewService.LoadFromCache(this.Context, new object[] { stockId }, stockFld.RefFormDynamicObjectType); // //stockFld.RefIDDynamicProperty.SetValue(item, stockId); // //stockFld.DynamicProperty.SetValue(item, stockObjs[0]); // item["StockID_Id"] = Convert.ToInt64(dt[0]["FOrgStockId"]); // } //} //#endregion ////目标单元数据 FormMetadata destFormMetadata = ServiceHelper.GetService().Load(this.Context, target) as FormMetadata; ////保存目标单据 IOperationResult saveResult = ServiceHelper.GetService().Save(this.Context, destFormMetadata.BusinessInfo, destObjs, OperateOption.Create()); ////合并保存操作结果 //result.MergeResult(saveResult); //根据操作结果构造返回结果 if ((saveResult.ValidationErrors != null && saveResult.ValidationErrors.Count > 0)) //|| (result.OperateResult != null && result.OperateResult.Count > 0)) { var errorInfo = string.Join(";", saveResult.ValidationErrors.Select(x => x.Message)); //this.View.ShowErrMessage("调用下推, 导致自动保存失败 原因:" + errorInfo); //result.IsSuccess = false; //this.View.ShowErrMessage("调用下推, 导致自动保存失败 原因:" + saveResult.ValidationErrors[0].Message.ToString()); throw new KDBusinessException("", "未知原因导致自动保存失败原因:" + errorInfo); } return result; //this.View.ShowMessage("1"); // 取到需要自动提交、审核的单据内码 object[] pkArray = (from p in destObjs select p[0]).ToArray(); //设置提交参数 IOperationResult submitResult = ServiceHelper.GetService().Submit(this.Context, destFormMetadata.BusinessInfo, pkArray, "Submit", OperateOption.Create()); // 判断提交结果,如果失败,则内部会抛出错误,回滚代码 if (submitResult.IsSuccess == false) { throw new KDBusinessException("", "未知原因导致自动提交失败!"); } //设置审核参数 IOperationResult auditResult = ServiceHelper.GetService().Audit(this.Context, destFormMetadata.BusinessInfo, pkArray, OperateOption.Create()); // 判断提交结果,如果失败,则内部会抛出错误,回滚代码 if (auditResult.IsSuccess == false) { throw new KDBusinessException("", "未知原因导致自动审核失败!"); } //显示下推后的单据 //ShowPushResult("k0f9e182dbc5247fcabc9479ddb300fa3", convertResult, destObjs); return result; } catch (Exception ex) { Logger.Error("同步报关信息时", "同步报关信息时 error:" + ex.Message + ex.StackTrace, ex); throw ex; } } } }