Beispiel #1
0
        /// <summary>
        /// Método Público encargado de Deshabilitar los Conceptos de las Facturas
        /// </summary>
        /// <param name="id_factura">Id Factura</param>
        /// <param name="id_usuario">Id de Usuario</param>
        /// <returns></returns>
        public static RetornoOperacion DeshabilitaFacturaConceptos(int id_factura, int id_usuario)
        {
            //Declaramos objeto Resultado
            RetornoOperacion resultado = new RetornoOperacion(0);

            //Cargamos Conceptos
            using (DataTable mitConceptos = CargaFacturadoConceptosParaDeshabilitacion(id_factura))
            {
                //Validamos Origen de Datos
                if (Validacion.ValidaOrigenDatos(mitConceptos))
                {
                    //Inicializando Bloque Transaccional
                    using (TransactionScope trans = TSDK.Datos.Transaccion.InicializaBloqueTransaccional(System.Transactions.IsolationLevel.ReadCommitted))
                    {
                        //Recorremos los conceptos
                        foreach (DataRow r in mitConceptos.Rows)
                        {
                            //Validamos Origen de Datos
                            if (resultado.OperacionExitosa)
                            {
                                //Instanciamos Facturado Concepto
                                using (FacturadoConcepto objFacturadoConcepto = new FacturadoConcepto(r.Field <int>("Id")))
                                {
                                    //Deshabilitamos Concepto
                                    resultado = objFacturadoConcepto.DeshabilitaFacturaConcepto(id_usuario);
                                }
                            }
                            else
                            {
                                //Salimos del ciclo
                                break;
                            }
                        }

                        //Si las Operaciones fueron exitosas
                        if (resultado.OperacionExitosa)
                        {
                            //Completando Transacción
                            trans.Complete();
                        }
                    }
                }
            }


            //Devolvemos Resultado
            return(resultado);
        }
