Diferencia entre revisiones de «Formulario Edición 2.0.N»
Ir a la navegación
Ir a la búsqueda
| Línea 56: | Línea 56: | ||
this.AgregarRegion(regionItems); | this.AgregarRegion(regionItems); | ||
| + | |||
| + | this.AgregarAccion("Imprimir", false); | ||
// Ejemplo de como obtener un valor cargado en los campos segun tipo | // Ejemplo de como obtener un valor cargado en los campos segun tipo | ||
| Línea 78: | Línea 80: | ||
// Ej: si ya esta creado, no dejo cambiar el nombre | // Ej: si ya esta creado, no dejo cambiar el nombre | ||
this.BuscarCampoCabecera("nombre").Habilitado = false; | this.BuscarCampoCabecera("nombre").Habilitado = false; | ||
| + | |||
| + | this.BuscarAccion("Imprimir").Visible = true; | ||
} | } | ||
| Línea 109: | Línea 113: | ||
if (nombre == "JUANA") | if (nombre == "JUANA") | ||
throw new Exception("El nombre no puede ser JUANA."); | throw new Exception("El nombre no puede ser JUANA."); | ||
| + | |||
| + | this.BuscarAccion("Imprimir").Visible = true; | ||
} | } | ||
Revisión del 08:20 24 mar 2020
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)
// Habilitado, Requerido
this.AgregarCampoCabeceraCadenaLarga("nombre", "Nombre", true, true);
this.BuscarCampoCabecera("nombre").Ancho = 100;
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;
// Requerido, Habilitado
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);
regionItems.AgregarCampoItemCadenaLarga("codigoBarras", "Código de Barras", true, false);
regionItems.AgregarCampoItemSiNo("habilitado", "Habilitado", true);
this.AgregarRegion(regionItems);
this.AgregarAccion("Imprimir", false);
// 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;
this.BuscarAccion("Imprimir").Visible = true;
}
}
// 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.");
this.BuscarAccion("Imprimir").Visible = true;
}
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);
}
}
//Metodo Auxiliar para reccorrer las filas de una region
private void ValidarRemitar()
{
int cant = 0;
foreach (FlexiEdicionRegionFila fila in this.Regiones[REG_ITEMS].Filas)
{
if (!fila.Eliminada && fila.Pos > 0)
{
int idRemitoItem = fila.Columnas[COL_RE_REL].ValorEntero;
if (idRemitoItem > 0)
cant++;
}
}
this.BuscarAccion("Remitar").Visible = (cant == 0);
}
}
}