RichFaces - Composants d'entrée

Jusqu'à présent, nous avons beaucoup appris sur les différents composants AJAX de RichFaces ainsi qu'une nouvelle fonctionnalité appelée «Skin». Dans ce chapitre, nous allons apprendre les différents composants «Rich» que propose RichFaces afin de développer une application web moderne. Voici les différents composants d'entrée fournis par «RichFaces».

<rich: inplaceInput>

Rich inplaceInput offre la possibilité de créer une zone de texte modifiable au lieu d'une zone de texte d'entrée normale. Dans l'exemple suivant, nous allons créer une zone de texte modifiable à l'aide de ce composant. Créez un fichier xhtml et nommez-le «richinplaceInput.xhtml». Écrivez le code suivant dans ce fichier.

<?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>TODO supply a title</title> 
   </h:head> 
    
   <h:body> 
      <f:view></f:view>   
      <h:form>   
         <rich:inplaceInput  value = "#{managedBean.message}"   
            defaultLabel = "Enter Your Name"/> 
      </h:form>  
   </h:body>
   
</html>

Enregistrez ce fichier et exécutez-le. Voici la sortie dans le navigateur.

Allez-y et tapez tout ce de votre choix dans cette zone de texte et appuyez sur Entrée. Cette balise fournit également une option d'édition en ligne. Ce qui suit sera produit après l'édition.

<rich: inplaceSelect>

Il s'agit d'un autre balisage d'entrée fourni par RichFaces, où l'utilisateur peut sélectionner une valeur d'entrée dans la liste déroulante, qui est également de nature en ligne et modifiable. Nous devons remplir la liste déroulante à partir de la classe de bean interne. Veuillez créer un fichier «xhtml» et nommez-le «richinplaceSelectExample.xhtml». Placez le morceau de code suivant dans ce fichier.

<?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>TODO supply a title</title>
   </h:head> 
    
   <h:body> 
      <h:form> 
         <rich:inplaceSelect value = "#{subject.subjectName}" defaultLabel = "Click to Select Country">
            <f:selectItems value = "#{subject.SubJectList()}"></f:selectItems>   
         </rich:inplaceSelect> 
      </h:form>     
   </h:body>
   
</html>

Dans l'exemple ci-dessus, nous remplirons les options de liste déroulante à partir du backend. Voici la classe de bean nommée «subject.java».

import java.util.ArrayList; 
import java.util.List; 
import javax.faces.bean.ManagedBean; 
import javax.faces.bean.ManagedProperty; 
import javax.faces.bean.RequestScoped;   

@ManagedBean 
@RequestScoped 

public class Subject { 
   String SubjectName;  
   public Subject() { 
   }  
   public Subject(String SubjectName) { 
      this.SubjectName = SubjectName; 
   } 
   public List<String> SubJectList() {  
      //this list to be rendered
      ArrayList<String> list = new ArrayList<>();   
      
      list.add("JAVA");   
      list.add("DOTNET");   
      list.add("COBOL");   
      list.add("AJAX");   
      list.add("JAVA SCRIPT");   
      return list;   
   }    
   public String getSubjectName() { 
      return SubjectName; 
   } 
   public void setSubjectName(String SubjectName) { 
      this.SubjectName = SubjectName; 
   } 
}

Tout le nom du sujet que nous passons dans la liste sera affiché dans le menu déroulant. Voici la sortie après l'exécution de cette application.

<riche: SuggestionBox>

<rich: SuggestionBox> est utilisé pour fournir des suggestions à l'utilisateur en fonction de l'entrée fournie dans la zone de texte d'entrée. Cette balise crée un événement JS en interne et appelle la classe istener requise pour fournir la suggestion depuis le backend. Malheureusement, ces suggestionsBox et ComboBox sont tous deux combinés dans une balise distincte appelée «<rich: autocomplete>» dans RichFaces 4, cependant, si vous utilisez RichFaces 3, vous pouvez utiliser cette balise comme indiqué ci-dessous.

<h:inputText id = "city" value = "#{capitalsBean.capital}" /> 
<rich:suggestionbox for = "city" var = "result" 
   suggestionAction = "#{capitalsBean.autocomplete}"> 
   
   <h:column> 
      <h:outputText value = "#{result.name}" /> 
   </h:column> 
</rich:suggestionbox>

Où «capitalsBean» sera une classe Java avec différents paramètres et la classe d'écoute nommée «autocomplete» définira la valeur de la variable d'instance «capital» au moment de l'exécution et fournira la sortie de choix requise. Il est fortement recommandé d'utiliser RichFaces 4 «autocomplete» au lieu d'utiliser cette balise car les concepteurs ne prennent plus en charge cette balise.

