public override void SetupData(XmlDocument doc) { try { // In case GetStoreId fails Summa.ErrorLevelFile = FileLogger.LogErrorLevelFile.TransactionXMLFile; Summa.ErrorStrDetail = doc.DocumentElement.Attributes["id"].Name; // build unique filename FULLFILEPATH = GenerateCGFileName(doc); XmlNodeList products = null; XmlNodeList cards = null; products = doc.DocumentElement.SelectNodes("/Transaction/Receipt/Product"); cards = doc.DocumentElement.SelectNodes("/Transaction/Receipt/Member/MagCards/MagCard"); int counter = 0; foreach (XmlNode productNode in products) { foreach (XmlNode cardNode in cards) { csvData.Add(new List <string>()); csvData[counter].Add(SummaTransactionCommon.GetTransactionID(doc)); // txn id csvData[counter].Add(SummaTransactionCommon.GetCustomerId(doc)); // customer id csvData[counter].Add(GetTag(cardNode)); // card tag csvData[counter].Add(GetMemberNumber(doc)); // member number csvData[counter].Add(SummaTransactionProductCommon.GetProductId(productNode)); // product id //csvData[counter].Add(GetProxCard(doc)); // proc card csvData[counter].Add(GetProductName(productNode)); // product name csvData[counter].Add(SummaTransactionCommon.GetDateStamp(doc)); // Date Stamp //csvData[counter].Add(GetProxCard(doc)); // prox card counter++; csvLineData.Add(new StringBuilder()); } } } catch (Exception e) { SummaException se = new SummaException("Problem processing transaction detail", e); se.Data = doc.OuterXml; throw se; } }
/// <summary> /// Deconstruct xml document and populate internal data fields /// </summary> /// <param name="doc"></param> public override void SetupData(XmlDocument doc) { try { // In case GetStoreId fails Summa.ErrorLevelFile = FileLogger.LogErrorLevelFile.TransactionXMLFile; Summa.ErrorStrDetail = doc.DocumentElement.Attributes["id"].Name; FULLFILEPATH += SummaFileName.GetName(SummaFileName.SummaFileType.Transactions, SummaTransactionCommon.GetStoreId(doc)); csvData.Add(new List <string>()); csvLineData.Add(new StringBuilder()); csvData[0].Add(SummaTransactionCommon.GetTransactionID(doc)); csvData[0].Add(SummaTransactionCommon.GetTransactionType(doc)); csvData[0].Add(SummaTransactionCommon.GetTerminalID(doc)); csvData[0].Add(SummaTransactionCommon.GetCustomerId(doc)); //string id = SummaTransactionCommon.GetCustomerId(doc); //CheckCustomerID.Check(id); //csvData[0].Add(id); #region Old Specs //csvData[0].Add(SummaTransactionCommon.GetSalesTotal(doc)); #endregion #region Specs v1.2 csvData[0].Add(GetSalesTotalXTax(doc)); // Sales Total Excluding Tax csvData[0].Add(GetSalesTotalTaxAmount(doc)); // Sales Total Tax Amount csvData[0].Add(GetDiscountXTax(doc)); // Discount Excluding Tax csvData[0].Add(GetDiscountTaxAmount(doc)); // Discount Tax Amount #endregion csvData[0].Add(SummaTransactionCommon.GetDateStamp(doc)); csvData[0].Add(SummaTransactionCommon.GetPromotionId(doc)); csvData[0].Add(SummaTransactionCommon.GetOperatorId(doc)); csvData[0].Add(SummaTransactionCommon.GetExtra1(doc)); csvData[0].Add(SummaTransactionCommon.GetExtra2(doc)); csvData[0].Add(SummaTransactionCommon.GetExtra3(doc)); csvData[0].Add(SummaTransactionCommon.GetStoreId(doc)); } catch (Exception e) { SummaException se = new SummaException("Problem processing transaction", e); se.Data = doc.OuterXml; throw se; } }