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));
        }
Esempio n. 4
0
        /// <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);
        }