<riche: comboBox>

<rich: comboBox> fonctionne exactement de la même manière que <rich: suggestionBox>, cependant, au lieu d'appeler la classe d'écouteur, cette balise pré-rend certaines suggestions dans le navigateur client qui interagit les unes avec les autres et fournit le résultat souhaité. Comme <rich: sugegstionBox>, cette fonctionnalité est également dépréciée dans la nouvelle version avec une autre balise appelée «<rich: autocomplete>» décrite dans le code suivant.

Créez un fichier séparé et nommez-le «richAutoComplete.xhtml». Placez le code suivant dans ce fichier.

<?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></h:head> 
   
   <h:body> 
      <h:form id = "form"> 
         <h:form id = "form"> 
            <rich:autocomplete mode = "cachedAJAX" minChars = "2" 
            autocompleteMethod = "#{autoComplete.SubJectList()}" /> 
         </h:form> 
      </h:form> 
   </h:body>
   
</html>

Dans l'exemple ci-dessus, nous remplissons la liste des sujets via la fonction de saisie semi-automatique de RichFaces. Créez une autre classe Java et nommez-la «autoComplete.java».

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

@ManagedBean 
@RequestScoped 

public class autoComplete { 
   public autoComplete(){} 
   private List<String> autoCompleteList=new ArrayList<>(); 
   
   public List<String> SubJectList() {   
      //ArrayList<String> list = new ArrayList<>();   
      autoCompleteList.add("JAVA");   
      autoCompleteList.add("DOTNET");   
      autoCompleteList.add("COBOL");   
      autoCompleteList.add("AJAX");   
      autoCompleteList.add("JAVA SCRIPT");   
      return autoCompleteList;   
   }   
   public List<String> getAutoCompleteList() {
      return autoCompleteList; 
   }  
   public void setAutoCompleteList(List<String> autoCompleteList) { 
      this.autoCompleteList = autoCompleteList; 
   } 
}

Le fichier ci-dessus agit comme la classe de bean et SubjectList () est la méthode, qui rend en fait la réponse au navigateur. Dans la balise <SuggestionBox>, <ComboBox>, nous devons implémenter la classe d'écouteur, cependant, en cas de balise <autocomplete>, cette création de classe d'écouteur a été automatisée, ce qui est plus facile pour le développeur. Le morceau de code ci-dessus donnera la sortie suivante dans le navigateur.

<rich: inputNumberSlider>

Il s'agit d'une balise très simple qui aide le développeur à créer une barre de défilement numérique en fonction de l'intervalle numérique. Créez le fichier «inputNumberSlider.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></h:head> 
   
   <h:body> 
      <h:form>   
         <h:outputText value = "Slide Bar example"></h:outputText>   
         <rich:inputNumberSlider    
            minValue = "1"   
            maxValue = "10"   
            showArrows = "false"   
            showTooltip = "false"   
            step = "1">   
         </rich:inputNumberSlider>   
      </h:form>  
   </h:body>
   
</html>

Dans l'exemple ci-dessus, les attributs sont assez descriptifs. Le morceau de code ci-dessus donnera la sortie suivante dans le navigateur.

<riche: Calendrier>

Comme son nom l'indique, cette balise aidera à créer un calendrier dans le navigateur. Créez un fichier séparé et nommez-le «richCalendar.xhtml». Placez le code suivant à l'intérieur.

<?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></h:head> 
   
   <h:body> 
      <h:form>   
         <h1>Calendar</h1>   
         <rich:calendar value = "#{calendarBean.selectedDate}"   
            locale = "#{calendarBean.locale}"   
            popup = "#{calendarBean.popup}"   
            datePattern = "#{calendar.pattern}"   
            style = "width:200px">
         </rich:calendar>   
      </h:form> 
   </h:body>
   
</html>

Nous devons créer une autre classe appelée «calendarBean.java» afin de contenir toutes les valeurs de calendrier telles que Date, Locale, Date Pattern, etc. Voici le code pour «calendarBean.java».

import java.text.DateFormat; 
import java.util.Date; 
import java.util.Locale; 
  
import javax.faces.event.ValueChangeEvent; 
  
public class CalendarBean { 
   private static final String[] WEEK_DAY_LABELS = new String[] { 
      "Sun *", "Mon +", "Tue +", "Wed +", "Thu +", "Fri +", "Sat *" }; 
   