Beispiel #2
0
        /// <summary>
        /// Método Público encargado de Editar los Conceptos de las Facturas
        /// </summary>
        /// <param name="id_factura">Id de Factura</param>
        /// <param name="cantidad">Cantidad</param>
        /// <param name="id_unidad">Tipo de Unidad</param>
        /// <param name="identificador">Identificador</param>
        /// <param name="id_concepto_cobro">Concepto del Cobro</param>
        /// <param name="valor_unitario">Valor Unitario</param>
        /// <param name="importe_pesos">Importe en Pesos</param>
        /// <param name="id_impuesto_retenido">Id Impuesto retenido</param>
        /// <param name="tasa_impuesto_retenido">Tasa de Impuesto Retenido</param>
        /// <param name="id_impuesto_trasladado">Id Impuesto Trasladado</param>
        /// <param name="tasa_impuesto_trasladado">Tasa de Impuesto Trasladado</param>
        /// <param name="id_cargo_recurrente">Id de cargo recurrente</param>
        /// <param name="id_usuario">Id de Usuario</param>
        /// <returns></returns>
        public RetornoOperacion EditaFacturaConcepto(int id_factura, decimal cantidad, byte id_unidad, string identificador, int id_concepto_cobro,
                                                     decimal valor_unitario, decimal importe_pesos, byte id_impuesto_retenido, decimal tasa_impuesto_retenido,
                                                     byte id_impuesto_trasladado, decimal tasa_impuesto_trasladado, int id_cargo_recurrente, int id_usuario)
        {
            //Declarando Variable de Retorno
            RetornoOperacion result = new RetornoOperacion();

            //Inicializando Bloques
            using (TransactionScope scope = Transaccion.InicializaBloqueTransaccional(System.Transactions.IsolationLevel.ReadCommitted))
            {
                //Instanciando factura
                using (Facturado fac = new Facturado(this._id_factura))
                {
                    //validando que exista la Factura
                    if (fac.id_factura != 0)
                    {
                        //Validando que la Moneda sea dinstinto de Pesos
                        if (fac.moneda != 1)
                        {
                            //Instanciando Servicio
                            using (Documentacion.Servicio serv = new Documentacion.Servicio(fac.id_servicio))

                                //Instanciando Facturación Otros
                                using (FacturacionOtros fo = FacturacionOtros.ObtieneInstanciaFactura(this._id_factura))

                                    //Instanciando Tipo de Cambio
                                    using (Bancos.TipoCambio tc = new Bancos.TipoCambio(serv.id_compania_emisor == 0 ? fo.id_compania_emisora : serv.id_compania_emisor, (byte)fac.moneda, fac.fecha_tipo_cambio, 0))
                                    {
                                        //Validando que exista el Tipo de Cambio
                                        if (tc.id_tipo_cambio > 0)
                                        {
                                            //Actualizando Registros
                                            result = this.actualizaRegistros(id_factura, cantidad, id_unidad, identificador, id_concepto_cobro, valor_unitario,
                                                                             System.Math.Round((cantidad * valor_unitario), 2, MidpointRounding.ToEven) * tc.valor_tipo_cambio, id_impuesto_retenido,
                                                                             tasa_impuesto_retenido, id_impuesto_trasladado, tasa_impuesto_trasladado, id_cargo_recurrente,
                                                                             id_usuario, this._habilitar);
                                        }
                                        else
                                        {
                                            //Instanciando Error
                                            result = new RetornoOperacion("No existe el Tipo de Cambio");
                                        }
                                    }
                        }
                        else
                        {
                            //Actualizando Registros
                            result = this.actualizaRegistros(id_factura, cantidad, id_unidad, identificador, id_concepto_cobro, valor_unitario,
                                                             System.Math.Round((cantidad * valor_unitario), 2, MidpointRounding.ToEven), id_impuesto_retenido,
                                                             tasa_impuesto_retenido, id_impuesto_trasladado, tasa_impuesto_trasladado, id_cargo_recurrente,
                                                             id_usuario, this._habilitar);
                        }

                        //Validando que se Actualizara
                        if (result.OperacionExitosa)
                        {
                            //Obteniendo Valores Totales
                            using (DataTable dt = FacturadoConcepto.ObtieneValoresTotalesFactura(this._id_factura))
                            {
                                //Validando que la tabla contenga Valores
                                if (TSDK.Datos.Validacion.ValidaOrigenDatos(dt))
                                {
                                    //Recorriendo cada Fila
                                    foreach (DataRow dr in dt.Rows)
                                    {
                                        //Editando Factura
                                        result = fac.EditaFactura(Convert.ToDecimal(dr["TotalFactura"]), Convert.ToDecimal(dr["SubTotalFactura"]),
                                                                  Convert.ToDecimal(dr["TrasladadoFactura"]), Convert.ToDecimal(dr["RetenidoFactura"]), id_usuario);
                                    }
                                }
                            }
                        }
                    }
                    else
                    {
                        //Instanciando Error
                        result = new RetornoOperacion("No existe la factura");
                    }
                }

                //Validando que las Operaciones hayan sido exitosas
                if (result.OperacionExitosa)
                {
                    //Instanciando Factura Concepto
                    result = new RetornoOperacion(this._id_detalle_facturado);

                    //Completando Transaccion
                    scope.Complete();
                }
            }

            //Devolviendo Resultado Obtenido
            return(result);
        }
