Skip to main content

Aplicar filtros a registros usando DataClassG y JSFGenerator

Aplicar Filtros a Registros usando DataClassG y JSFGenerator
Filtrar los registros de departamentos en base a la organización del usuario que se logueo en el sistema.




Tablas

Crear un ManagedBean llamado DatosSession y colocar el atributo por el cual deseamos filtrar los registros en base al usuario que se logea en la aplicación
Clase DatosSesion.java
@Named(value = "datosSesion")
@SessionScoped
public class DatosSesion implements Serializable {
Integer idorganizacion;


   public DatosSesion() {
   }
   public Integer getIdorganizacion() {
       return idorganizacion;
   }
   public void setIdorganizacion(Integer idorganizacion) {
       this.idorganizacion = idorganizacion;
   }    
}



Clase LoginBean.java
Definimos el objeto DatosSesion y en el método verificarLogin() realizamos la asignación
DatosSesion datosSesion;
 public LoginBean() {
    ELContext elContext = FacesContext.getCurrentInstance().getELContext();
    datosSesion = (DatosSesion) FacesContext.getCurrentInstance().getApplication().getELResolver().getValue(elContext, null, "datosSesion");
   }


public String verificarLogin(){
datosSesion.setIdorganizacion(usuarios.getIdorganizacion());



En el ManagedBeans DepartamentoServices.java
Creamos un objeto de DatosSesion, colocamos el valor en la propiedad del managedbean departamento en el mĆ©todo insert(), en el mĆ©todo loadItems() comentamos el selectAll() y lo reemplazamos por un query con el filtro, y en el mĆ©todo  selectAll()  comentamos  if(departamentoController.selectAll()){  y lo reemplazamos por un query con el filtro.


DatosSesion datosSesion;


public DepartamentoServices(){
    ELContext elContext = FacesContext.getCurrentInstance().getELContext();
  departamentolist = new ArrayList<>();
   datosSesion = (DatosSesion) FacesContext.getCurrentInstance().getApplication().getELResolver().getValue(elContext, null, "datosSesion");
}


@Override
public Boolean insert() {
try{
 departamento.setIdorganizacion(datosSesion.getIdorganizacion());


public List<SelectItem> loadItems() {
try {
  //  selectAll();
    query("idorganizacion='"+datosSesion.getIdorganizacion()+"'");


 @Override
   public Boolean selectAll() {
 // if(departamentoController.selectAll()){
      if (departamentoController.query("idorganizacion='" + datosSesion.getIdorganizacion() + "'")) {
            departamentolist = departamentoController.getDepartamentolist();
        }



En ManagedBeans  DepartamentosData
Creamos un objeto de DatosSesion, colocamos el valor en la propiedad del managedbean departamento en el mĆ©todo init(), insert(), en el mĆ©todo loadItems() comentamos el selectAll() y lo reemplazamos por un query con el filtro, y en el mĆ©todo  selectAll()  comentamos  if(departamentoController.selectAll()){  y lo reemplazamos por un query con el filtro.
DatosSesion datosSesion;
public DepartamentoServices(){
    ELContext elContext = FacesContext.getCurrentInstance().getELContext();
  departamentolist = new ArrayList<>();
   datosSesion = (DatosSesion) FacesContext.getCurrentInstance().getApplication().getELResolver().getValue(elContext, null, "datosSesion");
}
   @PostConstruct
   public void init() {
//           ---udpate with your filter;
      // selectAll();
       query("idorganizacion='"+datosSesion.getIdorganizacion()+"'");
   }


@Override
public Boolean insert() {
try{
 departamento.setIdorganizacion(datosSesion.getIdorganizacion());



public List<SelectItem> loadItems() {
try {
  //  selectAll();
    query("idorganizacion='"+datosSesion.getIdorganizacion()+"'");



  @Override
   public Boolean selectAll() {
       try {
           if (departamentolist != null) {
               departamentolist.removeAll(departamentolist);
           }
         //  if (departamentoController.selectAll()) {            
           if (departamentoController.query("idorganizacion='"+datosSesion.getIdorganizacion()+"'")) {
               departamentolist = departamentoController.getDepartamentolist();
           }
Select de todos los registros



Los componentes <p:dataTable se utilizan con la clase DepartamentosData
Imagen de los departamentos pertenecientes a la Organizacion A


Imagen de los departamentos pertenecientes a la Organizacion A


Formulario de insertar registros no se muestra el atributo idorganizacion ya que este se inserta directamente en base al usuario logueado.

Comments

Popular posts from this blog

Tutorial bƔsico de aplicaciones Web con NetBeans parte 1

NetBeans ofrece un excelente soporte para el desarrollo de aplicaciones Web, en esta ocasión lo haremos utilizando el Framework Java Server Faces 2.0. En el Menu Seleccionamos Nuevo->Proyecto y luego en Categorias Java Web y en tipo de Proyectos Web  Application indicamos el nombre del proyecto Seleccinamos el servidor Web, usamos GlassFish ya que este soporta EJB3.0 y JSF 2.0 Framework Java Server Faces El IDE genera el esquelto del proyecto Web Pages   almacenamos las paginas .html, xhtml, jsf, los archivos de recursos, los scripts .js, imagenes Source Packages    Son las clases Java  Test Packages    Son las clases que usamos para los Test Libraries     Tenemos las bibliotecas de Java y GlassFish necesarias para ejecutar la aplicación Web. Test Libraries     EstĆ”n las bibliotecas usadas para los test  Configuration Files    Archivos de configuración de la aplicación. Ejecutamos la...

Test con JUnit

El viernes dicte un taller en el que conversÔbamos sobre Tecnologías Java y luego desarrollamos una aplicación muy bÔsica para demostrar como utilizar JUnit con NetBeans. Pasos: 1. Crear un proyecto Desktop con NetBeans 2. Crear una clase llamada Operaciones 3. Diseñados un formulario y agregramos componentes de manera que quede similar a la figura Código de los botones try { double a = Double.parseDouble(jTextField1.getText()); double b = Double.parseDouble(jTextField2.getText()); Operaciones operaciones = new Operaciones(); double r = operaciones.Sumar(a, b); jTextField3.setText(String.valueOf(r)); } catch (Exception ex) { JOptionPane.showMessageDialog(this, ex.getMessage().toString()); } 4. Creamos los test Seleccionamos las clases En el menu Herramientas,seleccionamos Crear pruebas JUnit Seleccionamos la versión de JUnit En la ventana siguiente seleccionamos los parÔmetros para nuestras pruebas . Le quitamos la selección a Probar Inicializador y Probar Finalizador NetBeans crea las...

JUnit con DataClassG

JUnit con DataClassG 0. ESQUEMA Services: Por cada beans crearemos una clase Services que se encargarĆ” de interactuar con el controller para realizar las operaciones de la base de datos. Se crearan los mĆ©todos insert, update,delete y los demas metodos para realizar las diversas operaciones. Test: Se crearĆ”n las clases para test de las clases Services. Form: Los formularios para la interactuar con el usuario. ProvinciasServices.java colocamos los mĆ©todos, insert, update,delete public class ProvinciasServices {    ProvinciasController provinciasController = new ProvinciasController();    public ProvinciasServices() {    }    public Boolean insert (Provincias provincias){        try{            if(provinciasController.insert(provincias)){              return tru...