/// <summary> /// Setup internal data values for each product. /// </summary> /// <param name="doc"></param> public override void SetupData(XmlDocument doc) { XmlNodeList products = null; try { // In case GetStoreId fails Summa.ErrorLevelFile = FileLogger.LogErrorLevelFile.TransactionXMLFile; Summa.ErrorStrDetail = doc.DocumentElement.Attributes["id"].Name; FULLFILEPATH += SummaFileName.GetName(SummaFileName.SummaFileType.TransactionDetails, SummaTransactionCommon.GetStoreId(doc)); products = doc.DocumentElement.SelectNodes("/Transaction/Receipt/Product"); int counter = 0; foreach (XmlNode productNode in products) { csvData.Add(new List <string>()); #region Specs v1.2 csvData[counter].Add(GetTransactionDetailID(doc, productNode)); #endregion csvData[counter].Add(SummaTransactionCommon.GetTransactionID(doc)); csvData[counter].Add(SummaTransactionProductCommon.GetProductId(productNode)); csvData[counter].Add(GetQty(doc, productNode)); #region Old Specs //csvData[counter].Add(SummaTransactionProductCommon.GetUnitPrice(productNode)); //csvData[counter].Add(SummaTransactionProductCommon.GetDiscount(productNode)); #endregion #region Specs v1.2 // GST = Tax, in this context csvData[counter].Add(GetUnitPriceXGST(productNode)); csvData[counter].Add(GetGSTAmount(productNode)); csvData[counter].Add(SummaTransactionProductCommon.GetDiscountXGST(productNode)); csvData[counter].Add(SummaTransactionProductCommon.GetDiscountGSTAmount(productNode)); #endregion csvData[counter].Add(SummaTransactionProductCommon.GetPromotionId(productNode)); csvData[counter].Add(SummaTransactionProductCommon.GetBarcode(productNode)); csvData[counter].Add(SummaTransactionCommon.GetStoreId(doc)); 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; } }
public override void SetupData(XmlDocument doc) { XmlNodeList methods = null; try { // In case GetStoreId fails Summa.ErrorLevelFile = FileLogger.LogErrorLevelFile.TransactionXMLFile; Summa.ErrorStrDetail = doc.DocumentElement.Attributes["id"].Name; FULLFILEPATH += SummaFileName.GetName(SummaFileName.SummaFileType.TransactionPaymentMethods, SummaTransactionCommon.GetStoreId(doc)); methods = doc.DocumentElement.SelectNodes("/Transaction/Receipt/Payment"); if (methods.Count == 0) { Summa.SingletonLoggerStatic.Log(string.Format(string.Format("No payment methods for txn # {0}", SummaTransactionCommon.GetTransactionID(doc)))); //Summa.LOGGER.Log(LogLevel.Warn, string.Format("No payment methods for txn # {0}", // SummaTransactionCommon.GetTransactionID(doc))); } int counter = 0; foreach (XmlNode paymentNode in methods) { csvData.Add(new List <string>()); csvData[counter].Add(SummaTransactionCommon.GetTransactionPaymentID(paymentNode)); csvData[counter].Add(SummaTransactionCommon.GetTransactionID(doc)); csvData[counter].Add(SummaPaymentMethodsCommon.GetPaymentId(paymentNode)); csvData[counter].Add(SummaPaymentMethodsCommon.GetCardNumber(paymentNode)); csvData[counter].Add(SummaPaymentMethodsCommon.GetSalesValue(paymentNode)); csvData[counter].Add(SummaTransactionCommon.GetStoreId(doc)); counter++; csvLineData.Add(new StringBuilder()); } } catch (Exception e) { SummaException se = new SummaException("Problem processing transaction payment methods", 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) { FULLFILEPATH += SummaFileName.GetName(SummaFileName.SummaFileType.TransactionCheck, SummaTransactionCommon.GetStoreId(doc)); try { csvData.Add(new List <string>()); csvLineData.Add(new StringBuilder()); csvData[0].Add(SummaTransactionCommon.GetTransactionID(doc)); csvData[0].Add(SummaTransactionCommon.GetSalesTotalXTax(doc)); // Sales Total Excluding Tax //XmlNode productNode = doc.DocumentElement.SelectSingleNode("/Transaction/Receipt/Product"); XmlNodeList products = doc.DocumentElement.SelectNodes("/Transaction/Receipt/Product"); decimal summaNetXTax = 0; decimal quantity = 0; decimal unitPrice = 0; foreach (XmlNode productNode in products) { summaNetXTax += Convert.ToDecimal(SummaTransactionProductCommon.GetSummaNetXTax(productNode)); quantity += Convert.ToDecimal(SummaTransactionProductCommon.GetQuantity(productNode)); unitPrice += Convert.ToDecimal(SummaTransactionProductCommon.GetUnitPriceXGST(productNode)); } csvData[0].Add(string.Format("{0:#.00}", Math.Abs(summaNetXTax))); csvData[0].Add(string.Format("{0:#.00}", Math.Abs(quantity))); csvData[0].Add(string.Format("{0:#.00}", Math.Abs(unitPrice))); } catch (Exception e) { SummaException se = new SummaException("Problem processing transaction", e); se.Data = doc.OuterXml; throw se; } }