Beispiel #3
0
        /// <summary>
        /// Método Público encargado de Deshabilitar los Conceptos de las Facturas
        /// </summary>
        /// <param name="id_usuario">Id de Usuario</param>
        /// <returns></returns>
        public RetornoOperacion DeshabilitaFacturaConcepto(int id_usuario)
        {
            //Declarando Objeto de Retorno
            RetornoOperacion result = new RetornoOperacion();

            //Validando si esta ligada a una Factura Global
            if (!validaConceptoFacturaGlobal())
            {
                //Inicializando Bloques
                using (TransactionScope scope = Transaccion.InicializaBloqueTransaccional(System.Transactions.IsolationLevel.ReadCommitted))
                {
                    //Instanciando factura
                    using (Facturado fac = new Facturado(this._id_factura))
                    {
                        //validando que exista la Factura
                        if (fac.habilitar)
                        {
                            //Invocando Método de Actualización
                            result = this.actualizaRegistros(this._id_factura, this._cantidad, this._id_unidad, this._identificador, this._id_concepto_cobro,
                                                             this._valor_unitario, this._importe_pesos, this.id_impuesto_retenido, this._tasa_impuesto_retenido,
                                                             this._id_impuesto_trasladado, this._tasa_impuesto_trasladado, this._id_cargo_recurrente, id_usuario, false);

                            //Validando que se Actualizara
                            if (result.OperacionExitosa)
                            {
                                //Obteniendo Valores Totales
                                using (DataTable dt = FacturadoConcepto.ObtieneValoresTotalesFactura(this._id_factura))
                                {
                                    //Validando que la tabla contenga Valores
                                    if (TSDK.Datos.Validacion.ValidaOrigenDatos(dt))
                                    {
                                        //Recorriendo cada Fila
                                        foreach (DataRow dr in dt.Rows)
                                        {
                                            //Editando Factura
                                            result = fac.EditaFactura(Convert.ToDecimal(dr["TotalFactura"]), Convert.ToDecimal(dr["SubTotalFactura"]),
                                                                      Convert.ToDecimal(dr["TrasladadoFactura"]), Convert.ToDecimal(dr["RetenidoFactura"]), id_usuario);
                                        }
                                    }
                                }
                            }

                            //Validando que las Operaciones hayan sido exitosas
                            if (result.OperacionExitosa)
                            {
                                //Instanciando Factura Concepto
                                result = new RetornoOperacion(this._id_detalle_facturado);

                                //Completando Transaccion
                                scope.Complete();
                            }
                        }
                        else
                        {
                            //Instanciando Excepción
                            result = new RetornoOperacion("No existe la Factura");
                        }
                    }
                }
            }
            else
            {
                //Instanciando Excepción
                result = new RetornoOperacion("El detalle se encuentra en una Factura Global, Imposible su Eliminación");
            }

            //Devolviendo Objeto de Retorno
            return(result);
        }
