/// <summary> /// Mapped InvoiceType Model auf ebInterface4p1 /// </summary> /// <param name="source">Invoice Model</param> /// <returns>ebInterface 4p1 InvoiceType</returns> internal static TARGET.InvoiceType MapModelToV4p3(Model.IInvoiceModel source) { TARGET.InvoiceType invoice = new TARGET.InvoiceType(); #region Rechnungskopf invoice.InvoiceSubtype = source.InvoiceSubtype; invoice.InvoiceNumber = source.InvoiceNumber; invoice.InvoiceDate = source.InvoiceDate; invoice.GeneratingSystem = source.GeneratingSystem; invoice.DocumentType = source.DocumentType.ConvertEnum <DocumentTypeType>(); invoice.DocumentTitle = source.DocumentTitle; invoice.InvoiceCurrency = source.InvoiceCurrency.ToString(); //.ConvertEnum<CurrencyType>(); invoice.Language = source.Language.ToString(); // .ConvertEnum<LanguageType>(); invoice.Comment = source.Comment; #endregion #region Cancelled Original Document invoice.CancelledOriginalDocument = null; if (source.CancelledOriginalDocument != null) { invoice.CancelledOriginalDocument = new TARGET.CancelledOriginalDocumentType() { Comment = source.CancelledOriginalDocument.Comment, DocumentType = source.CancelledOriginalDocument.DocumentType.ConvertEnum <TARGET.DocumentTypeType>(), DocumentTypeSpecified = source.CancelledOriginalDocument.DocumentTypeSpecified, InvoiceDate = source.CancelledOriginalDocument.InvoiceDate, InvoiceNumber = source.CancelledOriginalDocument.InvoiceNumber }; } #endregion #region Related Document if (source.RelatedDocument.Any()) { invoice.RelatedDocument = new TARGET.RelatedDocumentType[] { new TARGET.RelatedDocumentType() { Comment = source.RelatedDocument[0].Comment, DocumentType = source.RelatedDocument[0].DocumentType.ConvertEnum <TARGET.DocumentTypeType>(), DocumentTypeSpecified = source.RelatedDocument[0].DocumentTypeSpecified, InvoiceDate = source.RelatedDocument[0].InvoiceDate, InvoiceDateSpecified = source.RelatedDocument[0].InvoiceDateSpecified, InvoiceNumber = source.RelatedDocument[0].InvoiceNumber }, }; } #endregion #region Delivery if (source.Delivery.Item is Model.PeriodType delType) { if ((delType.ToDate != null) && (delType.ToDate != DateTime.MinValue)) { var deliveryType = new PeriodType { FromDate = delType.FromDate, ToDate = delType.ToDate }; invoice.Delivery.Item = deliveryType; } else { invoice.Delivery.Item = delType.FromDate; } } else { invoice.Delivery.Item = source.Delivery.Item; } #endregion #region Biller if (source.Biller != null) { invoice.Biller = new TARGET.BillerType { VATIdentificationNumber = source.Biller.VATIdentificationNumber, InvoiceRecipientsBillerID = source.Biller.InvoiceRecipientsBillerID, Address = GetAddress(source.Biller.Address, source.Biller.Contact), FurtherIdentification = GetFurtherIdentification(source.Biller.FurtherIdentification) }; } #endregion #region InvoiceReceipient if (source.InvoiceRecipient != null) { invoice.InvoiceRecipient = new TARGET.InvoiceRecipientType { BillersInvoiceRecipientID = source.InvoiceRecipient.BillersInvoiceRecipientID, VATIdentificationNumber = source.InvoiceRecipient.VATIdentificationNumber, Address = GetAddress(source.InvoiceRecipient.Address, source.InvoiceRecipient.Contact), OrderReference = new OrderReferenceType() }; invoice.InvoiceRecipient.OrderReference.OrderID = source.InvoiceRecipient.OrderReference.OrderID; if (source.InvoiceRecipient.OrderReference.ReferenceDateSpecified) { invoice.InvoiceRecipient.OrderReference.ReferenceDate = source.InvoiceRecipient.OrderReference.ReferenceDate; invoice.InvoiceRecipient.OrderReference.ReferenceDateSpecified = source.InvoiceRecipient.OrderReference.ReferenceDateSpecified; } invoice.InvoiceRecipient.AccountingArea = source.InvoiceRecipient.AccountingArea; invoice.InvoiceRecipient.SubOrganizationID = source.InvoiceRecipient.SubOrganizationID; invoice.InvoiceRecipient.FurtherIdentification = GetFurtherIdentification(source.InvoiceRecipient.FurtherIdentification); } #endregion #region Details invoice.Details = new DetailsType { HeaderDescription = source.Details.HeaderDescription, FooterDescription = source.Details.FooterDescription }; // inv4P1.Details.ItemList = new List<InvV4p1.ItemListType>(); var detailsItemList = new List <ItemListType>(); // inv4P1.Details.ItemList.Clear(); // InvV4p1.ItemListType item = new InvV4p1.ItemListType(); foreach (Model.ItemListType srcItemList in source.Details.ItemList) { ItemListType itemList = new ItemListType(); var itemListLineItem = new List <ListLineItemType>(); foreach (Model.ListLineItemType srcLineItem in srcItemList.ListLineItem) { ListLineItemType lineItem = new ListLineItemType { PositionNumber = srcLineItem.PositionNumber, Description = srcLineItem.Description.ToArray(), AdditionalInformation = null, ArticleNumber = GetArtikelList(srcLineItem.ArticleNumber), // Menge Quantity = new UnitType() }; lineItem.Quantity.Unit = srcLineItem.Quantity.Unit; lineItem.Quantity.Value = srcLineItem.Quantity.Value; // Einzelpreis lineItem.UnitPrice = new UnitPriceType() { Value = srcLineItem.UnitPrice.Value }; // Auftragsreferenz if (!string.IsNullOrEmpty(srcLineItem.InvoiceRecipientsOrderReference.OrderPositionNumber) || source.InvoiceRecipient.BestellPositionErforderlich) // Orderposition angegeben oder erforderlich { lineItem.InvoiceRecipientsOrderReference.OrderID = source.InvoiceRecipient.OrderReference.OrderID; lineItem.InvoiceRecipientsOrderReference.OrderPositionNumber = srcLineItem.InvoiceRecipientsOrderReference.OrderPositionNumber; } // Rabatte / Zuschläge lineItem.DiscountFlagSpecified = true; lineItem.DiscountFlag = false; lineItem.ReductionAndSurchargeListLineItemDetails = null; if (srcLineItem.ReductionAndSurchargeListLineItemDetails != null) { lineItem.ReductionAndSurchargeListLineItemDetails = GetReductionDetails(srcLineItem.ReductionAndSurchargeListLineItemDetails, out bool discoutFlag); lineItem.DiscountFlag = discoutFlag; lineItem.DiscountFlagSpecified = true; } lineItem.Description = srcLineItem.Description.ToArray(); lineItem.ReCalcLineItemAmount(); // Steuer lineItem.Item = MapVatItemType(srcLineItem.TaxItem); itemListLineItem.Add(lineItem); } itemList.ListLineItem = itemListLineItem.ToArray(); detailsItemList.Add(itemList); } invoice.Details.ItemList = detailsItemList.ToArray(); #endregion #region Global ReductionANdSurcharge invoice.ReductionAndSurchargeDetails = new ReductionAndSurchargeDetailsType { Items = null, ItemsElementName = new ItemsChoiceType1[] { ItemsChoiceType1.Reduction } }; #endregion #region Tax var taxVATList = new List <VATItemType>(); foreach (var vatItem in source.Tax.TaxItem) { VATItemType vatItemNeu = new VATItemType() { Amount = vatItem.TaxAmount.FixedFraction(2), TaxedAmount = vatItem.TaxableAmount.FixedFraction(2), }; vatItemNeu.Item = MapVatItemType(vatItem); taxVATList.Add(vatItemNeu); } invoice.Tax.VAT = taxVATList.ToArray(); #endregion #region Amount invoice.TotalGrossAmount = source.TotalGrossAmount; invoice.PaymentMethod.Comment = source.PaymentMethod.Comment; invoice.PayableAmount = source.PayableAmount; #endregion #region PaymentMethod invoice.PaymentMethod.Comment = source.PaymentMethod.Comment; if (source.PaymentMethod.Item.GetType() == typeof(Model.UniversalBankTransactionType)) { Model.UniversalBankTransactionType txType = source.PaymentMethod.Item as Model.UniversalBankTransactionType; invoice.PaymentMethod = new PaymentMethodType { Item = new UniversalBankTransactionType() }; ((UniversalBankTransactionType)invoice.PaymentMethod.Item).BeneficiaryAccount = new AccountType[] { new AccountType() { BIC = txType.BeneficiaryAccount.First().BIC, BankName = txType.BeneficiaryAccount.First().BankName, IBAN = txType.BeneficiaryAccount.First().IBAN, BankAccountOwner = txType.BeneficiaryAccount.First().BankAccountOwner } }; } #endregion #region PaymentCoditions if (source.PaymentConditions.DueDate > DateTime.MinValue) { invoice.PaymentConditions.DueDate = source.PaymentConditions.DueDate; invoice.PaymentConditions.DueDateSpecified = true; } if (source.PaymentConditions.Discount != null) { // inv4P1.PaymentConditions.Discount.Clear(); var discountList = new List <DiscountType>(); foreach (Model.DiscountType srcDiscount in source.PaymentConditions.Discount) { DiscountType discount = new DiscountType() { Amount = srcDiscount.Amount, AmountSpecified = srcDiscount.AmountSpecified, BaseAmount = srcDiscount.BaseAmount, BaseAmountSpecified = srcDiscount.BaseAmountSpecified, PaymentDate = srcDiscount.PaymentDate, Percentage = srcDiscount.Percentage, PercentageSpecified = srcDiscount.PercentageSpecified }; discountList.Add(discount); } invoice.PaymentConditions.Discount = discountList.ToArray(); } #endregion // Fixe Einträge #region PresentationDetails invoice.PresentationDetails = new PresentationDetailsType() { URL = "http://www.austriapro.at", SuppressZero = true, SuppressZeroSpecified = true }; #endregion return(invoice); }
/// <summary> /// Mapped ebInterface4p3 InvoiceType auf InvoiceType Model /// </summary> /// <param name="source">ebInterface4p3 InvoiceType</param> /// <returns>InvoiceType Model</returns> internal static IInvoiceModel MapV4P3ToVm(SRC.InvoiceType source) { IInvoiceModel invoice = InvoiceFactory.CreateInvoice(); #region Rechnungskopf invoice.InvoiceNumber = source.InvoiceNumber; invoice.InvoiceDate = source.InvoiceDate; invoice.GeneratingSystem = source.GeneratingSystem; invoice.DocumentTitle = source.DocumentTitle; invoice.DocumentType = source.DocumentType.ConvertEnum <DocumentTypeType>(); invoice.InvoiceCurrency = source.InvoiceCurrency.ToEnum(ModelConstants.CurrencyCodeFixed); // source.InvoiceCurrency.ConvertEnum<CurrencyType>(); if (!string.IsNullOrEmpty(source.Language)) { invoice.Language = source.Language.ToEnum(ModelConstants.LanguangeCodeFixed); //source.Language.ConvertEnum<LanguageType>(); // invoice.LanguageSpecified = true; } else { // invoice.LanguageSpecified = false; invoice.Language = ModelConstants.LanguangeCodeFixed; } #endregion #region CancelledOriginalDocument invoice.Comment = source.Comment; if (source.CancelledOriginalDocument == null) { invoice.CancelledOriginalDocument = null; } else { invoice.CancelledOriginalDocument = new CancelledOriginalDocumentType() { Comment = source.CancelledOriginalDocument.Comment, DocumentType = source.CancelledOriginalDocument.DocumentType.ConvertEnum <DocumentTypeType>(), DocumentTypeSpecified = source.CancelledOriginalDocument.DocumentTypeSpecified, InvoiceDate = source.CancelledOriginalDocument.InvoiceDate, InvoiceNumber = source.CancelledOriginalDocument.InvoiceNumber }; } #endregion #region Releated Document if (source.RelatedDocument != null && source.RelatedDocument.Any()) { invoice.RelatedDocument = new List <RelatedDocumentType>(); foreach (SRC.RelatedDocumentType relDoc in source.RelatedDocument) { var newRel = new RelatedDocumentType() { Comment = relDoc.Comment, DocumentTypeSpecified = relDoc.DocumentTypeSpecified, InvoiceDateSpecified = relDoc.InvoiceDateSpecified, InvoiceNumber = relDoc.InvoiceNumber }; if (relDoc.InvoiceDateSpecified) { newRel.InvoiceDate = relDoc.InvoiceDate; } if (relDoc.DocumentTypeSpecified) { newRel.DocumentType = relDoc.DocumentType.ConvertEnum <DocumentTypeType>(); } invoice.RelatedDocument.Add(newRel); } } #endregion #region Delivery if (source.Delivery != null) { if (source.Delivery.Item is SRC.PeriodType) { var deliveryType = new PeriodType { FromDate = ((SRC.PeriodType)source.Delivery.Item).FromDate, ToDate = ((SRC.PeriodType)source.Delivery.Item).ToDate }; invoice.Delivery.Item = deliveryType; } else { // Invoice.Delivery.Item = source.Delivery.Item; var period = new PeriodType(); if (source.Delivery.Item != null) { period.FromDate = (DateTime)source.Delivery.Item; } invoice.Delivery.Item = period; // für das Model immer eine Lieferperiode, damit von/bis leichter abgebildet werden kann } } #endregion #region Biller invoice.Biller.VATIdentificationNumber = source.Biller.VATIdentificationNumber; invoice.Biller.InvoiceRecipientsBillerID = source.Biller.InvoiceRecipientsBillerID; invoice.Biller.Address = GetAddress(source.Biller.Address); invoice.Biller.Contact = GetContact(source.Biller.Address); invoice.Biller.FurtherIdentification = GetFurtherIdentification(source.Biller.FurtherIdentification); #endregion #region InvoiceRecipient invoice.InvoiceRecipient.BillersInvoiceRecipientID = source.InvoiceRecipient.BillersInvoiceRecipientID; invoice.InvoiceRecipient.VATIdentificationNumber = source.InvoiceRecipient.VATIdentificationNumber; invoice.InvoiceRecipient.Address = GetAddress(source.InvoiceRecipient.Address); invoice.InvoiceRecipient.Contact = GetContact(source.InvoiceRecipient.Address); invoice.InvoiceRecipient.OrderReference.OrderID = source.InvoiceRecipient.OrderReference.OrderID; invoice.InvoiceRecipient.OrderReference.ReferenceDateSpecified = source.InvoiceRecipient.OrderReference.ReferenceDateSpecified; invoice.InvoiceRecipient.OrderReference.ReferenceDate = source.InvoiceRecipient.OrderReference.ReferenceDate; invoice.InvoiceRecipient.FurtherIdentification = GetFurtherIdentification(source.InvoiceRecipient.FurtherIdentification); #endregion #region Details invoice.Details.HeaderDescription = source.Details.HeaderDescription; invoice.Details.FooterDescription = source.Details.FooterDescription; invoice.Details.ItemList = new List <ItemListType>(); if (source.Details.ItemList != null) { foreach (SRC.ItemListType srcItemList in source.Details.ItemList) { ItemListType item = new ItemListType { ListLineItem = new List <ListLineItemType>() }; foreach (SRC.ListLineItemType srcLineItem in srcItemList.ListLineItem) { ListLineItemType lineItem = new ListLineItemType { AdditionalInformation = null, PositionNumber = srcLineItem.PositionNumber, Description = new List <string>() }; if (srcLineItem.Description != null) { lineItem.Description = srcLineItem.Description.ToList(); } lineItem.ArticleNumber = GetArtikelList(srcLineItem.ArticleNumber); // Menge lineItem.Quantity = new UnitType { Unit = srcLineItem.Quantity.Unit, Value = srcLineItem.Quantity.Value }; // Einzelpreis lineItem.UnitPrice = new UnitPriceType() { Value = srcLineItem.UnitPrice.Value }; // Auftragsreferenz lineItem.InvoiceRecipientsOrderReference.OrderID = srcLineItem.InvoiceRecipientsOrderReference.OrderID; lineItem.InvoiceRecipientsOrderReference.OrderPositionNumber = srcLineItem.InvoiceRecipientsOrderReference.OrderPositionNumber; // Rabatte / Zuschläge if (srcLineItem.ReductionAndSurchargeListLineItemDetails != null) { lineItem.ReductionAndSurchargeListLineItemDetails = GetReductionDetails(srcLineItem.ReductionAndSurchargeListLineItemDetails); } lineItem.Description = new List <string>(); if (srcLineItem.Description != null) { lineItem.Description = srcLineItem.Description.ToList(); } //lineItem.LineItemAmount = srcLineItem.LineItemAmount; lineItem.ReCalcLineItemAmount(); // Steuer lineItem.TaxItem = MapVatItemType2Vm(srcLineItem.Item, lineItem.LineItemAmount); item.ListLineItem.Add(lineItem); } invoice.Details.ItemList.Add(item); } } if (source.Details.BelowTheLineItem != null) { // if (source.Details.BelowTheLineItem.Length > 0) // { // List<BelowTheLineItemType> belowItems = new List<BelowTheLineItemType>(); // foreach (V4P3.BelowTheLineItemType item in source.Details.BelowTheLineItem) // { // belowItems.Add(new BelowTheLineItemType() // { // Description = item.Description, // LineItemAmount = item.LineItemAmount // }); // } // invoice.Details.BelowTheLineItem.AddRange(belowItems); // } Mapping.MapInvoice.MappingErrors.Add(new MappingError(source.Details.BelowTheLineItem.GetType(), "BelowTheLineItem nicht konvertiert.")); } #endregion #region Tax invoice.CalculateTotals(); #endregion #region Amount invoice.TotalGrossAmount = source.TotalGrossAmount; invoice.PayableAmount = source.PayableAmount; #endregion #region PaymentMethod invoice.PaymentMethod.Comment = source.PaymentMethod.Comment; if (source.PaymentMethod.Item != null && source.PaymentMethod.Item.GetType() == typeof(SRC.UniversalBankTransactionType)) { SRC.UniversalBankTransactionType txType = source.PaymentMethod.Item as SRC.UniversalBankTransactionType; invoice.PaymentMethod = new PaymentMethodType { Item = new UniversalBankTransactionType() }; ((UniversalBankTransactionType)invoice.PaymentMethod.Item).BeneficiaryAccount = new List <AccountType>() { new AccountType() { BIC = txType.BeneficiaryAccount[0].BIC, BankName = txType.BeneficiaryAccount[0].BankName, IBAN = txType.BeneficiaryAccount[0].IBAN, BankAccountOwner = txType.BeneficiaryAccount[0].BankAccountOwner }, }; } #endregion #region PaymentConditions invoice.PaymentConditions.DueDate = source.PaymentConditions.DueDate; if (source.PaymentConditions.Discount != null) { invoice.PaymentConditions.Discount.Clear(); foreach (SRC.DiscountType srcDiscount in source.PaymentConditions.Discount) { DiscountType discount = new DiscountType() { Amount = srcDiscount.Amount, AmountSpecified = srcDiscount.AmountSpecified, BaseAmount = srcDiscount.BaseAmount, BaseAmountSpecified = srcDiscount.BaseAmountSpecified, PaymentDate = srcDiscount.PaymentDate, Percentage = srcDiscount.Percentage, PercentageSpecified = srcDiscount.PercentageSpecified }; invoice.PaymentConditions.Discount.Add(discount); } } #endregion return(invoice); }