private void BtnInvoiceSave_Click(object sender, EventArgs e) { if (ProdList.Count == 0) { MessageBox.Show("Документ пуст. Сохранение не возможно!"); return; } if (invType == InvoiceType.Arrival && CmbBxContractors.Text == string.Empty) { MessageBox.Show("Поставщик не заполнен!!!"); return; } if (Helper.FileExistsCheck(invType.ToString() + "_" + TxtBxDocName.Text + ".csv")) { MessageBox.Show("Документ существует. Переименуйте документ"); return; } Helper.WriteLineToFile(Helper.HeaderInvoice, invType.ToString() + "_" + TxtBxDocName.Text + ".csv"); foreach (Product item in ProdList) { item.Contractor = CmbBxContractors.Text; item.Storage = CmbBxStorage.Text; Helper.WriteLineToFile(item.ToString() + ";" + item.Contractor + ";" + item.Storage, invType.ToString() + "_" + TxtBxDocName.Text + ".csv"); } this.Close(); }
public static string ToString(this InvoiceType invoiceType) { switch (invoiceType) { case InvoiceType.SalesOrder: return("Sales Order"); case InvoiceType.Invoice: case InvoiceType.Quote: default: return(invoiceType.ToString()); } }
/// <summary> /// Obtiene un objeto RegistroLRFacturasRecibidas, este objeto se utiliza /// para la serialización xml. /// </summary> /// <param name="updateInnerSII">Si es true, actualiza el objeto SII subyacente /// con el valor calculado.</param> /// <param name="skipErrors">Indica si hay que omitir las excepciones.</param> /// <returns>Nueva instancia del objeto para serialización /// xml RegistroLRFacturasEmitidas.</returns> public RegistroLRFacturasRecibidas ToSII(bool updateInnerSII = false, bool skipErrors = false) { if (InnerSII != null) { return(InnerSII); } RegistroLRFacturasRecibidas siiInvoice = new RegistroLRFacturasRecibidas(); if (IssueDate == null && !skipErrors) { throw new ArgumentNullException("IssueDate is null."); } if (PostingDate == null && !skipErrors) { throw new ArgumentNullException("PostingDate is null."); } if (RegisterDate == null && !skipErrors) { throw new ArgumentNullException("RegisterDate is null."); } if (!string.IsNullOrEmpty(ExternalReference) && !(Settings.Current.IDVersionSii.CompareTo("1.1") < 0)) { siiInvoice.FacturaRecibida.RefExterna = ExternalReference; } if (Settings.Current.IDVersionSii.CompareTo("1.1") < 0) { siiInvoice.PeriodoImpositivo.Ejercicio = (PostingDate ?? new DateTime(1, 1, 1)).ToString("yyyy"); siiInvoice.PeriodoImpositivo.Periodo = (PostingDate ?? new DateTime(1, 1, 1)).ToString("MM"); } else { siiInvoice.PeriodoLiquidacion.Ejercicio = (PostingDate ?? new DateTime(1, 1, 1)).ToString("yyyy"); siiInvoice.PeriodoLiquidacion.Periodo = (PostingDate ?? new DateTime(1, 1, 1)).ToString("MM"); } if (SellerParty == null && !skipErrors) { throw new ArgumentNullException("SellerParty is null."); } if (GrossAmount != 0) { siiInvoice.FacturaRecibida.ImporteTotal = SIIParser.FromDecimal(GrossAmount); } if (!(Settings.Current.IDVersionSii.CompareTo("1.1") < 0)) { if (GrossAmount > UpperLimit) { siiInvoice.FacturaRecibida.Macrodato = "S"; } } siiInvoice.IDFactura.NumSerieFacturaEmisor = InvoiceNumber; siiInvoice.IDFactura.FechaExpedicionFacturaEmisor = SIIParser.FromDate(IssueDate); /* B) Facturas Recibidas * * En un plazo de cuatro días naturales desde la fecha en que se produzca el registro * contable de la factura y, en todo caso, antes del día 16 del mes siguiente al periodo * de liquidación en que se hayan incluido las operaciones correspondientes * (período en que se deduce el IVA soportado). * Se entiende que el registro contable de la factura se produce en la fecha de entrada * en el sistema contable con independencia de la fecha reflejada en el asiento contable. */ siiInvoice.FacturaRecibida.FechaRegContable = SIIParser.FromDate(RegisterDate); if (OperationIssueDate != null) { siiInvoice.FacturaRecibida.FechaOperacion = SIIParser.FromDate(OperationIssueDate); } if (Settings.Current.IDVersionSii.CompareTo("1.1") >= 0 && TaxDate != null) { siiInvoice.FacturaRecibida.ADeducirEnPeriodoPosterior = "S"; siiInvoice.FacturaRecibida.EjercicioDeduccion = TaxDate?.ToString("yyyy"); siiInvoice.FacturaRecibida.PeriodoDeduccion = TaxDate?.ToString("MM");; } siiInvoice.FacturaRecibida.TipoFactura = InvoiceType.ToString(); siiInvoice.FacturaRecibida.ClaveRegimenEspecialOTrascendencia = ((int)ClaveRegimenEspecialOTrascendencia).ToString().PadLeft(2, '0'); siiInvoice.FacturaRecibida.DescripcionOperacion = InvoiceText; if (InvoiceType == InvoiceType.F5) { /* SII_Descripcion_ServicioWeb_v0.7.pdf (pag. 203) * 8.1.2.2.Ejemplo mensaje XML de alta de importación * En los datos identificativos correspondientes al proveedor se consignaran los del importador y titular del libro registro * Deberán consignarse, como número de factura y fecha de expedición, el número de referencia que figura en el propio DUA y la fecha de su * admisión por la Administración Aduanera respectivamente*/ SellerParty = BuyerParty; } siiInvoice.FacturaRecibida.Contraparte = GetContraparte(siiInvoice, skipErrors); // Tratamiento de las facturas rectificativas. if (InvoicesRectified.Count != 0) { siiInvoice.FacturaRecibida.TipoRectificativa = RectifiedType.ToString(); if (RectifiedBase != 0) { // Si consta el datos de importe rectificacion (tipo rectif 's'), lo ponemos ImporteRectificacion importeRectifica = new ImporteRectificacion(); importeRectifica.BaseRectificada = SIIParser.FromDecimal(RectifiedBase); importeRectifica.CuotaRectificada = SIIParser.FromDecimal(RectifiedAmount); importeRectifica.CuotaRecargoRectificado = SIIParser.FromDecimal(RectifiedEquivCharge); siiInvoice.FacturaRecibida.ImporteRectificacion = importeRectifica; } siiInvoice.FacturaRecibida.FacturasRectificadas = new List <IDFactura>(); foreach (var regRect in InvoicesRectified) { IDFactura FactRectificada = new IDFactura(); FactRectificada.NumSerieFacturaEmisor = regRect.RectifiedInvoiceNumber; FactRectificada.FechaExpedicionFacturaEmisor = SIIParser.FromDate(regRect.RectifiedIssueDate); // En este caso pongo a null IDEmisorFactura para que no serialice una etiqueta vacía. FactRectificada.IDEmisorFactura = null; siiInvoice.FacturaRecibida.FacturasRectificadas.Add(FactRectificada); } } else { if (InvoiceType.ToString().StartsWith("R") && !skipErrors) { throw new Exception("RectifiedInvoiceNumber for InvoiceType of kind 'R' must be not null."); } } // Desgloses DesgloseIVA desgloseIVA = GetDesgloseIVA(); if (IsInversionSujetoPasivo) { siiInvoice.FacturaRecibida.DesgloseFactura.InversionSujetoPasivo = desgloseIVA; } else { siiInvoice.FacturaRecibida.DesgloseFactura.DesgloseIVA = desgloseIVA; } decimal cuotaDeducible = 0; foreach (KeyValuePair <decimal, decimal[]> kvp in TaxesOutputs) { cuotaDeducible += kvp.Value[1]; } siiInvoice.FacturaRecibida.CuotaDeducible = SIIParser.FromDecimal(cuotaDeducible); if (updateInnerSII) { InnerSII = siiInvoice; } return(siiInvoice); }
} // !FromString() public static string EnumToString(this InvoiceType i) { return(i.ToString("g")); } // !ToString()