Beispiel #4
0
        /// <summary>
        /// Método Público encargado de Insertar los Conceptos de las Facturas
        /// </summary>
        /// <param name="id_factura">Id de Factura</param>
        /// <param name="cantidad">Cantidad</param>
        /// <param name="id_unidad">Tipo de Unidad</param>
        /// <param name="identificador">Identificador</param>
        /// <param name="id_concepto_cobro">Concepto del Cobro</param>
        /// <param name="valor_unitario">Valor Unitario</param>
        /// <param name="importe_pesos">Importe en Pesos</param>
        /// <param name="tasa_impuesto_retenido">Tasa de Impuesto Retenido</param>
        /// <param name="tasa_impuesto_trasladado">Tasa de Impuesto Trasladado</param>
        /// <param name="id_cargo_recurrente"></param>
        /// <param name="id_usuario">Id de Usuario</param>
        /// <returns></returns>
        public static RetornoOperacion InsertaFacturaConcepto(int id_factura, decimal cantidad, byte id_unidad, string identificador, int id_concepto_cobro,
                                                              decimal valor_unitario, decimal importe_pesos, byte id_impuesto_retenido, decimal tasa_impuesto_retenido,
                                                              byte id_impuesto_trasladado, decimal tasa_impuesto_trasladado, int id_cargo_recurrente, int id_usuario)
        {
            //Declarando Objeto de Retorno
            RetornoOperacion result = new RetornoOperacion();

            //Declarando Variables Auxiliares
            int idFacturaConcepto = 0;

            //Inicializando Transac
            using (TransactionScope scope = Transaccion.InicializaBloqueTransaccional(System.Transactions.IsolationLevel.ReadCommitted))
            {
                //Instanciando factura
                using (Facturado fac = new Facturado(id_factura))
                {
                    //validando que exista la Factura
                    if (fac.id_factura != 0)
                    {
                        //Validando la Moneda
                        if (fac.moneda != 1)
                        {
                            //Instanciando Servicio
                            using (Documentacion.Servicio serv = new Documentacion.Servicio(fac.id_servicio))

                                //Instanciando Facturación Otros
                                using (FacturacionOtros fo = FacturacionOtros.ObtieneInstanciaFactura(id_factura))

                                    //Instanciando Tipo de Cambio
                                    using (Bancos.TipoCambio tc = new Bancos.TipoCambio(serv.id_compania_emisor == 0 ? fo.id_compania_emisora : serv.id_compania_emisor, (byte)fac.moneda, fac.fecha_tipo_cambio, 0))
                                        using (SAT_CL.FacturacionElectronica33.Moneda mon = new FacturacionElectronica33.Moneda(fac.moneda))
                                        {
                                            //Validando que existe el Tipo de Cambio
                                            if (tc.habilitar && mon.habilitar)
                                            {
                                                //Armando arreglo de parametros
                                                object[] param = { 1,                                             0, id_factura,                                    cantidad,            id_unidad,                                       identificador,        id_concepto_cobro,
                                                                   valor_unitario,                                0, System.Math.Round((cantidad * valor_unitario),                   2, MidpointRounding.ToEven) * tc.valor_tipo_cambio, id_impuesto_retenido, tasa_impuesto_retenido,0,
                                                                   id_impuesto_trasladado, tasa_impuesto_trasladado,                                             0, id_cargo_recurrente, id_usuario,                                      true,                 "",                    "" };

                                                //Obteniendo Resultado del SP
                                                result = CapaDatos.m_capaDeDatos.EjecutaProcAlmacenadoObjeto(_nom_sp, param);
                                            }
                                            else
                                            {
                                                //Instanciando Error
                                                result = new RetornoOperacion(string.Format("No existe el Tipo de Cambio del dia '{0:dd/MM/yyyy HH:mm}' de la Moneda '{1}'", fac.fecha_tipo_cambio, mon.clave));
                                            }
                                        }
                        }
                        else
                        {
                            //Armando arreglo de parametros
                            object[] param = { 1,                                             0, id_factura,                                    cantidad,            id_unidad,                identificador,        id_concepto_cobro,
                                               valor_unitario,                                0, System.Math.Round((cantidad * valor_unitario),                   2, MidpointRounding.ToEven), id_impuesto_retenido, tasa_impuesto_retenido,0,
                                               id_impuesto_trasladado, tasa_impuesto_trasladado,                                             0, id_cargo_recurrente, id_usuario,               true,                 "",                    "" };

                            //Obteniendo Resultado del SP
                            result = CapaDatos.m_capaDeDatos.EjecutaProcAlmacenadoObjeto(_nom_sp, param);
                        }

                        //Validando que la Operacion haya sido exitosa
                        if (result.OperacionExitosa)
                        {
                            //Guardando Id del Concepto
                            idFacturaConcepto = result.IdRegistro;

                            //Obteniendo Valores Totales
                            using (DataTable dt = FacturadoConcepto.ObtieneValoresTotalesFactura(id_factura))
                            {
                                //Validando que la tabla contenga Valores
                                if (TSDK.Datos.Validacion.ValidaOrigenDatos(dt))
                                {
                                    //Recorriendo cada Fila
                                    foreach (DataRow dr in dt.Rows)
                                    {
                                        //Editando Factura
                                        result = fac.EditaFactura(Convert.ToDecimal(dr["TotalFactura"]), Convert.ToDecimal(dr["SubTotalFactura"]),
                                                                  Convert.ToDecimal(dr["TrasladadoFactura"]), Convert.ToDecimal(dr["RetenidoFactura"]), 1);
                                    }
                                }
                            }

                            //Validando que las Operaciones hayan sido exitosas
                            if (result.OperacionExitosa)
                            {
                                //Instanciando Concepto
                                result = new RetornoOperacion(idFacturaConcepto);

                                //Completando la Transaccion
                                scope.Complete();
                            }
                        }
                    }
                    else
                    {
                        //Instanciando Error
                        result = new RetornoOperacion("No existe la factura");
                    }
                }
            }
            //Devolviendo Resultado Obtenido
            return(result);
        }