public async Task <IActionResult> PutMediosDePago(int id, MediosDePago mediosDePago) { if (id != mediosDePago.ID) { return(BadRequest()); } _context.Entry(mediosDePago).State = EntityState.Modified; try { await _context.SaveChangesAsync(); } catch (DbUpdateConcurrencyException) { if (!MediosDePagoExists(id)) { return(NotFound()); } else { throw; } } return(NoContent()); }
public async Task <ActionResult <MediosDePago> > PostMediosDePago(MediosDePago mediosDePago) { _context.MediosDePago.Add(mediosDePago); await _context.SaveChangesAsync(); return(CreatedAtAction("GetMediosDePago", new { id = mediosDePago.ID }, mediosDePago)); }
public async Task <IActionResult> PostMediosDePago([FromBody] MediosDePago mediosDePago) { if (!ModelState.IsValid) { return(BadRequest(ModelState)); } _context.MediosDePago.Add(mediosDePago); await _context.SaveChangesAsync(); return(CreatedAtAction("GetMediosDePago", new { id = mediosDePago.ID }, mediosDePago)); }
/// <summary> /// Arma el objeto FacturaGeneral que luego se debe enviar el web service /// </summary> /// <param name="documentoGP"></param> /// <returns></returns> private FacturaGeneral ArmaDocumentoEnviarWS(DocumentoVentaGP documentoGP) { //DocEnviarWS es el objeto del servicio web que se arma a traves del objeto documentoGP DocEnviarWS = new FacturaGeneral(); int i = 0; //FACTURA GENERAL DocEnviarWS.cantidadDecimales = documentoGP.DocVenta.cantidadDecimales.ToString(); DocEnviarWS.consecutivoDocumento = documentoGP.DocVenta.consecutivoDocumento; #region DATOS PRINCIPALES DEL CLIENTE DocEnviarWS.cliente = new Cliente(); DocEnviarWS.cliente.nombreRazonSocial = documentoGP.DocVenta.cliente_nombreRazonSocial; DocEnviarWS.cliente.numeroDocumento = documentoGP.DocVenta.cliente_numeroDocumento; DocEnviarWS.cliente.tipoIdentificacion = documentoGP.DocVenta.cliente_tipoIdentificacion.ToString(); DocEnviarWS.cliente.tipoPersona = documentoGP.DocVenta.cliente_tipoPersona; DocEnviarWS.cliente.notificar = documentoGP.DocVenta.cliente_notificar; //DocEnviarWS.cliente.telefono = documentoGP.DocVenta.cliente_telefono; DocEnviarWS.cliente.email = documentoGP.DocVenta.cliente_email; DocEnviarWS.cliente.numeroIdentificacionDV = documentoGP.DocVenta.cliente_numeroIdentificacionDV; if (!string.IsNullOrEmpty(documentoGP.DocVenta.cliente_nombreComercial)) { DocEnviarWS.cliente.nombreComercial = documentoGP.DocVenta.cliente_nombreComercial; } if (!string.IsNullOrEmpty(documentoGP.DocVenta.cliente_actividadEconomicaCIIU)) { DocEnviarWS.cliente.actividadEconomicaCIIU = documentoGP.DocVenta.cliente_actividadEconomicaCIIU; } #endregion #region DIRECCION DEL CLIENTE DocEnviarWS.cliente.direccionCliente = new Direccion(); Direccion direccion1 = new Direccion(); direccion1.ciudad = documentoGP.DocVenta.cliente_difCiudad; direccion1.codigoDepartamento = documentoGP.DocVenta.cliente_difcodigoDepartamento; //"11"; direccion1.departamento = documentoGP.DocVenta.cliente_difdepartamento; direccion1.direccion = documentoGP.DocVenta.cliente_difdireccion; //"Direccion"; direccion1.lenguaje = documentoGP.DocVenta.cliente_diflenguaje; //"es"; direccion1.municipio = documentoGP.DocVenta.cliente_difmunicipio; // "11001"; direccion1.pais = documentoGP.DocVenta.cliente_difpais; // "CO"; direccion1.zonaPostal = documentoGP.DocVenta.cliente_difzonapostal; //"110211"; DocEnviarWS.cliente.direccionCliente = direccion1; //FIN DIRECCION DEL CLIENTE #endregion #region DOCUMENTO REFERENCIADO int nre = documentoGP._LDocVentaRelacionados.Count(); if (nre != 0) { //if (documentoGP.DocVenta.tipoDocumento == "91" || documentoGP.DocVenta.tipoDocumento == "92") //{ DocEnviarWS.documentosReferenciados = new DocumentoReferenciado[nre * 2]; int cor = 0; int cor2 = 0; foreach (vwCfdiRelacionados relacionados in documentoGP._LDocVentaRelacionados) { DocumentoReferenciado referencia1 = new DocumentoReferenciado(); referencia1.codigoInterno = documentoGP.LDocVentaRelacionados[cor].discrepancyResponse.ToString(); //ver if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[cor].codigoEstatusDocumento)) { referencia1.codigoEstatusDocumento = documentoGP.LDocVentaRelacionados[cor].codigoEstatusDocumento; } if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[cor].cufeDocReferenciado)) { referencia1.cufeDocReferenciado = documentoGP.LDocVentaRelacionados[cor].cufeDocReferenciado; } if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[cor].numeroDocumento)) { referencia1.numeroDocumento = documentoGP.LDocVentaRelacionados[cor].numeroDocumento; } DocEnviarWS.documentosReferenciados[cor2] = referencia1; cor2++; DocumentoReferenciado referencia2 = new DocumentoReferenciado(); referencia2.codigoInterno = documentoGP.LDocVentaRelacionados[cor].billingReference.ToString(); //ver if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[cor].cufeDocReferenciado)) { referencia2.cufeDocReferenciado = documentoGP.LDocVentaRelacionados[cor].cufeDocReferenciado; } if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[cor].fecha.ToString())) { referencia2.fecha = Convert.ToDateTime(documentoGP.LDocVentaRelacionados[cor].fecha).ToString("yyyy-MM-dd"); } if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[cor].tipoCufe)) { referencia2.tipoCUFE = documentoGP.LDocVentaRelacionados[cor].tipoCufe; } if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[cor].numeroDocumento)) { referencia2.numeroDocumento = documentoGP.LDocVentaRelacionados[cor].numeroDocumento; } DocEnviarWS.documentosReferenciados[cor2] = referencia2; cor2++; cor++; } //} //if (documentoGP.DocVenta.tipoDocumento == "03") //{ // DocEnviarWS.documentosReferenciados = new DocumentoReferenciado[1]; // DocumentoReferenciado referencia1 = new DocumentoReferenciado(); // if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[0].codigoInterno.ToString())) // referencia1.codigoInterno = documentoGP.LDocVentaRelacionados[0].codigoInterno.ToString(); // if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[0].numeroDocumento.ToString())) // referencia1.numeroDocumento = documentoGP.LDocVentaRelacionados[0].numeroDocumento.ToString(); // if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[0].fecha.ToString())) // referencia1.fecha = documentoGP.LDocVentaRelacionados[0].fecha.ToString(); // if (!string.IsNullOrEmpty(documentoGP.LDocVentaRelacionados[0].tipoDocumento.ToString())) // referencia1.tipoDocumento = documentoGP.LDocVentaRelacionados[0].tipoDocumento.ToString(); // DocEnviarWS.documentosReferenciados[0] = referencia1; //} } #endregion FIN CLASE REFERENCIA #region DESTINATARIOS int des = documentoGP._clides.Count(); DocEnviarWS.cliente.destinatario = new Destinatario[des]; int p = 0; foreach (vwCfdiClienteDestinatario destinatarios_gp in documentoGP._clides) { var destinatario = new Destinatario(); destinatario.email = new string[] { destinatarios_gp.cliente_email }; destinatario.canalDeEntrega = destinatarios_gp.cliente_canalEntrega; DocEnviarWS.cliente.destinatario[p] = destinatario; p++; } //FIN DE DATOS DE CLIENTES VISTA DESTINATARIOS #endregion #region DETALLES TRIBUTARIOS DEL CLIENTE var imptri = documentoGP._facimpcab.GroupBy(ic => new { ic.codigoTotalImp }) .Select(impuTotales => new { CodigoTotalImp = impuTotales.Key.codigoTotalImp, SumMontoTotal = impuTotales.Sum(s => s.valorTotalImp), }); int ctr = imptri.Count(); DocEnviarWS.cliente.detallesTributarios = new Tributos[ctr]; int q = 0; foreach (var impcab in imptri) { Tributos tributos1 = new Tributos(); tributos1.codigoImpuesto = impcab.CodigoTotalImp; //"01"; DocEnviarWS.cliente.detallesTributarios[q] = tributos1; q++; } //FIN DETALLES TRIBUTOS #endregion #region DIRECCION FISCAL DEL CLIENTE Direccion direccionFiscal = new Direccion(); direccionFiscal.ciudad = documentoGP.DocVenta.cliente_difCiudad; direccionFiscal.codigoDepartamento = documentoGP.DocVenta.cliente_difcodigoDepartamento; //"11"; direccionFiscal.departamento = documentoGP.DocVenta.cliente_difdepartamento; direccionFiscal.direccion = documentoGP.DocVenta.cliente_difdireccion; //"Direccion"; direccionFiscal.lenguaje = documentoGP.DocVenta.cliente_diflenguaje; //"es"; direccionFiscal.municipio = documentoGP.DocVenta.cliente_difmunicipio; // "11001"; direccionFiscal.pais = documentoGP.DocVenta.cliente_difpais; // "CO"; direccionFiscal.zonaPostal = documentoGP.DocVenta.cliente_difzonapostal; //"110211"; DocEnviarWS.cliente.direccionFiscal = direccionFiscal; //FIN DIRECCION FISCAL #endregion #region INFORMACION LEGAL DEL CLIENTE DocEnviarWS.cliente.informacionLegalCliente = new InformacionLegal(); InformacionLegal informacionlegal1 = new InformacionLegal(); informacionlegal1.nombreRegistroRUT = documentoGP.DocVenta.cliente_nombreRegistroRUT; informacionlegal1.numeroIdentificacion = documentoGP.DocVenta.cliente_numeroIdentificacion; informacionlegal1.numeroIdentificacionDV = documentoGP.DocVenta.cliente_numeroIdentificacionDV; informacionlegal1.tipoIdentificacion = documentoGP.DocVenta.cliente_tipoIdentificacion.ToString(); DocEnviarWS.cliente.informacionLegalCliente = informacionlegal1; //FIN INFORMACION LEGAL DEL CLIENTE #endregion #region OBLIGACIONES //VIENE DE LA VISTA vwCfdiClienteObligacioS int cob = documentoGP._cliobl.Count(); DocEnviarWS.cliente.responsabilidadesRut = new Obligaciones[cob]; int obl = 0; foreach (vwCfdiClienteObligaciones obligaciones_gp in documentoGP._cliobl) { Obligaciones obligaciones1 = new Obligaciones(); obligaciones1.obligaciones = obligaciones_gp.cliente_obligaciones; obligaciones1.regimen = obligaciones_gp.cliente_regimen; DocEnviarWS.cliente.responsabilidadesRut[obl] = obligaciones1; obl++; } //FIN OBLIGACIONES DE LA VISTA vwCfdiClienteObligaciones #endregion //SECCION CONCEPTOS O DETALLES DE LA FACTURA DocEnviarWS.detalleDeFactura = new FacturaDetalle[documentoGP.LDocVentaConceptos.Count()]; i = 0; int toi = 0; decimal tsi = 0; decimal descuProrrateadoAcumulado = 0; foreach (vwCfdiConceptos detalleDeFactura_gp in documentoGP.LDocVentaConceptos) { #region FACTURA DETALLE var detalle1 = new FacturaDetalle(); detalle1.codigoProducto = detalleDeFactura_gp.facturadetalle_codigoproducto; detalle1.descripcion = detalleDeFactura_gp.facturadetalle_descripcion; detalle1.estandarCodigo = detalleDeFactura_gp.facturadetalle_estandarcodigo; detalle1.estandarCodigoProducto = detalleDeFactura_gp.facturadetalle_estandarcodigoproducto; detalle1.unidadMedida = detalleDeFactura_gp.facturadetalle_unidadMedida; detalle1.cantidadReal = Math.Round(detalleDeFactura_gp.facturadetalle_cantidadreal, 0).ToString(); detalle1.cantidadRealUnidadMedida = detalleDeFactura_gp.facturadetalle_cantidadrealunidadmedida; detalle1.cantidadUnidades = Math.Round(detalleDeFactura_gp.facturadetalle_cantidadunidades, 0).ToString(); detalle1.secuencia = detalleDeFactura_gp.facturadetalle_secuencia.ToString(); detalle1.precioVentaUnitario = Math.Round(detalleDeFactura_gp.facturadetalle_precioVentaUnitario, 2).ToString(); // "00000000000000.00"); detalle1.precioTotalSinImpuestos = Math.Round(detalleDeFactura_gp.facturadetalle_precioTotalSinImpuestos, 2).ToString(); //("00000000000000.00"); detalle1.precioTotal = Math.Round(Convert.ToDecimal(detalleDeFactura_gp.facturadetalle_precioTotal), 2).ToString(); tsi = tsi + detalleDeFactura_gp.facturadetalle_precioTotalSinImpuestos; //FIN DETALLES BASICOS #endregion var impuestosDelConcepto = documentoGP.facimpdet.Where(x => x.LNITMSEQ == detalleDeFactura_gp.LNITMSEQ); #region IMPUESTOS DETALLES DE FACTURA DETALLES int imp3 = impuestosDelConcepto.Count(); detalle1.impuestosDetalles = new FacturaImpuestos[imp3]; int j = 0; foreach (var regImpuestosDelConcepto in impuestosDelConcepto) { FacturaImpuestos facturaImpuestosDet = new FacturaImpuestos(); facturaImpuestosDet.baseImponibleTOTALImp = Math.Round(Convert.ToDecimal(regImpuestosDelConcepto.baseImponibleTotalImp), 2).ToString(); facturaImpuestosDet.codigoTOTALImp = regImpuestosDelConcepto.codigoTotalImp; facturaImpuestosDet.porcentajeTOTALImp = Math.Abs(Math.Round(Convert.ToDecimal(regImpuestosDelConcepto.porcentajeTotalImpAjustado), 2)).ToString(); facturaImpuestosDet.valorTOTALImp = Math.Round(Convert.ToDecimal(regImpuestosDelConcepto.valorTotalImp), 2).ToString(); if (!string.IsNullOrEmpty(regImpuestosDelConcepto.unidadMedida)) { facturaImpuestosDet.unidadMedida = regImpuestosDelConcepto.unidadMedida; } detalle1.impuestosDetalles[j] = facturaImpuestosDet; j++; } #endregion #region IMPUESTOS TOTALES DE FACTURA DETALLES var impTotalesDelConcepto = impuestosDelConcepto.GroupBy(ic => new { ic.codigoTotalImp }) .Select(impuTotales => new { CodigoTotalImp = impuTotales.Key.codigoTotalImp, SumMontoTotal = impuTotales.Sum(s => s.valorTotalImp), }); int imp4 = impTotalesDelConcepto.Count(); detalle1.impuestosTotales = new ImpuestosTotales[imp4]; j = 0; foreach (var regImpTotalesConcepto in impTotalesDelConcepto) { ImpuestosTotales impuestosTotales1 = new ImpuestosTotales(); impuestosTotales1.codigoTOTALImp = regImpTotalesConcepto.CodigoTotalImp; impuestosTotales1.montoTotal = Math.Round(Convert.ToDecimal(regImpTotalesConcepto.SumMontoTotal), 2).ToString(); detalle1.impuestosTotales[j] = impuestosTotales1; j++; } #endregion FIN IMPUESTOS TOTALES DE FACTURA DETALLE #region DESCUENTOS //Descuento por línea if (detalleDeFactura_gp.cargosdescuentos_monto != 0) { detalle1.cargosDescuentos = new CargosDescuentos[1]; CargosDescuentos cargosdescuentos1 = new CargosDescuentos(); cargosdescuentos1.codigo = documentoGP.DocVenta.cargosdescuentos_codigo.ToString(); cargosdescuentos1.descripcion = documentoGP.DocVenta.cargosdescuentos_descripcion.ToString(); cargosdescuentos1.indicador = documentoGP.DocVenta.cargosdescuentos_indicador.ToString(); cargosdescuentos1.monto = Math.Round(Convert.ToDecimal(detalleDeFactura_gp.cargosdescuentos_monto), 2).ToString(); cargosdescuentos1.montoBase = Math.Round(detalleDeFactura_gp.cargosdescuentos_montobase, 2).ToString(); cargosdescuentos1.porcentaje = Math.Round(Convert.ToDecimal(detalleDeFactura_gp.cargodescuentos_porcentaje), 2).ToString(); cargosdescuentos1.secuencia = detalleDeFactura_gp.cargosdescuentos_secuencia; detalle1.cargosDescuentos[0] = cargosdescuentos1; } //Descuento prorrateado else if (documentoGP.DocVenta.cargosdescuentos_monto != 0) { detalle1.cargosDescuentos = new CargosDescuentos[1]; CargosDescuentos cargosdescuentos1 = new CargosDescuentos(); cargosdescuentos1.codigo = documentoGP.DocVenta.cargosdescuentos_codigo.ToString(); cargosdescuentos1.descripcion = documentoGP.DocVenta.cargosdescuentos_descripcion.ToString(); cargosdescuentos1.indicador = documentoGP.DocVenta.cargosdescuentos_indicador.ToString(); cargosdescuentos1.montoBase = Math.Round(detalleDeFactura_gp.cargosdescuentos_montobase, 2).ToString(); var porcentajeDescuento = Math.Round(documentoGP.DocVenta.cargosdescuentos_monto / documentoGP.DocVenta.cargosdescuentos_montobase, 2); var descuentoProrrateado = Math.Round(Convert.ToDecimal(detalleDeFactura_gp.cargosdescuentos_montobase * porcentajeDescuento), 2); cargosdescuentos1.porcentaje = (100 * porcentajeDescuento).ToString(); cargosdescuentos1.monto = descuentoProrrateado.ToString(); descuProrrateadoAcumulado += descuentoProrrateado; if (i + 1 == documentoGP.LDocVentaConceptos.Count()) { descuentoProrrateado = documentoGP.DocVenta.cargosdescuentos_monto - (descuProrrateadoAcumulado - descuentoProrrateado); cargosdescuentos1.porcentaje = Math.Round(100 * descuentoProrrateado / detalleDeFactura_gp.cargosdescuentos_montobase, 2).ToString(); cargosdescuentos1.monto = Math.Round(descuentoProrrateado, 2).ToString(); } cargosdescuentos1.secuencia = detalleDeFactura_gp.cargosdescuentos_secuencia; detalle1.cargosDescuentos[0] = cargosdescuentos1; detalle1.precioTotalSinImpuestos = Math.Round(detalleDeFactura_gp.facturadetalle_precioTotalSinImpuestos - descuentoProrrateado, 2).ToString(); detalle1.precioTotal = Math.Round(Convert.ToDecimal(detalleDeFactura_gp.facturadetalle_precioTotal - descuentoProrrateado), 2).ToString(); } ////Descuento al primer item //else if (toi==0 && documentoGP.DocVenta.cargosdescuentos_monto != 0) // { // detalle1.cargosDescuentos = new CargosDescuentos[1]; // CargosDescuentos cargosdescuentos1 = new CargosDescuentos(); // cargosdescuentos1.codigo = documentoGP.DocVenta.cargosdescuentos_codigo.ToString(); // cargosdescuentos1.descripcion = documentoGP.DocVenta.cargosdescuentos_descripcion.ToString(); // cargosdescuentos1.indicador = documentoGP.DocVenta.cargosdescuentos_indicador.ToString(); // cargosdescuentos1.monto = Math.Round(documentoGP.DocVenta.cargosdescuentos_monto, 2).ToString(); // cargosdescuentos1.montoBase = Math.Round(detalleDeFactura_gp.cargosdescuentos_montobase, 2).ToString(); // cargosdescuentos1.porcentaje = Math.Round(documentoGP.DocVenta.cargosdescuentos_monto / detalleDeFactura_gp.cargosdescuentos_montobase, 2).ToString(); // cargosdescuentos1.secuencia = documentoGP.DocVenta.cargosdescuentos_secuencia.ToString(); // detalle1.cargosDescuentos[0] = cargosdescuentos1; // detalle1.precioTotalSinImpuestos = Math.Round(detalleDeFactura_gp.facturadetalle_precioTotalSinImpuestos - documentoGP.DocVenta.cargosdescuentos_monto, 2).ToString(); // detalle1.precioTotal = Math.Round(Convert.ToDecimal(detalleDeFactura_gp.facturadetalle_precioTotal - documentoGP.DocVenta.cargosdescuentos_monto), 2).ToString(); // } #endregion DocEnviarWS.detalleDeFactura[i] = detalle1; i++; toi = toi + 1; } //FIN SECCION DETALLES DE LA FACTURA #region MEDIOS DE PAGO. MEDIOS DE PAGO VIENE DE LA VISTA vwCfdiMediosDePago int mep = documentoGP._medpag.Count(); if (mep > 0) { DocEnviarWS.mediosDePago = new MediosDePago[mep]; for (int j = 0; j < mep; j++) { MediosDePago mediopago1 = new MediosDePago(); mediopago1.medioPago = documentoGP._medpag[j].mediopago; mediopago1.numeroDeReferencia = documentoGP._medpag[j].numeroreferencia; mediopago1.metodoDePago = documentoGP._medpag[j].metodopago; DocEnviarWS.mediosDePago[j] = mediopago1; } } #endregion MEDIOS DE PAGO DocEnviarWS.fechaEmision = Convert.ToDateTime(documentoGP.DocVenta.fechaEmision).ToString("yyyy-MM-dd 00:00:00"); DocEnviarWS.fechaVencimiento = Convert.ToDateTime(documentoGP.DocVenta.fechaVencimiento).ToString("yyyy-MM-dd"); #region Impuestos a nivel factura //SECCION IMPUESTOS GLOBALES O GENERALES int imp = documentoGP.facimpcab.Count(); DocEnviarWS.impuestosGenerales = new FacturaImpuestos[imp]; for (int j = 0; j < imp; j++) { FacturaImpuestos impuestosg1 = new FacturaImpuestos(); impuestosg1.baseImponibleTOTALImp = Math.Round(Convert.ToDecimal(documentoGP.facimpcab[j].baseImponibleTotalImp), 2).ToString(); impuestosg1.codigoTOTALImp = documentoGP.facimpcab[j].codigoTotalImp.ToString(); if (impuestosg1.codigoTOTALImp.Equals("07")) //rete ica { impuestosg1.porcentajeTOTALImp = Math.Abs(Convert.ToDecimal(documentoGP.facimpcab[j].porcentajeTotalImpAjustado)).ToString(); } else { impuestosg1.porcentajeTOTALImp = Math.Abs(Math.Round(Convert.ToDecimal(documentoGP.facimpcab[j].porcentajeTotalImpAjustado), 2)).ToString(); } impuestosg1.valorTOTALImp = Math.Round(Convert.ToDecimal(documentoGP.facimpcab[j].valorTotalImp), 2).ToString(); impuestosg1.unidadMedida = documentoGP.facimpcab[j].unidadMedida; DocEnviarWS.impuestosGenerales[j] = impuestosg1; } //FIN SECCION IMPUESTOS GENERALES //SECCION IMPUESTOS TOTALES var impuestosTotalesCab = documentoGP._facimpcab.GroupBy(ic => new { ic.codigoTotalImp }) .Select(impuTotales => new { CodigoTotalImp = impuTotales.Key.codigoTotalImp, SumMontoTotal = impuTotales.Sum(s => s.valorTotalImp), }); int imp2 = documentoGP._facimpcab.Count(); DocEnviarWS.impuestosTotales = new ImpuestosTotales[imp2]; int m = 0; foreach (var regImpuTotalesCab in impuestosTotalesCab) { ImpuestosTotales impuestototales1 = new ImpuestosTotales(); impuestototales1.codigoTOTALImp = regImpuTotalesCab.CodigoTotalImp; impuestototales1.montoTotal = Math.Round(Convert.ToDecimal(regImpuTotalesCab.SumMontoTotal), 2).ToString();// es una sumatoria de valorTotalImp DocEnviarWS.impuestosTotales[m] = impuestototales1; m++; } //FIN SECCION IMPUESTOS TOTALES #endregion DocEnviarWS.moneda = documentoGP.DocVenta.moneda.ToString(); DocEnviarWS.rangoNumeracion = documentoGP.DocVenta.rangonumeracion; DocEnviarWS.redondeoAplicado = documentoGP.DocVenta.redondeoaplicado.ToString(); //TASA DE CAMBIO //tasaDeCambio = new TasaDeCambio(); //DocEnviarWS.tasaDeCambio = new TasaDeCambio(); //TasaDeCambio tasadecambio1 = new TasaDeCambio(); //tasadecambio1.baseMonedaDestino = documentoGP.DocVenta.tc_baseMonedaDestino.ToString(); ; //tasadecambio1.fechaDeTasaDeCambio = documentoGP.DocVenta.tc_fechaDeTasaDeCambio; //tasadecambio1.monedaOrigen = documentoGP.DocVenta.tc_monedaOrigen; //tasadecambio1.monedaDestino = documentoGP.DocVenta.tc_monedaDestino; //tasadecambio1.tasaDeCambio = documentoGP.DocVenta.tasaDeCambio.ToString(); //DocEnviarWS.tasaDeCambio = tasadecambio1; //FIN TASA DE CAMBIO DocEnviarWS.tipoDocumento = documentoGP.DocVenta.tipoDocumento; DocEnviarWS.tipoOperacion = documentoGP.DocVenta.tipoOperacion; DocEnviarWS.totalBaseImponible = Math.Round(Convert.ToDecimal(documentoGP.DocVenta.totalBaseImponible), 2).ToString(); // ("0000000000000000.000000"); DocEnviarWS.totalBrutoConImpuesto = Math.Round(Convert.ToDecimal(documentoGP.DocVenta.totalBrutoconImpuestos), 2).ToString(); DocEnviarWS.totalMonto = Math.Round(Convert.ToDecimal(documentoGP.DocVenta.totalMonto), 2).ToString(); // ("0000000000000000.000000"); DocEnviarWS.totalProductos = toi.ToString(); // ("00000"); DocEnviarWS.totalSinImpuestos = Math.Round(Convert.ToDecimal(documentoGP.DocVenta.totalSinImpuestos), 2).ToString(); // ("0000000000000000.000000"); #region LEYENDAS if (!string.IsNullOrEmpty(documentoGP.LeyendasXml)) { XElement leyendasX = XElement.Parse(documentoGP.LeyendasXml); int numLeyendas = leyendasX.Elements().Count(); if (!string.IsNullOrEmpty(leyendasX.Elements().FirstOrDefault()?.Attribute("S")?.Value) && !string.IsNullOrEmpty(leyendasX.Elements().FirstOrDefault()?.Attribute("T")?.Value) && !string.IsNullOrEmpty(leyendasX.Elements().FirstOrDefault()?.Attribute("V")?.Value) ) { DocEnviarWS.informacionAdicional = new string[numLeyendas]; int idx = 0; foreach (XElement child in leyendasX.Elements()) { DocEnviarWS.informacionAdicional[idx] = child.Attribute("V").Value; idx++; } } } #endregion //FIN SECCION FACTURA FINAL return(DocEnviarWS); }