RichFaces - Composants de sélection

Dans ce chapitre, nous découvrirons les différents composants de sélection fournis par RichFaces Technology.

<riche: pickList>

En utilisant cette balise, nous pouvons sélectionner une valeur dans la liste remplie. Cela nous permet également d'ajouter et de supprimer un composant de liste dans une autre liste. L'exemple suivant montre comment cela fonctionne. Allez-y et créez un fichier xhtml et nommez-le comme "pickListExample.xhtml" et placez-y le code suivant.

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns  =  "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>PickList Example</title> 
   </h:head> 
    
   <h:body> 
      <h:form>   
         <h:outputText value  =  "Pick List Example"/>
         <br/>
         <br/>      
         
         <rich:pickList value = "#{managedBean.subjectList}"   
            sourceCaption = "SubjectList"   
            targetCaption = "Selected Subject"   
            listWidth = "170px"   
            listHeight = "120px"       
            orderable = "true">   
            
            <f:selectItems value = "#{managedBean.subjectList}" 
               itemValue = "#{subject}" itemLabel = "#{subject.subjectName}"/>   
         </rich:pickList>  
      </h:form>
   </h:body> 
   
</html>

Nous devons modifier notre fichier managedBean.java pour remplir les composants de la liste dans le fichier xhtml. Voici un aperçu de notre fichier Java modifié.

import java.util.Arrays; 
import java.util.List; 
import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   

@ManagedBean   
@RequestScoped   

public class managedBean {   
   String message;  
   String job; 
   private List<String> SubjectList = Arrays.asList(
      "Richface","AJAX","JAVA","JSF","DOTNET","python"); 
   
   public String getMessage() {   
      return message;   
   }   
   public void setMessage(String message) {   
      System.out.println("setMessage method is getting called with--"+message); 
      this.message = message;   
   } 
   public String getJob() { 
      return job; 
   } 
   public void setJob(String job) { 
      System.out.println("setJob method is getting called with--"+job); 
      this.job = job; 
   } 
   public List<String> getSubjectList() { 
      return SubjectList;
   }  
   public void setSubjectList(List<String> SubjectList) { 
      this.SubjectList = SubjectList; 
   } 
}

Le morceau de code ci-dessus donnera la sortie suivante dans le navigateur. L'attribut «value» de la balise pickList n'est rien d'autre que «getSubjectList ()» de la classe du bean. «ItemValue» est l'abréviation de la classe d'objets et le «itemLabel» correspondant est le nom de la valeur d'instance. Dans cet exemple, notre balise pickList crée automatiquement deux listes distinctes nommées «sourceCaption» et «targetCaption». L'attribut ordonnable est utilisé pour maintenir l'ordre de sélection dans la liste cible.

<riche: orderingList>

Cette balise est utilisée pour rendre une liste dans son ensemble. <orderingList> fournira automatiquement une fonction de type bouton pour se propager à travers la liste et cela aidera à commander un élément sélectionné. Dans l'exemple suivant, nous allons créer une liste de commande en utilisant le code suivant pour «OrderingListExample.xhtml».

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>OrderingList Example</title> 
   </h:head> 
    
   <h:body> 
      <h:form>   
         <h:outputText value = "ordering List Example"/><br/><br/>
         <rich:orderingList value = "#{managedBean.subjectList}"  
            itemValue = "#{subject}" 
            itemLabel = "#{subject.subjectName}" >   
         </rich:orderingList>  
      </h:form>    
   </h:body> 
   
</html>

Nous n'avons pas besoin de changer notre classe de bean car nous remplissons à nouveau la même liste en utilisant une balise différente pour une représentation différente. Comme l'exemple précédent, même ici, les attributs de valeur contiennent la liste entière provenant de «getSubjectList ()». «ItemValue» et «itemLabel» contiennent respectivement la valeur de la classe d'objet et de la variable d'instance correspondante.

Le morceau de code ci-dessus produira la sortie suivante dans le navigateur.

<riche: ListShuttle>

La balise ListShuttle est disponible dans RichFaces 3. Elle permet de se propager dans une liste et de mettre la même valeur dans une autre. Dans RichFaces 4, cette balise a été supprimée car la même fonctionnalité peut être obtenue par une autre nouvelle balise nommée <rich: pickList> comme décrit ci-dessus. Si vous utilisez RichFaces 3.0, vous pouvez utiliser cette balise de la manière suivante.

<rich:listShuttle sourceValue = "#{toolBar.freeItems}" 
   targetValue = "#{toolBar.items}" var = "items" listsHeight = "150" 
   sourceListWidth = "130" targetListWidth = "130" 
   sourceCaptionLabel = "Available Items" 
   targetCaptionLabel = "Currently Active Items" 
   converter = "listShuttleconverter">  
   
   <rich:column width = "18">  
      <h:graphicImage value = "#{items.iconURI}"></h:graphicImage> 
   </rich:column> 
   
   <rich:column> 
      <h:outputText value = "#{items.label}"></h:outputText> 
   </rich:column> 
   
   <a4j:support event = "onlistchanged" reRender = "toolBar" /> 
   <a4j:support event = "onorderchanged" reRender = "toolBar" /> 
</rich:listShuttle>

Il est très pratique d'utiliser pickList plutôt que d'utiliser cette balise, car la même fonctionnalité peut être obtenue en utilisant pickList en écrivant seulement deux lignes de code.