   private Locale locale; 
   private boolean popup; 
   private boolean readonly; 
   private boolean showInput; 
   private boolean enableManualInput;     
   private String pattern; 
   private Date currentDate; 
   private Date selectedDate; 
   private String jointPoint; 
   private String direction; 
   private String boundary; 
   private boolean useCustomDayLabels; 
  
   public Locale getLocale() { 
      return locale; 
   }
   public void setLocale(Locale locale) { 
      this.locale = locale; 
   } 
   public boolean isPopup() { 
      return popup; 
   } 
   public void setPopup(boolean popup) { 
      this.popup = popup; 
   } 
   public String getPattern() { 
      return pattern; 
   } 
   public void setPattern(String pattern) { 
      this.pattern = pattern; 
   } 
   public CalendarBean() { 
      locale = Locale.US; 
      popup = true; 
      pattern = "MMM d, yyyy"; 
      jointPoint = "bottomleft"; 
      direction = "bottomright"; 
      readonly = true; 
      enableManualInput = false; 
      showInput = true; 
      boundary = "inactive"; 
   } 
   public boolean isShowInput() { 
      return showInput;
   } 
   public void setShowInput(boolean showInput) { 
      this.showInput = showInput; 
   } 
   public boolean isEnableManualInput() { 
      return enableManualInput; 
   } 
   public void setEnableManualInput(boolean enableManualInput) { 
      this.enableManualInput = enableManualInput; 
   } 
   public boolean isReadonly() { 
      return readonly; 
   } 
   public void setReadonly(boolean readonly) { 
      this.readonly = readonly; 
   } 
   public void selectLocale(ValueChangeEvent event) { 
      String tLocale = (String) event.getNewValue(); 
      if (tLocale != null) { 
         String lang = tLocale.substring(0, 2); 
         String country = tLocale.substring(3); 
         locale = new Locale(lang, country, ""); 
      } 
   } 
   public boolean isUseCustomDayLabels() { 
      return useCustomDayLabels; 
   } 
   public void setUseCustomDayLabels(boolean useCustomDayLabels) { 
      this.useCustomDayLabels = useCustomDayLabels; 
   } 
   public Object getWeekDayLabelsShort() { 
      if (isUseCustomDayLabels()) { 
         return WEEK_DAY_LABELS; 
      } else { 
         return null; 
      } 
   } 
   public String getCurrentDateAsText() { 
      Date currentDate = getCurrentDate(); 
      if (currentDate ! =  null) { 
         return DateFormat.getDateInstance(DateFormat.FULL).format(currentDate); 
      } 
      return null; 
   } 
   public Date getCurrentDate() { 
      return currentDate; 
   } 
   public void setCurrentDate(Date currentDate) { 
      this.currentDate = currentDate; 
   } 
   public Date getSelectedDate() { 
      return selectedDate; 
   } 
   public void setSelectedDate(Date selectedDate) { 
      this.selectedDate = selectedDate; 
   } 
   public String getJointPoint() { 
      return jointPoint; 
   } 
   public void setJointPoint(String jointPoint) { 
      this.jointPoint = jointPoint; 
   } 
   public void selectJointPoint(ValueChangeEvent event) { 
      jointPoint = (String) event.getNewValue(); 
   } 
   public String getDirection() { 
      return direction; 
   } 
   public void setDirection(String direction) { 
      this.direction = direction; 
   } 
   public void selectDirection(ValueChangeEvent event) { 
      direction = (String) event.getNewValue(); 
   } 
   public String getBoundary() { 
      return boundary; 
   } 
   public void setBoundary(String boundary) { 
      this.boundary = boundary; 
   } 
}

Le morceau de code ci-dessus générera la sortie suivante dans le navigateur.

<riche: InputNumberSpinner>

Cette balise aide le développeur à créer une double flèche pour remplir une instance d'un bean. Voici un exemple qui vous aidera à comprendre la balise Spinner en détail. Veuillez créer un fichier xhtml séparé et le nommer «InputNumberSpinner.xhtml» et placer le code suivant à l'intérieur.

<?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>Number Slider Example</title> 
   </h:head>
   
   <h:body> 
      <h:form>   
         <h:outputText value = "Select a Date"></h:outputText>
         <br/>
         <br/>   
         
         <rich:inputNumberSpinner   
            minValue = "1"   
            maxValue = "31"   
            step = "1">   
         </rich:inputNumberSpinner>  
      </h:form>   
   </h:body>
   
</html>

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