Formulario Edición 2.0.N

De FlexiPymeDocs
Revisión del 19:14 5 nov 2019 de Diegogazzolo (discusión | contribuciones) (Página creada con «===Formulario Edición=== ==== Código de Referencia ==== <syntaxhighlight> using FlexiPyme.ui.formularios.especificos.edicion; using System; using System.Collections.Ge…»)
(dif) ← Revisión anterior | Revisión actual (dif) | Revisión siguiente → (dif)
Ir a la navegación Ir a la búsqueda

Formulario Edición

Código de Referencia

using FlexiPyme.ui.formularios.especificos.edicion;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using FlexiAplicacion.LogicaComun;
namespace FlexiAplicacion.##CARPETA##
{
    public class ##FORMULARIO## : FlexiEdicion
    {
        // Este metodo se ejecuta 1 vez para cargar la definición del formulario
        public override void InicializarFormulario()
        {
            // Parametros generales del formulario
            this.Titulo = "Edición de Tabla";
            this.TablaCabecera = "Tabla";
            this.CampoClaveCabecera = "id";
            this.ParametroRecibido = "id";
            this.GuardarYNuevo = false;

            // Campos a editar de la cabecera (tabla cabecera)
            this.AgregarCampoCabeceraCadenaLarga("nombre", "Nombre", true, true);
            this.AgregarCampoCabeceraCadena("nombre", "Nombre", true, true);
            this.AgregarCampoCabeceraCadenaMultilinea("nombre", "Nombre", true, true);
            this.AgregarCampoCabeceraEntero("nombre", "Nombre", true, true);
            this.AgregarCampoCabeceraFecha("nombre", "Nombre", true, true);
            this.AgregarCampoCabeceraSiNo("nombre", "Nombre", true, true);
            this.AgregarCampoCabeceraDependiente("nombre", "Nombre", "Tabla", "id", "nombre", true, true);
            this.AgregarCampoCabeceraDependienteAjax("nombre", "Nombre", "Tabla", "id", "nombre", true, true, "accion");
            this.AgregarCampoCabeceraMoneda("nombre", "Nombre", true, true);
            this.AgregarCampoCabeceraPassword("nombre", "Nombre", true, true);

            // Creo una region de una tabla relacionada
            FlexiEdicionRegion regionItems = new FlexiEdicionRegion();
            regionItems.Nombre = "Items de la tabla";
            regionItems.TablaItems = "NombreTablaItems";
            regionItems.CampoClaveItems = "id";
            regionItems.CampoFiltradoItems = "idTablaMaestra";
            regionItems.EliminacionMasiva = true;

            regionItems.AgregarCampoItemDependienteAjax("idFactura", "Factura (nro, fecha)", "FacturasVW", "id", "nombre", true, true, "");
            regionItems.AgregarCampoItemMoneda("monto", "Monto Aplicado", true, true);
            regionItems.AgregarCampoInferiorMoneda("totalAplicado", "Total Facturas", false, false);

            this.AgregarRegion(regionItems);

            // Ejemplo de como obtener un valor cargado en los campos segun tipo
            int intVal = this.BuscarCampoCabecera("valor").ValorEntero;
            bool boolVar = this.BuscarCampoCabecera("valor").ValorBool;
            DateTime dateVar = this.BuscarCampoCabecera("valor").ValorFecha;
            string strVar = this.BuscarCampoCabecera("valor").ValorCadena;
            decimal decVar = this.BuscarCampoCabecera("valor").ValorMoneda;
        }

        // Se ejecuta la primera vez que se ingresa al formulario
        public override void AntesDeVisualizar()
        {
            // Verifico si es un nuevo registro o si es existente
            if (this.IdEntidad == 0)
            {
                // Ej: se inicializan los campos con valores
                this.BuscarCampoCabecera("nombre").Valor = "aca va el nombre";
            }
            else
            {
                // Ej: si ya esta creado, no dejo cambiar el nombre
                this.BuscarCampoCabecera("nombre").Habilitado = false;
            }
            
        }

        // Eset evento permite validar antes de eliminar
        public override void AntesDeEliminar()
        {
            // Ej: validar que no tenga registros dependientes de otras tablas
            string sql = "select count(*) from TablaRelacionada where id = @idActual";
            Dictionary pars = new Dictionary();
            pars.Add("@idActual", this.IdEntidad);
            int cant = FlexiDb.EjecutarScalarInt(sql, pars);

            if (cant > 0)
                throw new Exception("No puede eliminar el registro porque tiene Tablas Vinculadas.");
        }

        public override void DespuesDeEliminar()
        {
            // Ej: puede cambiar el estado de otra tabla 
            //o enviar aviso de eliminacion o actualizar totales.
        }

        // Se ejecuta al presionar Guardar, si genera un error, no se guarda el formulario.
        // Se tiene que hacer todas las validaciones necesarias.
        public override void AntesDeGuardar()
        {
            string nombre = this.BuscarCampoCabecera("nombre").ValorCadena;

            if (nombre == "JUANA")
                throw new Exception("El nombre no puede ser JUANA.");
        }

        public override void DespuesDeGuardar()
        {
             // Ej: puede cambiar el estado de otra tabla 
            //o enviar aviso de eliminacion o actualizar totales.
        }

        // Cada campo de la cabecera o las acciones al pie pueden disparar este evento
        public override void EjecutarAccion(string accion)
        {
            if (accion == "nombre de la accion")
            {
                // Ej: cambio otro campo
                // Ej: deshabilito parte del formulario
                // Ej: genero un PDF
            }
        }

        // Se ejecuta antes de agregar un item en la region indicada
        // En la posición 0 (cero) de los items de la region esta la fila a agregar
        public override void AntesDeAgregarItem(int region)
        {
            // Ej segun el valor de un campo, valido otro
            FlexiEdicionRegionFila fila = this.Regiones[region].FilaNueva;
            int idReciboItemTipo = fila.Columnas[PAG_TIPO].ValorEntero;

            string tipo = LogicaDeNombres.ObtenerCodigoReciboItemTipo(idReciboItemTipo);
            if (tipo == "TR" || tipo == "DEP")
            {
                int idCuentaBancaria = fila.Columnas[PAG_CTA_BCO].ValorEntero;
                if (idCuentaBancaria == 0)
                    throw new BusinessException("La cuenta bancaria es requerida para transferencias o depósitos.");
            }
        }
        
        // Se ejecuta luego de agregar un item
        public override void DespuesDeAgregarItem(int region)
        {
            // Generalemnte se recalculan totales o re enumeran lineas
        }

        // Se ejecuta luego de eliminar un item
        public override void DespuesDeEliminarItem(int region)
        {
            // Generalemnte se recalculan totales o re enumeran lineas
        }
        
        // Se ejecuta cuando se dispara una accion en una fila de una region
        public override void EjecutarAccion(string accion, int region, int fila)
        {
            FlexiEdicionRegionFila filaReg = this.Regiones[region].Filas[fila];
            if (accion == "factura")
            {
                int idFactura = filaReg.Columnas[APLI_FAC].ValorEntero;

                //Obtengo monto pendiente de aplicar factura.
                filaReg.Columnas[APLI_MONTO].Valor = LogicaDeFacturas.ObtenerMontoPendienteDeAplicar(idFactura);
            }
        }
        
    }
}