/// <summary> /// Realiza actualizaciones en plataformas de terceros sin afectar el flujo operativo de la aplicación /// </summary> /// <param name="id_movimiento">Id de Movimiento de interés</param> /// <param name="id_usuario">Id de Usuario</param> public static RetornoOperacion ActualizaPlataformaTerceros(int id_movimiento, int id_usuario) { //Declarando objeto de resultado RetornoOperacion resultado = new RetornoOperacion(0); //Instanciando movimiento involucrado using (Movimiento mov = new Movimiento(id_movimiento)) { //Si el movimiento pertenece a un servicio if (mov.id_servicio > 0) { //Instanciando servicio del movimiento using (Documentacion.Servicio srv = new Documentacion.Servicio(mov.id_servicio)) { //Realizando actualización resultado = srv.ActualizaPlataformaTerceros(id_usuario); } } } //Devolviendo resultado return(resultado); }
/// <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); }
/// <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); }