Richfaces Reference
Richfaces Reference
Richfaces Reference
1. Introduction ................................................................................................................... 1
2. Technical Requirements ................................................................................................. 3
2.1. Supported Java Versions .................................................................................... 3
2.2. Supported JavaServer Faces Implementations and Frameworks ............................ 3
2.3. Supported Servers .............................................................................................. 3
2.4. Supported Browsers ............................................................................................ 4
3. Getting Started with RichFaces ...................................................................................... 5
3.1. Downloading the RichFaces ................................................................................ 5
3.2. Simple JSF application with RichFaces ................................................................ 5
3.2.1. Adding RichFaces libraries into the project ................................................ 5
3.2.2. Registering RichFaces in web.xml ............................................................. 6
3.2.3. Managed bean ......................................................................................... 8
3.2.4. Registering bean in faces-cofig.xml ........................................................... 8
3.2.5. RichFaces Greeter index.jsp ..................................................................... 9
3.3. Integration of RichFaces into Maven Project ....................................................... 10
3.4. Relevant Resources Links ................................................................................. 16
4. Settings for different environments ................................................................................ 17
4.1. Web Application Descriptor Parameters .............................................................. 17
4.2. Sun JSF RI ...................................................................................................... 20
4.3. Apache MyFaces .............................................................................................. 20
4.4. Facelets Support ............................................................................................... 21
4.5. JBoss Seam Support ........................................................................................ 21
4.6. Portlet Support .................................................................................................. 25
4.7. Sybase EAServer .............................................................................................. 25
4.8. Oracle AS/OC4J ............................................................................................... 25
5. Basic concepts of the RichFaces Framework ................................................................ 27
5.1. Introduction ....................................................................................................... 27
5.2. RichFaces Architecture Overview ....................................................................... 28
5.3. Partial Rendering .............................................................................................. 31
5.4. RichFaces Integral Parts ................................................................................... 31
5.5. Limitations and Rules ........................................................................................ 32
5.6. Ajax Request Optimization ................................................................................. 32
5.6.1. Re-Rendering ......................................................................................... 32
5.6.2. Queue and Traffic Flood Protection ......................................................... 34
5.6.3. Queue Principles .................................................................................... 35
5.6.4. Data Processing Options ........................................................................ 41
5.6.5. Action and Navigation ............................................................................. 42
5.6.6. JavaScript Interactions ............................................................................ 42
5.6.7. Iteration components Ajax attributes ........................................................ 44
5.6.8. Other useful attributes ............................................................................ 44
5.6.9. Common Ajax Attributes ......................................................................... 45
5.7. How To... ......................................................................................................... 55
5.7.1. Send an Ajax request ............................................................................. 55
5.7.2. Decide What to Send ............................................................................. 56
iii
RichFaces Developer Guide
iv
RichFaces Developer Guide
v
RichFaces Developer Guide
vi
RichFaces Developer Guide
vii
Chapter 1. Introduction
Introduction
RichFaces is an open source framework that adds Ajax capability into existing JSF applications
without resorting to JavaScript.
• Intensify the whole set of JSF benefits while working with Ajax. RichFaces is fully integrated into
the JSF lifecycle. While other frameworks only give you access to the managed bean facility,
RichFaces advantages the action and value change listeners, as well as invokes server-side
validators and converters during the Ajax request-response cycle.
• Add Ajax capability to the existing JSF applications. Framework provides two components
libraries (Core Ajax and UI). The Core library sets Ajax functionality into existing pages, so
there is no need to write any JavaScript code or to replace existing components with new Ajax
ones. RichFaces enables page-wide Ajax support instead of the traditional component-wide
support and it gives the opportunity to define the event on the page. An event invokes an Ajax
request and areas of the page which become synchronized with the JSF Component Tree after
changing the data on the server by Ajax request in accordance with events fired on the client.
• Create quickly complex View basing on out of the box components. RichFaces UI library
contains components for adding rich user interface features to JSF applications. It extends
the RichFaces framework to include a large (and growing) set of powerful rich Ajax-enabled
components that come with extensive skins support. In addition, RichFaces components are
designed to be used seamlessly with other 3d-party component libraries on the same page, so
you have more options for developing your applications.
• Write your own custom rich components with built-in Ajax support. We're always working on
improvement of Component Development Kit (CDK) that was used for RichFaces UI library
creation. The CDK includes a code-generation facility and a templating facility using a JSP-
like syntax. These capabilities help to avoid a routine process of a component creation.
The component factory works like a well-oiled machine allowing the creation of first-class
rich components with built-in Ajax functionality even more easily than the creation of simpler
components by means of the traditional coding approach.
• Package resources with application Java classes. In addition to its core, Ajax functionality of
RichFaces provides an advanced support for the different resources management: pictures,
JavaScript code, and CSS stylesheets. The resource framework makes possible to pack easily
these resources into Jar files along with the code of your custom components.
1
Chapter 1. Introduction
• Easily generate binary resources on-the-fly. Resource framework can generate images,
sounds, Excel spreadsheets etc.. on-the-fly so that it becomes for example possible to create
images using the familiar approach of the "Java Graphics2D" library.
• Create a modern rich user interface look-and-feel with skins-based technology. RichFaces
provides a skinnability feature that allows easily define and manage different color schemes
and other parameters of the UI with the help of named skin parameters. Hence, it is possible to
access the skin parameters from JSP code and the Java code (e.g. to adjust generated on-the-
fly images based on the text parts of the UI). RichFaces comes with a number of predefined
skins to get you started, but you can also easily create your own custom skins.
• Test and create the components, actions, listeners, and pages at the same time. An automated
testing facility is in our roadmap for the near future. This facility will generate test cases for your
component as soon as you develop it. The testing framework will not just test the components,
but also any other server-side or client-side functionality including JavaScript code. What is
more, it will do all of this without deploying the test application into the Servlet container.
RichFaces UI components come ready to use out-of-the-box, so developers save their time and
immediately gain the advantage of the mentioned above features in Web applications creation.
As a result, usage experience can be faster and easily obtained.
2
Chapter 2. Technical Requirements
Technical Requirements
RichFaces was developed with an open architecture to be compatible with the widest possible
variety of environments.
• Java
• JavaServer Faces
• RichFaces framework
• Facelets 1.1.x
• Seam 2.x
• Resin 3.1.x
• Jetty 6.1.x
• Glassfish V2, V3
3
Chapter 2. Technical Requirements
• JBoss 4.2.x - 5
Windows environments
• Google Chrome
Mac OS environments
This list is composed basing on reports received from our users. We assume the list can be
incomplete and absence of your environment in the list doesn't mean incompatibility.
We appreciate your feedback on platforms and browsers that aren't in the list but are compatible
with RichFaces. It helps us to keep the list up-to-date.
4
Chapter 3. Getting Started with RichFaces
To start with RichFaces in computer file system create new folder with name "RichFaces",
download and unzip the archive with binaries there.
For those who want to download and compile the RichFaces by themselfs there is an
article at JBoss community that describes the RichFaces repository's structure overview [http://
www.jboss.org/community/docs/DOC-11864] and some aspects of working with it.
Create standard JSF 1.2 project with all necessary libraries; name the project "Greeter" and follow
the decription.
Go to the folder with unzipped earlier RichFaces binary files and open lib folder. This folder
contains three *.jar files with API, UI and implementation libraries. Copy that "jars" from lib
folder to WEB-INF/lib folder of "Greeter" JSF application.
Important:
A JSF application with RichFaces assumes that the following JARs are available in
the project: commons-beanutils-1.7.0.jar, commons-collections-3.2.jar, commons-
digester-1.8.jar, commons-logging-1.0.4.jar, jhighlight-1.0.jar.
5
Chapter 3. Getting Started with RichFaces
After RichFaces libraries where added into the project it is necessary to register them in project
web.xml file. Add following lines in web.xml:
...
<!-- Plugging the "Blue Sky" skin into the project -->
<context-param>
<param-name>org.richfaces.SKIN</param-name>
<param-value>blueSky</param-value>
</context-param>
<!-- Making the RichFaces skin spread to standard HTML controls -->
<context-param>
<param-name>org.richfaces.CONTROL_SKINNING</param-name>
<param-value>enable</param-value>
</context-param>
<filter-mapping>
<filter-name>richfaces</filter-name>
<servlet-name>Faces Servlet</servlet-name>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
</filter-mapping>
...
For more information on how to work with RichFaces skins read "Skinnabilty" chapter.
<?xml version="1.0"?>
<web-app version="2.5"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
6
Chapter 3. Getting Started with RichFaces
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/
javaee/web-app_2_5.xsd">
<display-name>Greeter</display-name>
<context-param>
<param-name>javax.faces.STATE_SAVING_METHOD</param-name>
<param-value>server</param-value>
</context-param>
<context-param>
<param-name>org.richfaces.SKIN</param-name>
<param-value>blueSky</param-value>
</context-param>
<context-param>
<param-name>org.richfaces.CONTROL_SKINNING</param-name>
<param-value>enable</param-value>
</context-param>
<filter>
<display-name>RichFaces Filter</display-name>
<filter-name>richfaces</filter-name>
<filter-class>org.ajax4jsf.Filter</filter-class>
</filter>
<filter-mapping>
<filter-name>richfaces</filter-name>
<servlet-name>Faces Servlet</servlet-name>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
</filter-mapping>
<listener>
<listener-class>com.sun.faces.config.ConfigureListener</listener-class>
</listener>
7
Chapter 3. Getting Started with RichFaces
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
</web-app>
package demo;
8
Chapter 3. Getting Started with RichFaces
<managed-bean-class>demo.user</managed-bean-class>
<managed-bean-scope>request</managed-bean-scope>
<managed-property>
<property-name>name</property-name>
<property-class>java.lang.String</property-class>
<value/>
</managed-property>
</managed-bean>
</faces-config>
The "RichFaces Greeter" application has only one JSP page. Create index.jsp page in root of
WEB CONTENT folder and add there following code:
<html>
<head>
<title>RichFaces Greeter</title>
</head>
<body>
<f:view>
<a4j:form>
<rich:panel header="RichFaces Greeter" style="width: 315px">
<h:outputText value="Your name: " />
<h:inputText value="#{user.name}" >
<f:validateLength minimum="1" maximum="30" />
</h:inputText>
9
Chapter 3. Getting Started with RichFaces
</a4j:form>
</f:view>
</body>
</html>
The application uses three RichFaces components: <rich:panel> is used as visual container
for information; <a4j:commandButton> with built-in Ajax support allows rendering a greeting
dynamically after a response comes back and <a4j:form> helps the button to perform the action.
Note, that the RichFaces tag library should be declared on each JSP page.
For Facelets you should add the following lines for tag library declaration:
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:a4j="http://richfaces.org/a4j"
xmlns:rich="http://richfaces.org/rich">
...
</ui:composition>
That's it. Run the application on server. Point your browser to index.jsp page in browser: http://
localhost:8080/Greeter/index.jsf
In the first place you need to make sure that Maven is installed on you local machine. We will
run the JSF application on Tomcat 6.0 server, so please download and install it if you haven't
done already so.
Now we can move on to creating the application. To create the project structure and fill it with
minimal content we will use the "maven-archetype-jsfwebapp" Maven archetype which is a part
of RichFaces CDK.
The "maven-archetype-jsfwebapp" archetype and the project itself require extra repositories
to be provided, namely "http://snapshots.jboss.org/maven2/" and "http://repository.jboss.com/
10
Chapter 3. Getting Started with RichFaces
maven2/". The easiest way to make the repositories visible for Maven is to create a profile in
"maven_installation_folder/conf/settings.xml" in <profiles> element. This is the content of the
profile:
<profile>
<id>jsf-app-profile</id>
<repositories>
<repository>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
<updatePolicy>always</updatePolicy>
</snapshots>
<id>snapshots.jboss.org</id>
<name>Snapshot Jboss Repository for Maven</name>
<url>http://snapshots.jboss.org/maven2/</url>
<layout>default</layout>
</repository>
<repository>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
<updatePolicy>always</updatePolicy>
</snapshots>
<id>repository.jboss.com</id>
<name>Jboss Repository for Maven</name>
<url>http://repository.jboss.com/maven2/</url>
<layout>default</layout>
</repository>
</repositories>
</profile>
When the profile is added you need to activate it in the <activeProfiles> element. It can be
done like this:
...
11
Chapter 3. Getting Started with RichFaces
<activeProfiles>
<activeProfile>jsf-app-profile</activeProfile>
</activeProfiles>
...
Now you have everything to create the project using the "maven-archetype-jsfwebapp" archetype.
Create a folder that will house your project and run the this command in it:
...
mvn archetype:generate -DarchetypeGroupId=org.richfaces.cdk -DarchetypeArtifactId=maven-
archetype-jsfwebapp -DarchetypeVersion=3.3.3-SNAPSHOT -DgroupId=org.docs.richfaces -
DartifactId=jsf-app
...
Parameter Description
-DgroupId Defines the package for the Managed beans
-DartifactId Defines the name of the project
This command generates a JSF project that has the following structure:
jsf-app
|-- pom.xml
`-- src
|-- main
| |-- java
| | `-- org
| | `-- docs
| | `-- richfaces
| | `-- Bean.java
| |-- resources
| `-- webapp
| |-- WEB-INF
| | |-- faces-config.xml
| | `-- web.xml
| |-- index.jsp
| `-- pages
| |-- index.jsp
12
Chapter 3. Getting Started with RichFaces
| `-- index.xhtml
`-- test
`-- java
`-- org
`-- docs
`-- richfaces
`-- BeanTest.java
Now go to "jsf-app" folder, it contains a project descriptor(pom.xml). Open the project descriptor
to edit and add dependencies to the <dependencies> element. Your <dependencies> element
content should be the following:
...
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.4</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.1.2</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
<scope>provided</scope>
13
Chapter 3. Getting Started with RichFaces
</dependency>
<dependency>
<groupId>javax.faces</groupId>
<artifactId>jsf-api</artifactId>
<version>1.2_12</version>
</dependency>
<dependency>
<groupId>javax.faces</groupId>
<artifactId>jsf-impl</artifactId>
<version>1.2_12</version>
</dependency>
<dependency>
<groupId>javax.el</groupId>
<artifactId>el-api</artifactId>
<version>1.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>el-impl</groupId>
<artifactId>el-impl</artifactId>
<version>1.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.annotation</groupId>
<artifactId>jsr250-api</artifactId>
<version>1.0</version>
</dependency>
<!-- RichFaces libraries -->
<dependency>
<groupId>org.richfaces.framework</groupId>
<artifactId>richfaces-api</artifactId>
<version>3.3.3-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.richfaces.framework</groupId>
<artifactId>richfaces-impl</artifactId>
<version>3.3.3-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.richfaces.ui</groupId>
<artifactId>richfaces-ui</artifactId>
<version>3.3.3-SNAPSHOT</version>
</dependency>
14
Chapter 3. Getting Started with RichFaces
</dependencies>
...
The last three dependences add RichFaces libraries to the project. You can now build the project
with the mvn install command.
When you see the "BUILD SUCCESSFUL" message, the project is assembled and can be
imported to a IDE and run on the server.
The project can be built for Eclipse IDE with mvn eclipse:eclipse -Dwtpversion=2.0
command.
Then you can import the project into Eclipse. After importing to Eclipse open the "jsf-app/src/main/
webapp/WEB-INF/web.xml" to configure it according to the listing in the Registering RichFaces
in web.xml section of the guide.
The project is configured and now you can start using RichFaces. Open "jsf-app/src/main/webapp/
pages/index.jsp" file and add the tag library declaration.
...
<%@ taglib uri="http://richfaces.org/rich" prefix="rich"%>
...
Add some RichFaces component to the "index.jsp" page, for instance <rich:calendar>. Your
"index.jsp" page will look like this:
...
<%@ taglib uri="http://java.sun.com/jsf/html" prefix="h" %>
<%@ taglib uri="http://java.sun.com/jsf/core" prefix="f"%>
<%@ taglib uri="http://richfaces.org/rich" prefix="rich"%>
<html>
<head>
<title>JSF Application with RichFaces built by Maven</title>
</head>
<body>
<f:view>
<rich:calendar />
</f:view>
</body>
</html>
...
15
Chapter 3. Getting Started with RichFaces
Now run the application on Tomcat server and open it in your favourite browser by pointing it to
"http://localhost:8080/jsf-app/" .
See also the "How to start RichFaces application with NetBeans IDE" [http://www.jboss.org/
community/wiki/HowtostartRichFacesapplicationwithNetBeansIDE] article in the RichFaces
Cookbook.
Read also the quick overview [http://mkblog.exadel.com/?p=110] to "Practical RichFaces " book
by Max Katz at his blog.
16
Chapter 4. Settings for different environments
17
Chapter 4. Settings for different environments
18
Chapter 4. Settings for different environments
Note:
19
Chapter 4. Settings for different environments
java.sun.com [http://java.sun.com/javaee/javaserverfaces/]
Note:
There are some problems with different filters defined in the web.xml file clashing.
To avoid these problems, the RichFaces filter must be the first one among other
filters in the web.xml configuration file.
There's one more problem while using MyFaces + Seam . If you use this combination you should
use <a4j:page> inside <f:view> (right after it in your code) wrapping another content inside
your pages because of some problems in realization of <f:view> in myFaces.
20
Chapter 4. Settings for different environments
You should also take into account that some JSF frameworks such as Facelets use their
own ViewHandler and need to have it first in the chain of ViewHandlers and the RichFaces
AjaxViewHandler is not an exception. At first RichFaces installs its ViewHandler in any case, so in
case of two frameworks, for example RichFaces + Facelets, no changes in settings are required.
Although, when more then one framework (except RichFaces) is used, it's possible to use the
VIEW_HANDLERS parameter defining these frameworks view handlers according to its usage order
in it. For example, the declaration:
Example:
...
<context-param>
<param-name>org.ajax4jsf.VIEW_HANDLERS</param-name>
<param-value>com.sun.facelets.FaceletViewHandler</param-value>
</context-param>
...
says that Facelets will officially be the first, however AjaxViewHandler will be a little ahead
temporarily to do some small, but very important job.
Note:
In this case you don't have to define FaceletViewHandler in the WEB-INF/faces-
config.xml.
21
Chapter 4. Settings for different environments
version="2.4">
<filter>
<display-name>RichFaces Filter</display-name>
<filter-name>richfaces</filter-name>
<filter-class>org.ajax4jsf.Filter</filter-class>
</filter>
<filter-mapping>
<filter-name>richfaces</filter-name>
<url-pattern>*.seam</url-pattern>
</filter-mapping>
<listener>
<listener-class>org.jboss.seam.servlet.SeamListener</listener-class>
</listener>
<servlet>
<servlet-name>Seam Resource Servlet</servlet-name>
<servlet-class>org.jboss.seam.servlet.ResourceServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Seam Resource Servlet</servlet-name>
<url-pattern>/seam/resource/*</url-pattern>
</servlet-mapping>
<filter>
<filter-name>Seam Filter</filter-name>
<filter-class>org.jboss.seam.web.SeamFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>Seam Filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
22
Chapter 4. Settings for different environments
<listener-class>org.apache.myfaces.webapp.StartupServletContextListener</listener-
class>
</listener>
<context-param>
<param-name>javax.faces.STATE_SAVING_METHOD</param-name>
<param-value>client</param-value>
</context-param>
<context-param>
<param-name>javax.faces.DEFAULT_SUFFIX</param-name>
<param-value>.xhtml</param-value>
</context-param>
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.seam</url-pattern>
</servlet-mapping>
</web-app>
Seam 2 supports RichFaces Filter. Thus your web.xml for Seam 2 must be like this:
<context-param>
<param-name>org.ajax4jsf.VIEW_HANDLERS</param-name>
<param-value>com.sun.facelets.FaceletViewHandler</param-value>
</context-param>
23
Chapter 4. Settings for different environments
<listener>
<listener-class>org.jboss.seam.servlet.SeamListener</listener-class>
</listener>
<servlet>
<servlet-name>Seam Resource Servlet</servlet-name>
<servlet-class>org.jboss.seam.servlet.SeamResourceServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Seam Resource Servlet</servlet-name>
<url-pattern>/seam/resource/*</url-pattern>
</servlet-mapping>
<filter>
<filter-name>Seam Filter</filter-name>
<filter-class>org.jboss.seam.servlet.SeamFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>Seam Filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<context-param>
<param-name>javax.faces.DEFAULT_SUFFIX</param-name>
<param-value>.xhtml</param-value>
</context-param>
<context-param>
<param-name>facelets.DEVELOPMENT</param-name>
<param-value>true</param-value>
</context-param>
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
24
Chapter 4. Settings for different environments
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.seam</url-pattern>
</servlet-mapping>
</web-app>
Only one issue still persists while using Seam with MyFaces. Look at myFaces part of this section.
Detailed information on how to integrate Richfaces and Trinidad and how to hide ".seam"
postfix in the URL you can find in the RichFaces Cookbook article [http://wiki.jboss.org/auth/wiki/
RichFacesWithTrinidad]
Example:
...
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>0</load-on-startup>
</servlet>
...
This is because, EAServer calls servlet init() before the ServletContextInitializer. Not an
EAServer bug, this is in Servlet 2.3 spec.
...
<imported-shared-libraries>
<remove-inherited name="oracle.xml"/>
<remove-inherited name="oracle.xml.security"/>
25
Chapter 4. Settings for different environments
</imported-shared-libraries>
...
26
Chapter 5. Basic concepts of the RichFaces
Framework
RichFaces allows to define (by means of JSF tags) different parts of a JSF page you wish to
update with an Ajax request and provide a few options to send Ajax requests to the server. Also
27
Chapter 5. Basic concepts of the RichFaces
Framework
JSF page doesn't change from a "regular" JSF page and you don't need to write any JavaScript
or XMLHTTPRequest objects by hands, everything is done automatically.
Ajax Filter. To get all benefits of RichFaces , you should register a Filter in web.xml file of
your application. The Filter recognizes multiple request types. Necessary information about Filter
configuration can be found in the "Filter configuration" section. The sequence diagram on Figure
3 shows the difference in processing of a "regular" JSF request and an Ajax request.
28
Chapter 5. Basic concepts of the RichFaces
Framework
In the first case the whole JSF tree will be encoded, in the second one option it depends on the
"size" of the Ajax region. As you can see, in the second case the filter parses the content of an
Ajax response before sending it to the client side.
In both cases, the information about required static or dynamic resources that your application
requests is registered in the ResourseBuilder class.
When a request for a resource comes (Figure 4), the RichFaces filter checks the Resource Cache
for this resource and if it is there, the resource is sent to the client. Otherwise, the filter searches for
29
Chapter 5. Basic concepts of the RichFaces
Framework
the resource among those that are registered by the ResourceBuilder. If the resource is registered,
the RichFaces filter will send a request to the ResourceBuilder to create (deliver) the resource.
AJAX Containers. AjaxContainer is an interface that describes an area on your JSF page that
should be decoded during an Ajax request. AjaxViewRoot and AjaxRegion are implementations
of this interface.
JavaScript Engine. RichFaces JavaScript Engine runs on the client-side. It knows how to
update different areas on your JSF page based on the information from the Ajax response. Do
not use this JavaScript code directly, as it is available automatically.
30
Chapter 5. Basic concepts of the RichFaces
Framework
A good example that can illustrate this feature is rendering of the tabs of the <rich:tabPanel>. By
default the component updates the whole page to display the content of the tab which is clicked
on, to enable partial rendering the "switchType" attribute set to "ajax" should be used.
...
<rich:tabPanel switchType="ajax">
<rich:tab label="Tab 1">
Content of Tab 1
</rich:tab>
<rich:tab label="Tab 2">
Content of Tab 2
</rich:tab>
<rich:tab label="Tab 3">
Content of Tab 3
</rich:tab>
</rich:tabPanel>
...
For more information about framework and libraries loading see the following section in the FAQ
[http://www.jboss.org/community/wiki/Commonclientside#resourcesfromjars].
Note:
In order to prevent JavaScript versions conflict you should use only one version of
the framework or library. You could find more information about libraries exclusion
in the FAQ [http://www.jboss.org/community/wiki/Commonclientside#jsconflicts].
31
Chapter 5. Basic concepts of the RichFaces
Framework
• Any Ajax framework should not append or delete, but only replace elements on the page. For
successful updates, an element with the same ID as in the response must exist on the page.
If you'd like to append any code to a page, put in a placeholder for it (any empty element). For
the same reason, it's recommended to place messages in the "AjaxOutput" component (as
no messages is also a message).
• Don't use <f:verbatim> for self-rendered containers, since this component is transient and
not saved in the tree.
• Ajax requests are made by XMLHTTPRequest functions in XML format, but this XML bypasses
most validations and the corrections that might be made in a browser. Thus, create only a strict
standards-compliant code for HTML and XHTML, without skipping any required elements or
attributes. Any necessary XML corrections are automatically made by the XML filter on the
server, but lot's of unexpected effects can be produced by an incorrect HTML code.
• The RichFaces ViewHandler puts itself in front of the Facelets ViewHandlers chain.
• RichFaces components uses their own renderers. On the Render Response Phase RichFaces
framework makes a traversal of the component tree, calls its own renderer and put the result
into the Faces Response.
"reRender" is a key attribute. The attribute allows to point to area(s) on a page that should be
updated as a response on Ajax interaction. The value of the "reRender" attribute is an id of the
JSF component or an id list.
...
<a4j:commandButton value="update" reRender="infoBlock"/>
...
<h:panelGrid id="infoBlock">
32
Chapter 5. Basic concepts of the RichFaces
Framework
...
</h:panelGrid>
...
The value of "reRender" attribute of the <a4j:commandButton> tag defines which part(s) of your
page is (are) to be updated. In this case, the only part of the page to update is the <h:panelGrid>
tag because its ID value matches to the value of "reRender" attribute. As you see, it's not difficult
to update multiple elements on the page, only list their IDs as the value of "reRender" .
...
<h:form id="form1">
...
<a4j: commandButton value="Usual Way" reRender="infoBlock, infoBlock2" />
<a4j:commandButton value="Shortcut" reRender=":infoBlockl,:sv:infoBlock2" />
...
</h:form>
<h:panelGrid id="infoBlock">
...
</h:panelGrid>
...
<f:subview id="sv">
<h:panelGrid id="infoBlock2">
...
</h:panelGrid>
...
</f:subview>
...
It's also possible to use JSF EL expression as a value of the reRender attribute. It might be a
property of types Set, Collection, Array or simple String. The EL for reRender is resolved right
before the Render Response phase. Hence, you can calculate what should be re-rendered on
any previous phase during the Ajax request processing.
Most common problem with using reRender is pointing it to the component that has a "rendered"
attribute. Note, that JSF does not mark the place in the browser DOM where the outcome of the
33
Chapter 5. Basic concepts of the RichFaces
Framework
component should be placed in case the "rendered" condition returns false. Therefore, after the
component becomes rendered during the Ajax request, RichFaces delivers the rendered code to
the client, but does not update a page, because the place for update is unknown. You need to
point to one of the parent components that has no "rendered" attribute. As an alternative, you
can wrap the component with <a4j:outputPanel> layout="none" .
"ajaxRendered" attribute of the <a4j:outputPanel> set to "true" allows to define the area of the
page that will be re-rendered even if it is not pointed in the reRender attribute explicitly. It might be
useful if you have an area on a page that should be updated as a response on any Ajax request.
For example, the following code allows to output error messages regardless of what Ajax request
causes the Validation phase failed.
...
<a4j:outputPanel ajaxRendered="true">
<h:messages />
</a4j:outputPanel>
...
...
<h:form>
<h:inputText value="#{person.name}">
<a4j:support event="onkeyup" reRender="test" limitToList="true"/>
</h:inputText>
<h:outputText value="#{person.name}" id="test"/>
</form>
...
"eventsQueue" attribute defines the name of the queue that will be used to order upcoming
Ajax requests. By default, RichFaces does not queue Ajax requests. If events are produced
simultaneously, they will come to the server simultaneously. JSF implementations (especially, the
very first ones) does not guaranty that the request that comes first will be served or passed into
the JSF lifecycle first. The order how the server-side data will be modified in case of simultaneous
request might be unpredictable. Usage of eventsQueue attribute allows to avoid possible mess.
Define the queue name explicitly, if you expect intensive Ajax traffic in your application.
34
Chapter 5. Basic concepts of the RichFaces
Framework
The next request posted in the same queue will wait until the previos one is not processed and
Ajax Response is returned back if the "eventsQueue" attribute is defined. In addition, RichFaces
starts to remove from the queue "similar" requests. "Similar'"requests are the requests produced
by the same event. For example, according to the following code, only the newest request will be
sent to the server if you type very fast and has typed the several characters already before the
previous Ajax Response is back.
...
<h:inputText value="#{userBean.name}">
<a4j:support event="onkeyup" eventsQueue="foo" reRender="bar" />
</h:inputText>
...
"requestDelay" attribute defines the time (in ms) that the request will be wait in the queue before
it is ready to send. When the delay time is over, the request will be sent to the server or removed
if the newest "similar" request is in a queue already .
"ignoreDupResponses" attribute orders to ignore the Ajax Response produced by the request
if the newest "similar" request is in a queue already. ignoreDupResponses"="true" does not
cancel the request while it is processed on the server, but just allows to avoid unnecessary updates
on the client side if the response loses the actuality.
Defining the "eventsQueue" along with "requestDelay" allows to protect against unnecessary
traffic flood and synchronizes Ajax requests order. If you have several sources of Ajax requests,
you can define the same queue name there. This might be very helpful if you have Ajax
components that invoke request asynchronously from the ones produced by events from users.
For example, <a4j:poll> or <a4j:push> . In case the requests from such components modify
the same data, the synchronization might be very helpful.
"timeout" attribute is used for setting response waiting time on a particular request. If a response
is not received during this time, the request is aborted.
There are some reasons why the queue has been improved. In previous versions the queue had
quite simple implementation: it sent to the server only the last Ajax request out of all requests
coming in the queue during request delay.
35
Chapter 5. Basic concepts of the RichFaces
Framework
• Eliminate the possibility of collisions when several JSF requests pass the JSF lifecycle at the
same time. The queue prevents sending such requests. Only one request is processed. The
rest ones are waiting.
• Reduce the traffic between browser and the server. The "similar" requests came within request
delay are absorbed. Only the last one is actually sent. Reducing the number of request reduces
the server load.
In this section we will take a closer look at the listed above types of the queue and see in more
detail how they differ. Usage details are covered in the <a4j:queue> chapter.
Design details
If you define more than one with this name while attempting to set its attributes a warning will
appear in server console during rendering. All the same named queues after the first instance
are ignored.
Global default queue has application scope and is defined in the web.xml
...
<context-param>
<param-name>org.richfaces.queue.global.enabled</param-name>
<param-value>true</param-value>
</context-param>
...
The global default queue is disabled by default, because artificial serializing of all Ajax requests
on a page can significantly affect expected behavior. The global default queue causes all
36
Chapter 5. Basic concepts of the RichFaces
Framework
Asynchronous JavaScript And XML requests becoming synchronous via the single global queue.
If the global queue is turned on it can change the behavior on all views of the application without
any visible or obvious setting.
Design details
• Only one default queue is ever active at one time for a given view or form.
• If ever more are detected a warning will appears in server console during rendering. All the
same named queues after the first instance are ignored.
• View scoped default queue is also created for components which have the following Ajax
attributes: (in this case queue has a component scope)
• "requestDelay"
• "ignoreDupResponce"
• View scoped default queue is created automatically if the "eventsQueue" attribute is defined
with some name in a component but not found in the view. It has a scope the same as defined
in corresponding context param.
The view scoped default, named and formed-based types of queue utilize the <a4j:queue> tag
to override the settings of the global queue defined in the web.xml file.
You can also programmatically enable/disable the global queue on a single view using the
following:
...
<a4j:queue name="org.richfaces.queue.global" disabled="true"... />
...
Hence, to enable the queue for a single view page you need to define the "disable" attribute with
"false".
Now, you can override the default settings using the attributes of the <a4j:queue> component.
The full list of attributes [file:///C:/Projects/RichFaces/docs/userguide/en/target/docbook/publish/
en-US/html_single/index.html#d0e10019] is given in the "6.20. <a4j:queue>" chapter of the guide.
Example:
...
<a4j:queue name="org.richfaces.queue.global" requestDelay="1000" />
37
Chapter 5. Basic concepts of the RichFaces
Framework
...
View scoped queue can be also added by just definition of the queue without name specified.
In this case it should be placed anywhere outside the forms in order not to be recognized as a
form-based queue.
...
<a4j:queue ... />
...
• Named queues must have a unique name, if a second queue with the same name is defined
all the same named queues after the first instance are ignored.
• Form elements are used as naming container for the queue i.e. custom queue defined within
the form cannot be used by the components outside this concrete form.
You can reference a named queue from any Ajax4JSF or RichFaces component that supports
the "eventsQueue" attribute. Below there is an example of how the components can reference
a named queue.
Example:
...
<a4j:queue name="sampleQueue"/>
<h:inputText value="#{bean.inputValue}" >
<a4j:support id="inputSupport" event="onkeyup" eventsQueue="sampleQueue"/>
</h:inputText>
<rich:comboBox
value="#{bean.state}"
suggestionValues="#{bean.suggestions}"
eventsQueue="sampleQueue"
/
>
...
• Only one enabled form based default queue can be active at a time.
38
Chapter 5. Basic concepts of the RichFaces
Framework
• A warning appears in server console during rendering if more than one enabled form based
queue exists. All queues with the same name after the first instance should be ignored.
• Users can define more than one form queue, however all but one must be disabled.
Queues are often used within forms, but defining the "eventsQueue" attribute on every component
within a form can be tedious work. To avoid that you can create a default queue for a form
(overriding the global default queue ).
Example:
...
<h:form ... >
<a4j:queue ... /><!-- note no name specified -->
...
</h:form>
...
Though, using an Ajax4JSF <a4j:form> you can refrence a named queue via the "eventsQueue".
Example:
...
<a4j:form eventsQueue="fooQueue" ...>
...
</a4j:form>
...
However the implementation of the queue allows you to reference a named queue from the form
with a form-based queue.
Example:
...
<a4j:queue name="sampleQueue" ... /> <!-- named queue -->
...
<h:form ... >
<a4j:queue ... /><!-- form-based queue-->
<a4j:commandButton ... /> <!-- uses the form-based queue -->
<a4j:commandButton eventsQueue="sampleQueue" /> <!-- uses named queue -->
</h:form>
39
Chapter 5. Basic concepts of the RichFaces
Framework
...
By default all the events raised by the same component are similar to the queue (according to
client Id of event source). This means that if new requests come from the same component they
are combined with the previous ones. For example: if we use a4j:support on an input field and
the user types frequently all the request raised by key up during requestDelay will be combined
into one.
You can also manually specify multiple components which will produce similar requests. The
"similarityGroupingId" attribute is added to all the Ajax action components with 3.3.0 release.
Hence, for example, you can add two <a4j:support/> components to the input (one for key up
and the second for blur) and define that request events are similar by specifying the same
"similarityGroupingId".
As written above requests are collected in the queue during requestDelay and similar ones are
combined. But similar requests can only be combined if they are raised sequentially. This is done
in order not to block the queue and not to change the requests order.
Example:
1
A request with some delay comes to the queue, let it be A the delay counter for this request is
2
started. If similar request(e.g. from the same component - A ) appears - these two requests are
1 2 combined
combined(A A to A ) and the counter is reset.
1 combined 1
But if some not similar request comes to the queue B - it is placed after the first one(A ,B ).
combined 3
And if the A request doesn't exit the queue and another request similar to A (let is be A )
appears again - these requests are not combined with the first one. The request is placed after
1 combined 1 3
B . (A , B , A ).
• not to block the queue if the different types of requests comes to queue and should wait one
for another
The <a4j:poll> component has delay time 0 by default staring from 3.3.0 version in order not
to use the queue delay(its own value for this parameter redefines queue's parameter) to avoid
blocking periodical update in the queue. You can redefine this on the component level if need.
40
Chapter 5. Basic concepts of the RichFaces
Framework
When "ajaxSingle" attribute value is "true" , it orders to include only a value of the current
component (along with <f:param> or <a4j:actionparam> values if any) to the request map. In
case of <a4j:support> , it is a value of the parent component. An example is placed below:
...
<h:form>
<h:inputText value="#{person.name}">
<a4j:support event="onkeyup" reRender="test" ajaxSingle="true"/>
</h:inputText>
<h:inputText value="#{person.middleName}"/>
</form>
...
In this example the request contains only the input component causes the request generation, not
all the components contained on a form, because of ajaxSingle="true" usage.
Note, that ajaxSingle="true" reduces the upcoming traffic, but does not prevent decoding other
input components on the server side. Some JSF components, such as <h:selectOneMenu> do
recognize the missing data in the request map value as a null value and try to pass the validation
process with a failed result. Thus, use <a4j:region> to limit a part of the component tree that will
be processed on the server side when it is required.
"immediate" attribute has the same purpose as any other non-JSF component. The default
"ActionListener" should be executed immediately (i.e. during the Apply Request Values phase
of a request processing lifecycle), rather than waiting until the Invoke Application phase. Using
immediate="true" is one of the ways to have some data model values updated when other
cannot be updated because of a problem with passing the Validation phase successfully. This
might be important inside the <h:dataTable> like components where using <a4j:region> is
impossible due to the <h:dataTable> component architecture.
41
Chapter 5. Basic concepts of the RichFaces
Framework
"bypassUpdates" attribute allows to bypass the Update Model phase. It might be useful if you need
to check your input against the available validator, but not to update the model with those data.
Note, that an action will be invoked at the end of the Validation phase only if the Validation phase
is passed successfully. The listeners of the Application phase will not be invoked in any case.
"action" method must return null if you want to have an Ajax Response with a partual page update.
This is regular mode called "Ajax request generates Non-Ajax Response". In case of action
does not return null, but the action outcome that matches one of navigation rules, RichFaces starts
to work in "Ajax request generates Non-Ajax Response" mode. This mode might be helpful
in two major cases:
• RichFaces allows to organize a page flow inside the <a4j:include> component. This is a typical
scenario for Wizard like behavior. The new content is rendered inside the <a4j:include> area.
The content is taken from the navigation rule of the faces configuration file (usually, the faces-
config.xml). Note, that the content of the "wizard" is not isolated from the rest of the page. The
included page should not have own <f:view> (it does not matter if you use facelets). You need
to have an Ajax component inside the <a4j:include> to navigate between the wizard pages.
Otherwize, the whole page update will be performed.
• If you want to involve the server-side validators and navigate to the next page only if
the Validation phase is passed successfully, you can replace <h:commandButton> with
<a4j:commandButton> and point to the action method that navigates to the next page. If
Validation process fails, the partial page update will occur and you will see an error message.
Otherwize, the application proceeds to the next page. Make sure, you define <redirect/> option
for the navigation rule to avoid memory leaks.
"onsubmit" attribute allows to invoke JavaScript code before an Ajax request is sent. If "onsubmit"
returns "false" , the Ajax request is canceled. The code of "onsubmit" is inserted before the
RichFaces Ajax call. Hence, the "onsubmit" should not has a "return" statement if you want
the Ajax request to be sent. If you are going to invoke a JavaScript function that returns "true"
or "false" , use the conditional statement to return something only when you need to cancel the
request. For example:
...
42
Chapter 5. Basic concepts of the RichFaces
Framework
"onclick" attribute is similar to the "onsubmit" , but for clickable components such as
<a4j:commandLink> and <a4j:commandButton> . If it returns "false" , the Ajax request is
canceled also.
The "oncomplete" attribute is used for passing JavaScript that would be invoked right after the
Ajax response returns back and DOM is updated. It is not recommended to use use keyword this
inside the EL-expression, because it will not always point to the component where Ajax request
was initiated.
"onbeforedomupdate" attribute defines JavaScript code for call after Ajax response receiving and
before updating DOM on a client side.
"data" attribute allows to get the additional data from the server during an Ajax call. You can use
JSF EL to point the property of the managed bean and its value will be serialized in JSON format
and be available on the client side. You can refer to it using the "data" variable. For example:
...
<a4j:commandButton
value="Update"
data="#{userBean.name}"
oncomplete="showTheName(data.name)"
/
>
...
RichFaces allows to serialize not only primitive types into JSON format, but also complex types
including arrays and collections. The beans should be serializable to be refered with "data" .
• rich:clientId('id') - returns client id by short id or null if the component with the id specified
hasn't been found
...
<h:inputText id="myInput">
<a4j:support event="onkeyup" reRender="outtext"/>
</h:inputText>
<h:outputText id="outtext" value="#{rich:findComponent('myInput').value}" />
43
Chapter 5. Basic concepts of the RichFaces
Framework
...
...
<a4j:poll intervall="1000" action="#{repeater.action}" reRender="text">
<table>
<tbody>
<a4j:repeat value="#{bean.props}" var="detail" ajaxKeys="#{repeater.ajaxedRowsSet}">
<tr>
<td>
<h:outputText value="detail.someProperty" id="text"/>
</td>
</tr>
</a4j:repeat>
</tbody>
</table>
</a4j:poll>
...
...
<a4j:region id="extr">
<h:form>
<h:outputText value="Status:" />
<a4j:status id="commonstatus" startText="In Progress...." stopText=""/>
<h:panelGrid columns="2">
<h:outputText value="Name"/>
<h:inputText id="name" value="#{userBean.name}">
<a4j:support event="onkeyup" reRender="out" />
</h:inputText>
<h:outputText value="Job"/>
<a4j:region id="intr">
44
Chapter 5. Basic concepts of the RichFaces
Framework
Other useful attribute is "focus" . It points to an ID of a component where focus will be set after
an Ajax request.
45
Chapter 5. Basic concepts of the RichFaces
Framework
<rich:panelMenuGroup>
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
<rich:toggleControl>
<rich:toolTip>
<rich:calendar>
<rich:fileUpload>
<rich:suggestionbox>
bypassUpdates If "true", after process <a4j:form> <rich:dataFilterSlider>
validations phase it
of <a4j:support> <rich:datascroller>
skips updates
model beans on <a4j:commandButton> <rich:scrollableDataTable>
a force render
response. It can be <a4j:commandLink> <rich:dropSupport>
used for validating
<a4j:jsFunction> <rich:menuItem>
components input
<a4j:poll> <rich:tree>
<a4j:push> <rich:treeNode>
<rich:panelMenuGroup>
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:calendar>
<rich:suggestionbox>
limitToList If "true", then of <a4j:form> <rich:ajaxValidator>
all AJAX-rendered on
the page components <a4j:support> <rich:dataFilterSlider>
46
Chapter 5. Basic concepts of the RichFaces
Framework
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
<rich:toggleControl>
<rich:calendar>
<rich:suggestionbox>
reRender Id['s] (in format of call <a4j:form> <rich:ajaxValidator>
UIComponent.findComponent())
components, <a4j:support> <rich:dataFilterSlider>
of
rendered in case of <a4j:commandButton> <rich:datascroller>
AjaxRequest caused
by this component. <a4j:commandLink> <rich:dataTable>
Can be single id,
<a4j:jsFunction> <rich:extendedDataTable>
comma-separated list
of Id's, or EL <a4j:poll> <rich:scrollableDataTable>
Expression with array
or Collection <a4j:push> <rich:dragSupport>
<rich:dropSupport>
<rich:menuItem>
<rich:tree>
<rich:treeNode>
<rich:panelMenuGroup>
47
Chapter 5. Basic concepts of the RichFaces
Framework
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
<rich:calendar>
<rich:suggestionbox>
process Id['s] (in format of call <a4j:form> <rich:dataFilterSlider>
UIComponent.findComponent())
components, <a4j:support> <rich:datascroller>
of
processed at the <a4j:commandButton> <rich:dropSupport>
phases 2-5 in case of
AjaxRequest caused <a4j:commandLink> <rich:menuItem>
by this component.
<a4j:jsFunction> <rich:tree>
Can be single id,
comma-separated list <a4j:poll> <rich:treeNode>
of Id's, or EL
Expression with array <a4j:push> <rich:panelMenuGroup>
or Collection
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
<rich:toggleControl>
<rich:calendar>
<rich:suggestionbox>
status ID (in format of call <a4j:form> <rich:ajaxValidator>
UIComponent.findComponent())
of Request status <a4j:support> <rich:dataFilterSlider>
<a4j:commandLink> <rich:scrollableDataTable>
<a4j:jsFunction> <rich:dragSupport>
<a4j:poll> <rich:dropSupport>
48
Chapter 5. Basic concepts of the RichFaces
Framework
<a4j:queue> <rich:treeNode>
<rich:panelMenuGroup>
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
<rich:toggleControl>
<rich:calendar>
<rich:fileUpload>
<rich:suggestionbox>
eventsQueue Name of requests <a4j:form> <rich:ajaxValidator>
queue to avoid send
next request before <a4j:support> <rich:dataFilterSlider>
<rich:tree>
<rich:panelMenuGroup>
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
<rich:toggleControl>
<rich:calendar>
49
Chapter 5. Basic concepts of the RichFaces
Framework
<rich:tree>
<rich:panelMenuGroup>
<rich:panelMenuItem>
<rich:simpleTogglePanel>
<rich:tab>
<rich:calendar>
<rich:suggestionbox>
data Serialized (on default <a4j:form> <rich:ajaxValidator>
with JSON) data
passed on the client <a4j:support> <rich:dataFilterSlider>
<a4j:poll> <rich:menuItem>
<a4j:push> <rich:tree>
<rich:treeNode>
<rich:paint2D>
<rich:panelMenuGroup>
<rich:panelMenuItem>
50
Chapter 5. Basic concepts of the RichFaces
Framework
<rich:simpleTogglePanel>
<rich:tab>
<rich:toggleControl>
<rich:calendar>
ignoreDupResponses Attribute
allows to <a4j:form> <rich:ajaxValidator>
ignore an Ajax
Response produced <a4j:support> <rich:dataFilterSlider>
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
<rich:toggleControl>
<rich:calendar>
<rich:suggestionbox>
timeout Response waiting <a4j:form> <rich:ajaxValidator>
time on a particular
request. If a response <a4j:form> <rich:dataFilterSlider>
51
Chapter 5. Basic concepts of the RichFaces
Framework
<a4j:jsFunction> <rich:dropSupport>
<a4j:poll> <rich:menuItem>
<a4j:push> <rich:tree>
<a4j:queue> <rich:treeNode>
<rich:panelMenuGroup>
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
<rich:toggleControl>
<rich:suggestionbox>
similarityGroupingId If there are any <a4j:form> <rich:ajaxValidator>
component requests
with identical IDs then <a4j:support> <rich:dataFilterSlider>
<a4j:jsFunction> <rich:dragSupport>
<a4j:poll> <rich:dropSupport>
<rich:menuItem>
<rich:tree>
<rich:treeNode>
<rich:panelMenuGroup>
<rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tab>
52
Chapter 5. Basic concepts of the RichFaces
Framework
<rich:calendar>
<rich:suggestionbox>
<rich:message>
<rich:messages>
keepTransient Flag for mark all child <a4j:include>
components to non-
transient. If "true", all <a4j:outputPanel>
children components
will be set to
non-transient state
and keep in saved
components tree. For
output in self-renderer
region all content (By
default, all content in
<f:verbatim> tags and
non-jsf elements in
facelets, marked as
transient - since, self-
rendered ajax regions
don't plain output for
ajax processing). The
default value is "false".
ajaxListener MethodExpression <a4j:include>
representing an action
listener method that <a4j:outputPanel>
will be notified when
this component is
activated by the ajax
Request and handle it.
The expression must
evaluate to a public
method that takes an
AjaxEvent parameter,
with a return type of
void.
selfRendered if "true", self- <a4j:page> <rich:suggestionbox>
render subtree at
InvokeApplication ( or <a4j:region>
53
Chapter 5. Basic concepts of the RichFaces
Framework
<a4j:page> <rich:panelMenuGroup>
<a4j:htmlCommandLink><rich:panelMenuItem>
<rich:progressBar>
<rich:simpleTogglePanel>
<rich:tabPanel>
<rich:tab>
<rich:togglePanel>
<rich:toggleControl>
<rich:toolTip>
<rich:calendar>
<rich:colorPicker>
<rich:comboBox>
<rich:editor>
<rich:inplaceInput>
<rich:inplaceSelect>
<rich:inputNumberSlider>
54
Chapter 5. Basic concepts of the RichFaces
Framework
<rich:suggestionbox>
<rich:listShuttle>
<rich:orderingList>
<rich:pickList>
mode Defines the <rich:panelMenu>
submission type: Ajax
<rich:panelMenuItem>
or Sever
<rich:progressBar>
<rich:toolTip>
<rich:calendar>
switchType Defines the re- <rich:simpleTogglePanel>
rendering mode: Ajax,
<rich:tabPanel>
server, client.
<rich:tab>
<rich:togglePanel>
<rich:tree>
<rich:simpleTogglePanel>
There are different ways to send Ajax requests from your JSF page. For example you can use
<a4j:commandButton> , <a4j:commandLink> , <a4j:poll> or <a4j:support> tags or any
other.
All these tags hide the usual JavaScript activities that are required for an XMHTTPRequest object
building and an Ajax request sending. Also, they allow you to decide which components of your
JSF page are to be re-rendered as a result of the Ajax response (you can list the IDs of these
components in the "reRender" attribute).
55
Chapter 5. Basic concepts of the RichFaces
Framework
The <a4j:support> tag allows you to add Ajax functionality to standard JSF components and
send Ajax request onto a chosen JavaScript event: "onkeyup" , "onmouseover" , etc.
The easiest way to describe an Ajax region on your JSF page is to do nothing, because the content
between the <f:view> and </f:view> tags is considered the default Ajax region.
You may define multiple Ajax regions on the JSF page (they can even be nested) by using the
<a4j:region> tag.
If you wish to render the content of an Ajax response outside of the active region then the value
of the "renderRegionOnly" attribute should be set to "false" ("false" is default value). Otherwise,
your Ajax updates are limited to elements of the active region.
But you can not use this approach if your page contains, e.g. a <f:verbatim> tag and you wish
to update its content on an Ajax response.
The problem with the <f:verbatim/> tag as described above is related to the value of the
transientFlag of JSF components. If the value of this flag is true, the component must not
participate in state saving or restoring of process.
In order to provide a solution to this kind of problems, RichFaces uses the concept of an output
panel that is defined by the <a4j:outputPanel> tag. If you put a <f:verbatim> tag inside of the
output panel, then the content of the <f:verbatim/> tag and content of other panel's child tags
could be updated on Ajax response. There are two ways to control this:
• By setting the "reRender" attribute value of an Action Component to the output panel ID.
You could make use of the "process" attribute when you need to process only two components
in the different parts of view.
Imagine you need to process only two input fields but not all the view. If you wrap the first input
to region or make <a4j:support> component with ajaxSingle="true" nested the second input
will not be processed.
56
Chapter 5. Basic concepts of the RichFaces
Framework
...
<h:inputText value="#{bean.name}" id="name">
<a4j:support ajaxSingle="true" process="email" event="onblur" reRender="someOut"/>
</h:inputText>
<h:inputTextarea value="#{bean.description}" id="desc" />
<h:inputText value="#{bean.email}" id="email">
<a4j:support ajaxSingle="true" process="name" event="onblur" reRender="someOut"/>
</h:inputText>
...
In the example above when the input field with the id="name" looses focus, an Ajax request is
sent. So only two input fields (with id="name" and additionally with id="email") are processed:
decoding, conversion/validation, value applying phases are executed. The input field with the
id="email" is handled the same way on blur event.
An example of how to set a Filter in a web.xml file of your application is placed below.
Example:
...
<filter>
<display-name>RichFaces Filter</display-name>
<filter-name>richfaces</filter-name>
<filter-class>org.ajax4jsf.Filter</filter-class>
</filter>
...
Note:
Fast Filter is deprecated and available only for backward compatibility with previous
RichFaces versions. Fast Filter usage isn't recomended, because there is another
way to use its functionality by means of Neko filter type [58] .
57
Chapter 5. Basic concepts of the RichFaces
Framework
From RichFaces 3.2 filter configuration becomes more flexible. It's possible to configure different
filters for different sets of pages for the same application.
• TIDY
"TIDY" filter type based on the Tidy parser. This filter is recommended for applications with
complicated or non-standard markup when all necessary code corrections are made by the filter
when a response comes from the server.
• NEKO
"NEKO" filter type corresponds to the former "Fast Filter" and it's based on the Neko parser. In
case of using this filter code isn't strictly verified. Use this one if you are sure that your application
markup is really strict for this filter. Otherwise it could cause lot's of errors and corrupt a layout as
a result. This filter considerably accelerates all Ajax requests processing.
• NONE
No correction.
Example:
...
<context-param>
<param-name>org.ajax4jsf.xmlparser.ORDER</param-name>
<param-value>NONE,NEKO,TIDY</param-value>
</context-param>
<context-param>
<param-name>org.ajax4jsf.xmlparser.NONE</param-name>
<param-value>/pages/performance\.xhtml,/pages/default.*\.xhtml</param-value>
</context-param>
<context-param>
<param-name>org.ajax4jsf.xmlparser.NEKO</param-name>
<param-value>/pages/repeat\.xhtml</param-value>
</context-param>
<filter>
<display-name>RichFaces Filter</display-name>
<filter-name>richfaces</filter-name>
<filter-class>org.ajax4jsf.Filter</filter-class>
</filter>
<filter-mapping>
<filter-name>richfaces</filter-name>
<servlet-name>Faces Servlet</servlet-name>
58
Chapter 5. Basic concepts of the RichFaces
Framework
<dispatcher>FORWARD</dispatcher>
<dispatcher>REQUEST</dispatcher>
<dispatcher>INCLUDE</dispatcher>
</filter-mapping>
...
The example shows that ORDER parameter defines the order in which particular filter types are
used for pages code correction.
First of all "NONE" type is specified for the filter. Then two different sets of pages are defined for
which two filter types (NONE and NEKO) are used correspondingly. If a page relates to the first
set that is defined in the following way:
<param-value>/pages/performance\.xhtml,/pages/default.*\.xhtml</param-value>
it's not corrected, because filter type for this page is defined as "NONE". If a page is not from the
first set, then "NEKO" type is set.
If a page relates to the second set that is defined in the following way:
<param-value>/pages/repeat\.xhtml</param-value>
then "NEKO" filter type is used for correction. If it's not related to the second set, "TIDY" type is
set for the filter ("TIDY" filter type is used for code correction).
org.richfaces.LoadScriptStrategy
The following declaration in your web.xml allows loading the integrated script files.
...
<context-param>
<param-name>org.richfaces.LoadScriptStrategy</param-name>
<param-value>ALL</param-value>
</context-param>
...
59
Chapter 5. Basic concepts of the RichFaces
Framework
...
<context-param>
<param-name>org.richfaces.LoadScriptStrategy</param-name>
<param-value>DEFAULT</param-value>
</context-param>
...
The third possible value is "NONE". You have no a special reason to use it unless you obtain the
newest (or modified) version of the script and want to include it manually in a page header.
org.richfaces.LoadStyleStrategy
The following declaration allows to load only one integrated style sheet file.
...
<context-param>
<param-name>org.richfaces.LoadStyleStrategy</param-name>
<param-value>ALL</param-value>
</context-param>
...
The integrated style sheet contains style for all shipped components. The skinnability feature still
works.
The "NONE" stops loading the styles at all. The earlier introduced plain skin resets all color and
font parameters to null. The "NONE" value for org.richfaces.LoadStyleStrategy means that
predefined styles for RichFaces are not used.
<context-param>
<param-name>org.ajax4jsf.handleViewExpiredOnClient</param-name>
60
Chapter 5. Basic concepts of the RichFaces
Framework
<param-value>true</param-value>
</context-param>
Thus, it's possible to create your own handler that is called on timeouts, internal server errors,
and etc.
Example:
61
Chapter 5. Basic concepts of the RichFaces
Framework
Note:
Note that custom "onError", "onExpire" handlers do not work under MyFaces.
MyFaces handles exception by its internals generating debug page. You could use
the following code to prevent such behavior:
...
<context-param>
<param-name>org.apache.myfaces.ERROR_HANDLING</param-name>
<param-value>false</param-value>
</context-param>
...
5.11. Skinnability
Hence, if you want to change the application palette, you have to change all interrelating values,
otherwise your interface can appear a bit clumsy. The chances of such an interface coming
about is very high, as CSS editing usually becomes the duty of a general developer who doesn't
necessarily have much knowledge of user interface design.
Moreover, if a customer wishes to have an interface look-and-feel that can be adjusted on-the-fly
by an end user, your work is multiplied, as you have to deal with several CSS files variants, each
of which contains the same values repeated numerous times.
These problems can be solved with the skinnability system built into the RichFaces project and
implemented fully in RichFaces. Every named skin has some skin-parameters for the definition of
a palette and the other parameters of the user interface. By changing just a few parameters, you
can alter the appearance of dozens of components in an application in a synchronized fashion
without messing up user interface consistency.
The skinnability feature can't completely replace standard CSS and certainly doesn't eliminate
its usage. Skinnability is a high-level extension of standard CSS, which can be used together
62
Chapter 5. Basic concepts of the RichFaces
Framework
with regular CSS declarations. You can also refer to skin parameters in CSS via JSF Expression
Language. You have the complete ability to synchronize the appearance of all the elements in
your pages.
The color scheme of the component can be applied to its elements using any of three style classes:
This contains style parameters linked to some constants from a skin. It is defined for every
component and specifies a default representation level. Thus, an application interface could be
modified by changing the values of skin parameters.
This class name is defined for every component element and inserted into the framework to
allow defining a class with the same name into its CSS files. Hence, the appearance of all
components that use this class is extended.
It's possible to use one of the styleClass parameters for component elements and define your
own class in it. As a result, the appearance of one particular component is changed according
to a CSS style parameter specified in the class.
5.11.3. Example
Here is a simple panel component:
Example:
The code generates a panel component on a page, which consists of two elements: a wrapper
<div> element and a <div> element for the panel body with the particular style properties. The
wrapper <div> element looks like:
Example:
63
Chapter 5. Basic concepts of the RichFaces
Framework
It's possible to change all colors for all panels on all pages by changing these skin parameters.
However, if a <rich:panel> class is specified somewhere on the page, its parameters are also
acquired by all panels on this page.
A developer may also change the style properties for a particular panel. The following definition:
Example:
Could add some style properties from customClass to one particular panel, as a result we get
three styles:
Example:
• DEFAULT
• plain
• emeraldTown
• blueSky
64
Chapter 5. Basic concepts of the RichFaces
Framework
• wine
• japanCherry
• ruby
• classic
• deepMarine
To plug one in, it's necessary to specify a skin name in the org.richfaces.SKIN context-param.
Here is an example of a table with values for one of the main skins, "blueSky" .
65
Chapter 5. Basic concepts of the RichFaces
Framework
Skin "plain" was added from 3.0.2 version. It doesn't have any parameters. It's necessary for
embedding RichFaces components into existing projecst which have its own styles.
To get detailed information on particular parameter possibilities, see the chapter where each
component has skin parameters described corresponding to its elements.
• Create a file and define in it skin constants which are used by style classes (see section
"Skin Parameters Tables in RichFaces" ). The name of skin file should correspond to the
following format: <name>.skin.properties . As an example of such file you can see RichFaces
predefined skin parameters (skins): blueSky, classic, deepMarine, etc. These files are located
in the richfaces-impl-xxxxx.jar inside the /META-INF/skins folder.
• Add a skin definition <contex-param> to the web.xml of your application. An example is placed
below:
Example:
...
<context-param>
<param-name>org.richfaces.SKIN</param-name>
<param-value>name</param-value>
</context-param>
...
66
Chapter 5. Basic concepts of the RichFaces
Framework
• Put your <name>.skin.properties file in one of the following classpath elements: META-INF/
skins/ or classpath folder (e.g. WEB-INF/classes).
http://livedemo.exadel.com/richfaces-demo/ [http://livedemo.exadel.com/richfaces-demo/]
You may simply control the look-and-feel of your application by using the skinnability service of the
RichFaces framework. With the means of this service you can define the same style for rendering
standard JSF components and custom JSF components built with the help of RichFaces.
• Create a custom render kit and register it in the faces-config.xml like this:
<render-kit>
<render-kit-id>NEW_SKIN</render-kit-id>
<render-kit-class>org.ajax4jsf.framework.renderer.ChameleonRenderKitImpl</render-kit-
class>
</render-kit>
• Then you need to create and register custom renderers for the component based on the look-
and-feel predefined variables:
<renderer>
<component-family>javax.faces.Command</component-family>
<renderer-type>javax.faces.Link</renderer-type>
<renderer-class>newskin.HtmlCommandLinkRenderer</renderer-class>
</renderer>
• Finally, you need to place a properties file with skin parameters into the class path root. There
are two requirements for the properties file:
• The first line in this file should be render.kit=<render-kit-id> in this case, it would be
called render.kit=NEW_SKIN .
67
Chapter 5. Basic concepts of the RichFaces
Framework
http://java.sun.com/javaee/javaserverfaces/reference/docs/index.html [http://java.sun.com/
javaee/javaserverfaces/reference/docs/index.html]
<context-param>
<param-name>org.richfaces.SKIN</param-name>
<param-value>#{skinBean.skin}</param-value>
</context-param>
Further, it is necessary to set the skin property to the initial value in the configuration file. For
example, "classic":
<managed-bean>
<managed-bean-name>skinBean</managed-bean-name>
<managed-bean-class>SkinBean</managed-bean-class>
<managed-bean-scope>session</managed-bean-scope>
<managed-property>
<property-name>skin</property-name>
<value>classic</value>
</managed-property>
</managed-bean>
68
Chapter 5. Basic concepts of the RichFaces
Framework
You can also change the default skin, for instance, change the default color. To do this, edit the
file properties of the skin. Here is an example of the code for page:
<h:form>
<div style="display: block; float: left">
<h:selectOneRadiovalue="#{skinBean.skin}"border="0"layout="pageDirection"title="Changing
skin" style="font-size: 8; font-family: comic" onchange="submit()">
<f:selectItem itemLabel="plain" itemValue="plain" />
<f:selectItem itemLabel="emeraldTown" itemValue="emeraldTown" />
<f:selectItem itemLabel="blueSky" itemValue="blueSky" />
<f:selectItem itemLabel="wine" itemValue="wine" />
<f:selectItem itemLabel="japanCherry" itemValue="japanCherry" />
<f:selectItem itemLabel="ruby" itemValue="ruby" />
<f:selectItem itemLabel="classic" itemValue="classic" />
<f:selectItem itemLabel="laguna" itemValue="laguna" />
<f:selectItem itemLabel="deepMarine" itemValue="deepMarine" />
<f:selectItem itemLabel="blueSky Modified" itemValue="blueSkyModify" />
</h:selectOneRadio>
</div>
<div style="display: block; float: left">
<rich:panelBar height="100" width="200">
<rich:panelBarItem label="Item 1" style="font-family: monospace; font-size: 12;">
Changing skin in runtime
</rich:panelBarItem>
This is result:
69
Chapter 5. Basic concepts of the RichFaces
Framework
Standard controls skinning feature provides 2 levels of skinning: Standard and Extended. The level
is based on detecting the browser type. If browser type is not identified, Advanced level is used.
However, if you want to explicitly specify the level of skinning you want to be applied, you need
to add a context parameter to your web.xml with org.richfaces.CONTROL_SKINNING_LEVEL as
the parameter name and value set to either basic or extended.
• Internet Explorer 6
• Opera
• Safari
• Extended level extends basic level introducing broader number of style properties and is applied
to browsers with rich visual styling capability of controls
• Mozilla Firefox
70
Chapter 5. Basic concepts of the RichFaces
Framework
• input
• select
• textarea
• keygen
• isindex
• legend
• fieldset
• hr
Example:
...
.rich-container select {
//class content
}
...
• Elements that have class name corresponding to one of the basic elements name/type mapped
by the following scheme rich-<elementName>[-<elementType>] . See the example:
71
Chapter 5. Basic concepts of the RichFaces
Framework
Example:
...
.rich-select {
//class content
}
.rich-input-text {
//class content
}
...
Note:
Elements have classes based on "link" and pseudo class name, e.g.: rich-link,
rich-link-hover, rich-link-visited
Additionally, the predefined rich CSS classes that we provide can be used not only as classes for
basic HTML elements but also as classes for creation of complex elements .
...
<u:selector name=".rich-box-bgcolor-header">
<u:style name="background-color" skin="headerBackgroundColor" />
</u:selector>
<u:selector name=".rich-box-bgcolor-general">
<u:style name="background-color" skin="generalBackgroundColor" />
</u:selector>
...
//gradient elements
...
<u:selector name=".rich-gradient-menu">
<u:style name="background-image">
<f:resource f:key="org.richfaces.renderkit.html.gradientimages.MenuGradientImage"/>
</u:style>
<u:style name="background-repeat" value="repeat-x" />
</u:selector>
<u:selector name=".rich-gradient-tab">
<u:style name="background-image">
72
Chapter 5. Basic concepts of the RichFaces
Framework
<f:resource f:key="org.richfaces.renderkit.html.gradientimages.TabGradientImage"/>
</u:style>
<u:style name="background-repeat" value="repeat-x" />
</u:selector>
...
To get a better idea of standard component skinning we recommend to explore CSS files located
in ui/core/src/main/resources/org/richfaces/ folder of RichFaces svn.
Table 5.5. Html Elements Skin Bindings for input, select, textarea, button,
keygen, isindex, legend
73
Chapter 5. Basic concepts of the RichFaces
Framework
Table 5.11. Rich Elements Skin Bindings for .rich-input, .rich-select, .rich-
textarea, .rich-keygen, .rich-isindex, .rich-link
74
Chapter 5. Basic concepts of the RichFaces
Framework
75
Chapter 5. Basic concepts of the RichFaces
Framework
Table 5.22. Rich Elements Skin Bindings for .rich-container fieldset, .rich-
fieldset
Table 5.25. Html Elements Skin Bindings for input, select, textarea, button,
keygen, isindex
76
Chapter 5. Basic concepts of the RichFaces
Framework
77
Chapter 5. Basic concepts of the RichFaces
Framework
78
Chapter 5. Basic concepts of the RichFaces
Framework
Note:
...
<portlet>
<portlet-name>ajaxPortlet</portlet-name>
<header-content>
<script src="/faces/rfRes/org/ajax4jsf/framework.pack.js" type="text/
javascript" />
<script src="/faces/rfRes/org/richfaces/ui.pack.js" type="text/javascript" />
<link rel="stylesheet" type="text/css" href="/faces/rfRes/org/richfaces/
skin.xcss" />
</header-content>
</portlet>
...
However, if you don't want the RichFaces components and standard HTML controls to be skinned
automatically and perform the skinnability implementation yourself, you might encounter with a
79
Chapter 5. Basic concepts of the RichFaces
Framework
problem, namely standard HTML controls in such browsers as Opera and Safari will be affected by
standard controls skinning. ( In this section you can get more details on how to disable skinnability.)
In brief, to disable the skinnability mechanism of RichFaces you need to set the
"org.richfaces.LoadStyleStrategy" parameter to "NONE" in the web.xml file.
...
<context-param>
<param-name>org.richfaces.LoadStyleStrategy</param-name>
<param-value>NONE</param-value>
</context-param>
...
Additionally, you should include the style sheets that perform skinning of the RichFaces
component and standard HTML controls.
In order to resolve the problem with extended skinning in Opera and Safari a client script
(skinning.js) is added to the RichFaces library. The script detects the browser type and enables
extended skinning only for those browsers that fully support it.
The script can be activated by inserting this JavaScript code to the page:
<script type="text/javascript">
window.RICH_FACES_EXTENDED_SKINNING_ON = true;
</script>
When NO script loading strategy is used and extended skinning is turned on then corresponding
warning message will appears in the console.
You also need to specify "media" attribute in the <link> tag which includes the
"extended_both.xcss" style sheet with "rich-extended-skinning".
This is how you can include the style sheets to the page, in case automatic skinnability
implementation is disabled.
<link href='/YOUR_PROJECT_NAME/a4j_3_2_2-SNAPSHOTorg/richfaces/renderkit/html/css/
basic_both.xcss/DATB/eAF7sqpgb-jyGdIAFrMEaw__.jsf' type='text/
css' rel='stylesheet' class='component' />
<link media='rich-extended-skinning' href='/ YOUR_PROJECT_NAME /a4j_3_2_2-
SNAPSHOTorg/richfaces/renderkit/html/css/extended_both.xcss/DATB/eAF7sqpgb-
jyGdIAFrMEaw__.jsf' type='text/css' rel='stylesheet' class='component' />
80
Chapter 5. Basic concepts of the RichFaces
Framework
Note
XCSS is an XML formatted CSS that adds extra functionality to the skinning process. XCSS
extends skinning possibilities by parsing the XCSS file that contains all look-and-feel parameters
of a particular component into a standard CSS file that a web browser can recognize.
XCSS file contains CSS properties and skin parameters mappings. Mapping of a CSS selector
to a skin parameter is performed using < u:selector > and < u:style> XML tags that form the
mapping structure. Please study the example below.
...
<u:selector name=".rich-component-name">
<u:style name="background-color" skin="additionalBackgroundColor" />
<u:style name="border-color" skin="tableBorderColor" />
<u:style name="border-width" skin="tableBorderWidth" />
<u:style name="border-style" value="solid" />
</u:selector>
...
During processing the code in the shown example is parsed into a standard CSS format.
...
.rich-component-name {
background-color: additionalBackgroundColor; /*the value of the constant defined by your skin*/
border-color: tableBorderColor; /*the value of the constant defined by your skin*/
border-width: tableBorderWidth; /*the value of the constant defined by your skin*/
border-style: solid;
}
...
81
Chapter 5. Basic concepts of the RichFaces
Framework
The "name" attribute of <u:selector> tag defines the CSS selector, while "name" attribute of
the <u:style> tag defines what skin constant is mapped to a CSS property. The "value" attribute
of the <u:style> tag can also be used to assign a value to a CSS property.
CSS selectors with identical skinning properties can be set as a comma separated list.
...
<u:selector name=".rich-ordering-control-disabled, .rich-ordering-control-top, .rich-ordering-
control-bottom, .rich-ordering-control-up, .rich-ordering-control-down">
<u:style name="border-color" skin="tableBorderColor" />
</u:selector>
...
5.11.11. Plug-n-Skin
Plug-n-Skin is a feature that gives you an opportunity to easily create, customize and plug into
your project a custom skin. The skin can be created basing on parameters of some predefined
RichFaces skin.
The feature also provides an option to unify the appearance of rich controls with standard HTML
elements.
In order to create your own skin using Plug-n-Skin feature, you can follow these step by step
instructions.
First of all, you need to create a template for the new skin. Creation of the template can
be performed using Maven build and deployment tool. More information on how to configure
Maven for RichFaces you can find out from JBoss wiki article [http://wiki.jboss.org/wiki/
HowToConfigureMavenForRichFaces] . You can copy and paste these Maven instructions to
command line and execute them.
...
mvn archetype:create -DarchetypeGroupId=org.richfaces.cdk -DarchetypeArtifactId=maven-
archetype-plug-n-skin -DarchetypeVersion=RF-VERSION -DartifactId=ARTIFACT-ID -
DgroupId=GROUP-ID -Dversion=VERSION
...
82
Chapter 5. Basic concepts of the RichFaces
Framework
After this operation, a folder with the name of your "ARTIFACT-ID" appears. The folder contains
a template of Maven project.
Next steps will guide you though creating of the skin itself.
In the root folder of Maven project (the one that contains "pom.xml" file) you should run the
following command in the command line:
...
mvn cdk:add-skin -Dname=SKIN-NAME -Dpackage=SKIN-PACKAGE
...
• package base package of the skin. By default "groupId" of the project is used.
• createExt if set to "true", extended CSS classes are added. For more information, please, see
"Standard controls skinning"
As a result of the performed operations the following files and folders are created:
• XCSS files - XCSS files define the new look of RichFaces components affected by the new skin.
Location: "\src\main\resources\SKIN-PACKAGE\SKIN-NAME\css\"
• SKIN-NAME.properties - a file that contains properties of the new skin. Location: "\src\main
\resources\SKIN-PACKAGE\SKIN-NAME\css\"
• baseSkin – the name of the base skin to be used as basis. The look of the skin you define
will be affected by new style properties.
• generalStyleSheet - a path to the style sheet (SKIN-NAME.xcss) that imports style sheets of
the components to be affected by the new skin.
83
Chapter 5. Basic concepts of the RichFaces
Framework
• extendedStyleSheet - a path to a style sheet that is used to unify the appearance of RichFaces
components and standard HTML controls. For additional information please read "Standard
controls skinning" chapter.
• gradientType - a predefined property to set the type of gradient applied to the new skin.
Possible values are glass, plastic, plain. More information on gradient implementation you
can find further in this chapter.
• SKIN-NAME.xcss - a XCSS file that imports XCSS files of the components to be affected by
the new skin. Location: "src\main\resources\META-INF\skins "
• XCSS files If the command is executed with the "DcreateExt" key set to "true", the XCSS
(extended_classes.xcss and extended.xcss) files that define style for standard controls will be
created. Location: "\src\main\resources\SKIN-PACKAGE\SKIN-NAME\css\".
• SKIN-NAME-ext.xcss If the command is executed with the "DcreateExt" key set to "true", the
configuration SKIN-NAME-ext.xcss file that imports XCSS file defining styles for the standard
controls will be created. Location: "src\main\resources\META-INF\skins ".
• SKIN-NAME-resources.xml - the file contains the description of all listed above files. Location:
"src\main\config\resources ".
Now you can start editing the XCSS files located in "\src\main\resources\SKIN-PACKAGE\SKIN-
NAME\css\". New style properties can be assigned to the selectors (the selectors listed in the
XCSS files) in two ways, which are both valid, and it'up to you what way to choose.
• Standard CSS coding approach, i.e. you can add CSS properties to the given selectors. The
only thing, you have to keep in mind is that the selectors must be inside <f:verbatim> <!
[CDATA[ ...]]> </f:verbatim> tags.
For example
...
.rich-calendar-cell {
background: #537df8;
}
...
• Using XCSS coding approach, the same way as XCSS files are normally formed in RichFaces.
The XCSS tags have to be placed outside <f:verbatim> <![CDATA[ ...]]> </f:verbatim>
tags.
...
<u:selector name=".rich-calendar-cell">
<u:style name="border-bottom-color" skin="panelBorderColor"/>
84
Chapter 5. Basic concepts of the RichFaces
Framework
Having performed described above steps and edited the XCSS files you can proceed to building
the new skin and to plugging it into the project. Building the new skin can be done by executing
the given below command in the command line in the root folder of you skin project (the one that
contains pom.xml file).
...
mvn clean install
...
In addition Plug-n-Skin has a number of predefined gradients that you can also use to make your
application look nicer. The given below code snippet shows how a gradient can be used
...
<u:selector name=".rich-combobox-item-selected">
<u:style name="border-width" value="1px" />
<u:style name="border-style" value="solid" />
<u:style name="border-color" skin="newBorder" />
<u:style name="background-position" value="0% 50%" />
<u:style name="background-image">
<f:resource f:key="org.richfaces.renderkit.html.CustomizeableGradient">
<f:attribute name="valign" value="middle" />
<f:attribute name="gradientHeight" value="17px" />
<f:attribute name="baseColor" skin="headerBackgroundColor" />
</f:resource>
</u:style>
</u:selector>
...
So, as you can see, the background-image CSS property is defined with <f:resource
f:key="org.richfaces.renderkit.html.CustomizeableGradient"> that sets the gradient.
While the gradient type can be specified in the SKIN-NAME.properties file with gradientType
property. The gradientType property can be set to one of the possible values glass, plastic, plain.
The gradient in it's turn can be can be adjusted using baseColor, gradientColor, gradientHeight,
valign attributes. Their usage is shown in the snippet above.
85
Chapter 5. Basic concepts of the RichFaces
Framework
Now, you can use your newly-created and customized skin in your project by adding your new
skin parameters to web.xml file and placing the jar file with your skin ( the jar file is located in
"target" folder of your skin project) to "\WebContent\WEB-INF\lib\".
...
<context-param>
<param-name>org.ajax4jsf.SKIN</param-name>
<param-value>SKIN-NAME</param-value>
</context-param>
...
This section will cover some practical aspects of Plug-n-Skin implementation. It's assumed that
you have read the section of the guide that tells how the new skin using Plug-n-Skin prototype
can be created.
Above all, we need to create a new skin, in order to do that we just have to follow the steps
described in the previous section.
This command will be used to create a template of the new skin project.
Now you can browse the "P-n-S" folder to view what files and folders were created there.
Next, we will use Maven to add all needed files to the skin project. This will done by the following
command:
As you remember from the previous section "-DbaseSkin" key defines what RichFaces built-in
skin to be used as a base one, "-DcreateExt=true" determines that the new skin will come with
XCSS files that unify the look of the rich components with standard HTML controls.
So, now the files and folder with all needed resources are created and redefining/editing the new
skin can be started.
86
Chapter 5. Basic concepts of the RichFaces
Framework
Now we can start editing XCSS files of the rich components. In order to see how the Plug-n-Skin
feature works we will change some style attributes of <rich:calendar> and some basic HTML
controls to see how they are affected by standard controls skinning.
• Recolor the current day's cell background of the <rich:calendar> to see how the new skin
created with the help of Plug-n-Skin feature affects the style of the component;
In oder to edit the style properties of <rich:calendar> you need to open the "calendar.xcss" file
located in "P-n-S\src\main\resources\skinpackage\plugnskindemo\css\". Once, you have opened
the file, please find ".rich-calendar-today" selector and amend it as follows: background-color:
#075ad1;. The current day's background color can be considered recolored.
Now we will see how font style of a standard HTML submit button can be changed. Please,
open "extended.xcss" file located in "P-n-S\src\main\resources\skinpackage\plugnskindemo\css
\" and put in font-weight: bold; inside the curly braces of these coma separated
selectors button[type="button"], button[type="reset"], button[type="submit"],
input[type="reset"], input[type="submit"], input[type="button"]. So, the CSS code
should look like this.
button[type="button"], button[type="reset"],
button[type="submit"], input[type="re
input[type="submit"], input[type="button"] { font-weight: bold;
}
All the changes that were planned to be preformed are done and now you can proceed to building
the new PlugnSkinDemo skin and import it into the project. As you read in the previous section,
the skin should be built in the "P-n-S" folder of the skin project by executing mvn clean install
command. This procedure results in creating a "target" folder that contains a .jar file with a
compiled new skin, it our case the file is named "P-n-S-1.0.-SNAPSHOT.jar". The next step is to
import the new PlugnSkinDemo skin into the project.
What you need to do, in order to have the new skin imported to the project is to
• Add the new skin's name to the "web.xml" file. It is done like this
<context-param>
<param-name>org.ajax4jsf.SKIN</param-name>
<param-value>PlugnSkinDemo</param-value>
87
Chapter 5. Basic concepts of the RichFaces
Framework
</context-param>
Please, do not forget that standard controls skinning has to be enabled in the "web.xml" file, which
can be done by adding the following code to the "web.xml" file:
<context-param>
<param-name>org.richfaces.CONTROL_SKINNING</param-name>
<param-value>enable</param-value>
</context-param>
88
Chapter 5. Basic concepts of the RichFaces
Framework
Let's consider the <rich:modalPanel> component. To change the background color for the mask,
it's enough to redefine the .rich-mpnl-mask-div class.
Example:
...
.rich-mpnl-mask-div{
background-color:#fae6b0;
}
...
This is a result:
If you have multiple components on the page, the redefined styles will be applied to all of them.
To change styles for a particular component on the page, create your own style classes and use
them in corresponding style class attributes. An example on how to change the font style for the
header of a particular modal panel is placed below:
Example:
...
.myClass{
font-style:italic;
}
...
89
Chapter 5. Basic concepts of the RichFaces
Framework
Next specify myClass as the value of the "headerClass" attribute for <rich:modalPanel> :
This is a result:
90
Chapter 5. Basic concepts of the RichFaces
Framework
RichFaces State API allows easily to define some set of states for the pages and any properties
for this states.
Actually States is a map where the entry key is a name of the State and the value is a State map.
Particular State map has entries with some names as keys and any objects as values that are used
after the state activation. Thus, in the State map you could define any values, method bindings,
or just some simple state variables (constants) which have different values for every State.
One of the most convenience features of the RichFaces State API is a navigation between states.
The RichFaces State API implements states change as the standard JSF navigation. Action
91
Chapter 5. Basic concepts of the RichFaces
Framework
component just returns outcome and the RichFaces State API extension for the JSF navigation
handler checks whether this outcome is registered as a state change outcome or not. If the state
change outcome is found the corresponding state is activated. Otherwise the standard navigation
handling is called.
In order to use RichFaces State API you should follow the next steps:
...
<application>
<navigation-handler>org.richfaces.ui.application.StateNavigationHandler</navigation-
handler>
<el-resolver>org.richfaces.el.StateELResolver</el-resolver>
</application>
...
...
<factory>
<application-factory>org.richfaces.ui.application.StateApplicationFactory</application-
factory>
</factory>
...
...
<managed-bean>
<managed-bean-name>state</managed-bean-name>
<managed-bean-class>org.richfaces.ui.model.States</managed-bean-class>
<managed-bean-scope>request</managed-bean-scope>
<managed-property>
<property-name>states</property-name>
<property-class>org.richfaces.ui.model.States</property-class>
<value>#{config.states}</value>
</managed-property>
</managed-bean>
<managed-bean>
<managed-bean-name>config</managed-bean-name>
<managed-bean-class>org.richfaces.demo.stateApi.Config</managed-bean-class>
92
Chapter 5. Basic concepts of the RichFaces
Framework
<managed-bean-scope>none</managed-bean-scope>
</managed-bean>
...
One bean ("config") defines and stores states as it is shown in the following example:
...
public class Config {
/**
* @return States
*/
public States getStates() {
FacesContext facesContext = FacesContext.getCurrentInstance();
States states = new States();
93
Chapter 5. Basic concepts of the RichFaces
Framework
beanExpression = expressionFactory.createValueExpression(facesContext
.getELContext(), "#{loginbean}", Bean.class);
states.put("bean", beanExpression);
beanExpression = expressionFactory.createValueExpression(facesContext
.getELContext(), "#{loginaction}", LoginAction.class);
states.put("action", beanExpression);
methodExpression = expressionFactory.createMethodExpression(
facesContext.getELContext(), "#{loginaction.ok}",
String.class, new Class[] {});
states.put("ok", methodExpression);
states.setNavigation("switch", "register");
return states;
}
}
...
The other bean ("state") with the type org.richfaces.ui.model.States has the "states"
managed property that is bound to the "config" bean which defines states.
...
<h:panelGrid columns="3">
<h:outputText value="username" />
<h:inputText value="#{state.bean.name}" id="name" required="true" />
<h:outputText value="password" />
94
Chapter 5. Basic concepts of the RichFaces
Framework
<h:inputSecret
value="#{state.bean.confirmPassword}"
rendered="#{state.showConfirm}"id="confirm"
required="true"
/
>
</h:panelGrid>
<a4j:commandButton
actionListener="#{state.action.listener}"
action="#{state.ok}"
value="#{state.okBtn}"
id="action"/
>
...
To get full Login/Register dialog example, please, have a look at RichFaces Live Demo [http://
livedemo.exadel.com/richfaces-demo/richfaces/stateAPI.jsf?c=stateAPI].
For example, you need to render some controls only for administrators. To do this you
need to create a role "admin" in web.xml and implement authorisation that assigns the
"admin" role to the user that loggged-in as an administrator. Afterwards, you can use the
rich:isUserInRole(Object) function with the "rendered" attribute of any component.
Example:
...
<rich:editor value="#{bean.text}" rendered="#{rich:isUserInRole('admin')}" />
...
In the example above only a logged-in user with the role "admin" can see the text editor while for
the user with other roles the component will not be rendered.
95
Chapter 6. The RichFaces Components
6.1.1.1. Description
The <a4j:ajaxListener> component adds an action listener to a parent component and works
like the <f:actionListener> or <f:valueChangeListener> JSF components but for the whole
Ajax container.
The <a4j:ajaxListener> component adds an action listener to a parent component. That listener
is invoked on each Ajax request during the "Render Response" JSF phase. In comparison with
standard JSF <f:actionListener> and <f:valueChangeListener> components the invocation
of the <a4j:ajaxListener> is not skipped in case when validation of "Update Model" fails. The
<a4j:ajaxListener> is guarantied to be invoked for each Ajax response.
The "type" attribute defines the fully qualified Java class name for the listener. This Java
class should implement org.ajax4jsf.event.AjaxListener [../../apidoc_framework/
org/ajax4jsf/event/AjaxListener.html] interface which is base interface for all listeners,
capable for receiving Ajax events. The object on which the Event initially occurred could
be accessed using the java.util.EventObject.getSource() [http://java.sun.com/
j2se/1.4.2/docs/api/java/util/EventObject.html] method.
The <a4j:ajaxListener> is not invoked for non-Ajax requests and when RichFaces works in the
"Ajax Request generates Non-Ajax Response" mode, so <a4j:ajaxListener> invocation is a good
indicator that Ajax Response is going to be processed. Let's check it in the following example.
Example:
...
<rich:messages/>
<h:form id="form">
<a4j:commandLink value="Click to send Ajax request">
<a4j:ajaxListener type="org.docs.richfaces.actionListenerBean"/>
</a4j:commandLink>
97
Chapter 6. The RichFaces Components
</h:form>
...
Example:
...
public class ActionListenerBean implements org.ajax4jsf.event.AjaxListener {
public void processAjax(AjaxEvent event) {
FacesContext.getCurrentInstance().addMessage("form", new FacesMessage("Ajax request
is sent"));
}
}
...
There is a result:
Name Value
listener-class org.ajax4jsf.event.AjaxListener
event-class org.ajax4jsf.event.AjaxEvent
tag-class org.ajax4jsf.taglib.html.jsp.AjaxListenerTag
Check Sun JSF TLD documentation for more information on <f:valueChangeListener> tag [http://
java.sun.com/javaee/javaserverfaces/1.1_01/docs/tlddocs/f/valueChangeListener.html].
98
Chapter 6. The RichFaces Components
6.1.2.1. Description
• "assignTo" defines updatable bean property. This property will be updated if the
parent command component performs an actionEvent. The update occurs in the same
phase as the actionEvent is processed (INVOKE_APPLICATION, PROCESS_VALIDATIONS, or
APPLY_REQUEST_VALUES, depending on the values of the "immediate" and "bypassUpdates"
attributes).
Example:
...
<h:form id="form">
<a4j:commandButton value="Set Name to Alex" reRender="rep">
<a4j:actionparam name="username" value="Alex" assignTo="#{actionparamBean.name}"/>
</a4j:commandButton>
<br/>
<h:outputText id="rep" value="Name: #{actionparamBean.name}"/>
</h:form>
...
...
public class ActionparamBean {
private String name = "John";
99
Chapter 6. The RichFaces Components
You can use <a4j:actionparam> not only with Ajax components, but with non-ajax
command component also. This feature allows to update model values without invoking even
a single line of Java code on the server side. The usage of this feature you can find at
ActionParameter Usage [http://livedemo.exadel.com/richfaces-demo/richfaces/actionparam.jsf?
c=actionparam&tab=usage] page of RichFaces LiveDemo.
If you need to convert the value before the "Update Model" phase you can specify the converter
in the "converter" attribute.
Note:
The property is assigned with a parameter value on the "Update Model" phase.
Therefore if the validation of the form is failed, this phase will be skipped and the
property won't be updated.
It is possible to use JavaScript expression or function in the "value" attribute. In this case the
"noEscape" attribute should be set to "true". The result of this JavaScript invocation is sent to the
server as a value of <a4j:actionparam> .
Name Value
component-type org.ajax4jsf.ActionParameter
component-class org.ajax4jsf.component.html.HtmlActionParameter
100
Chapter 6. The RichFaces Components
More information about <f:param> and <f:actionListener> can be found in Sun JSF TLD
documentation [http://java.sun.com/javaee/javaserverfaces/1.2/docs/tlddocs/index.html].
6.1.3.1. Description
The <a4j:form> component enhances functionality of the standard JSF <h:form> component
with possibility of default Ajax submission and fixes the problem with <h:commandLink>
generation inside the form.
If the <a4j:form> component works in an Ajax mode, the standard Ajax attributes such as
"reRender" , "limitToList" , "requestDelay" , etc. can be used.
Example:
...
<a4j:form ajaxSubmit="true" reRender="name">
<h:panelGrid>
<h:commandButton value="Set Local Name to John
(Ajax)" action="#{userBean.nameItJohn}" />
<h:outputText id="name" value="Name:#{userBean.name}" />
</h:panelGrid>
</a4j:form>
...
...
public class UserBean {
private String name="";
101
Chapter 6. The RichFaces Components
return null;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
}
...
In the example above the ajaxSubmit="true", so all standard action components on this form
become ajaxable. The "reRender" attribute contains an Id of component for re-rendering after
an Ajax response.
Tip:
If you have <h:commandButton> or <h:commandLink> inside a form, they
work as <a4j:commandButton> .
Note:
You should not use <a4j:form> component with ajaxSubmit="true" if it contains
other Ajax command components. Also, due to the security reason, file upload form
element cannot be convertible to the be ajaxable.
Name Value
component-type org.ajax4jsf.Form
component-family javax.faces.Form
component-class org.ajax4jsf.component.html.AjaxForm
renderer-type org.ajax4jsf.FormRenderer
102
Chapter 6. The RichFaces Components
For additional information about attributes of this component read 'Ajax Attribute [http://
livedemo.exadel.com/richfaces-demo/richfaces/ajaxAttributes.jsf?c=ajaxattributes] section.
6.1.4.1. Description
The <a4j:region> component specifies the part of the component tree to be processed on server.
If no <a4j:region> is defined the whole View functions as a region.
Example:
<h:form>
...
<a4j:region>
<a4j:commandLink/>
</a4j:region>
...
<h:form>
The whole Form on the schematic listing above will be submitted by request invoked with the
<a4j:commandLink> . The only part that is going to be processed on the server is enclosed with
<a4j:region> and </a4j:region> tags. If no <a4j:region> is defined the whole View functions
as a region.
The regions could be nested. Server picks out and decodes only the region, which contains the
component that initiates the request.
Example:
<h:form>
...
<a4j:region>
<a4j:commandLink value="Link 1" id="link1"/>
<a4j:region>
<a4j:commandLink value="Link 2" id="link2"/>
</a4j:region >
</a4j:region>
...
103
Chapter 6. The RichFaces Components
<h:form>
The external region is decoded for link1 and the internal one is decoded for link2.
The "renderRegionOnly" attribute is used when it is necessary to exclude all the components
from the outside of the region from updating on the page during Renderer Response phase. Such
manipulation allows region to be passed straight into Encode and reduces performance time. This
optimization should be implemented carefully because it doesn't allow data from the outside of
active region to be updated.
Example:
<h:form>
...
<a4j:region renderRegionOnly="true">
<a4j:commandLink value="Link 1" id="link1"/>
</a4j:region>
...
<a4j:region renderRegionOnly="false">
<a4j:commandLink value="Link 2" id="link2"/>
</a4j:region>
...
</h:form>
On the example above the first region only will be updated if link1 initiates a request. When a
request is initiated by link2 both regions will be updated. In this case search for components to
include them into Renderer Response will be performed on the whole component tree.
RichFaces allows setting Ajax responses rendering basing on component tree nodes directly,
without referring to the JSP (XHTML) code. This speeds up a response output considerably and
could be done by setting the <a4j:region> "selfRendered" attribute to "true". However, this rapid
processing could cause missing of transient components that present on view and don't come into
a component tree as well as omitting of <a4j:outputPanel> usage described below.
Example:
In this case the processing is quicker and going on without referring to the page code. The HTML
code is not saved in a component tree and could be lost. Thus, such optimization should be
104
Chapter 6. The RichFaces Components
Starting from RichFaces 3.2.0 the <a4j:region> can be used together with iterative components
(e.g. <rich:column> or <rich:scrollableDataTable> , etc.). It became possible to re-render a
particular row in a table without updating the whole table and without any additional listeners.
Example:
<rich:column>
<a4j:region>
<a4j:commandLink reRender="out"/>
</a4j:region>
</rich:column>
<rich:column>
<h:outputText id="out">
</rich:column>
In most cases there is no need to use the <a4j:region> as ViewRoot is a default one.
105
Chapter 6. The RichFaces Components
6.1.5.1. Description
The <a4j:support> component is the most important core component in the RichFaces library.
It enriches any existing non-Ajax JSF or RichFaces component with Ajax capability. All other
RichFaces Ajax components are based on the same principles <a4j:support> has.
• mandatory "event" attribute that defines the JavaScript event the Ajax support will be attached
to
• "reRender" attribute that defines id(s) of JSF component(s) that should be rerendered after an
Ajax request
As mentioned above, the <a4j:support> component adds Ajax capability to non-Ajax JSF
components. Let's create ajaxed <h:selectOneMenu> called "Planets and Their Moons".
We begin with the common behavior description. When a page is rendered you see only one
select box with the list of planets. When you select a planet the <h:dataTable> containing moons
of the selected planet appears.
In other words we need <h:selectOneMenu> with the nested <a4j:support> component that
is attached to the onchange event.
When an Ajax response comes back the <h:dataTable> is re-rendered on the server side and
updated on the client.
...
<h:form id="planetsForm">
<h:outputLabel value="Select the planet:" for="planets" />
106
Chapter 6. The RichFaces Components
...
public class PlanetsMoons {
private String currentPlanet="";
public List<SelectItem> planetsList = new ArrayList<SelectItem>();
public List<String> moonsList = new ArrayList<String>();
private static final String [] EARTH = {"The Moon"};
private static final String [] MARS = {"Deimos", "Phobos"};
private static final String [] JUPITER = {"Europa", "Gamymede", "Callisto"};
public PlanetsMoons() {
SelectItem item = new SelectItem("earth", "Earth");
planetsList.add(item);
item = new SelectItem("mars", "Mars");
planetsList.add(item);
item = new SelectItem("jupiter", "Jupiter");
planetsList.add(item);
}
There are two properties planetsList and moonsList. The planetsList is filled with planets
names in the constructor. After you select the planet, the planetChanged() listener is called and
the moonsList is populated with proper values of moons.
107
Chapter 6. The RichFaces Components
With the help of "onsubmit" and "oncomplete" attributes the <a4j:support> component allows
to use JavaScript calls before and after an Ajax request respectively. Actually the JavaScript
specified in the "oncomplete" attribute will be executed in any case whether the Ajax request is
completed successfully or not.
You can easily add confirmation dialog for the planet select box and colorize <h:dataTable>
after the Ajax response:
...
<h:form id="planetsForm">
<h:outputLabel value="Select the planet:" for="planets" />
Information about the "process" attribute usage you can find in the " Decide what to process "
guide section.
Tip:
The <a4j:support> component created on a page as following
<h:inputText value="#{bean.text}">
108
Chapter 6. The RichFaces Components
is decoded in HTML as
Name Value
component-type org.ajax4jsf.Support
component-family org.ajax4jsf.AjaxSupport
component-class org.ajax4jsf.component.html.HtmlAjaxSupport
renderer-type org.ajax4jsf.components.AjaxSupportRenderer
6.1.6.1. Description
The <a4j:commandButton> component is very similar to JSF <h:commandButton> , the only
difference is that an Ajax form submit is generated on a click and it allows dynamic rerendering
after a response comes back.
109
Chapter 6. The RichFaces Components
#licking the generated anchor fires the utility method A4J.AJAX.Submit() that perfroms Ajax
request.
Note:
The usage of the keyword 'this' in JavaScript code in the value for "oncomplete" attribute
depends on the location of <a4j:commandButton> . If the <a4j:commandButton> is situated
outside the re-rendered region it is possible to use keyword 'this' as in the following example:
<h:form>
<a4j:commandButton
action="director.rollCamera"
onclick="this.disabled=true"
oncomplete="this.disabled=false"
/
>
</h:form>
<h:form id="form">
4j:commandButton
id="cbutton"
action="director.rollCamera"
onclick="this.disabled=true"
oncomplete="document.getElementById('form:cbutton').disabled=false"
/
>
</h:form>
110
Chapter 6. The RichFaces Components
Common JSF navigation could be performed after an Ajax submit and partial rendering, but
Navigation Case must be defined as <redirect/> in order to avoid problems with some browsers.
As any Core Ajax component that sends Ajax requests and processes server responses the
<a4j:commandButton> has all attributes that provide the required behavior of requests (delay,
limitation of submit area and rendering, etc.)
Note:
<rich:componentControl
attachTo="button"
for="panel"
event="oncomplete"
operation="show"
/
>
</a4j:commandButton>
Information about the "process" attribute usage you can find in the "Decide what to process"
guide section.
Name Value
component-type org.ajax4jsf.CommandButton
component-family javax.faces.Command
component-class org.ajax4jsf.component.html.HtmlAjaxCommandButton
111
Chapter 6. The RichFaces Components
Name Value
renderer-type org.ajax4jsf.components.AjaxCommandButtonRenderer
6.1.7.1. Description
...
<a4j:commandLink value="Get greeting" reRender="greeting" />
...
It's not necessary to add nested <a4j:support> as the <a4j:commandLink> has an Ajax
support already built-in. As a result of our changes we will get a form with "Get greeting" link
instead of the button:
112
Chapter 6. The RichFaces Components
If you click on the generated anchor the utility method A4J.AJAX.Submit() will be fired.
Note:
Common JSF navigation could be performed after Ajax submit and partial
rendering, but Navigation Case must be defined as <redirect/> in order to avoid
problems with some browsers.
As any Core Ajax component that sends Ajax requests and processes server responses the
<a4j:commandLink> has all attributes that provide the required behavior of requests (delay,
limitation of submit area and rendering, etc.)
Information about the "process" attribute usage you can find "Decide what to process" guide
section.
Name Value
component-type org.ajax4jsf.CommandLink
component-family javax.faces.Command
component-class org.ajax4jsf.component.html.HtmlAjaxCommandLink
renderer-type org.ajax4jsf.components.AjaxCommandLinkRenderer
Useful articles:
113
Chapter 6. The RichFaces Components
6.1.8.1. Description
The <a4j:jsFunction> component allows to perform Ajax requests directly from JavaScript code,
invoke server-side data and return it in a JSON format to use in a client JavaScript calls.
As the component uses Ajax request to get data from server it has all common Ajax Action
attributes. Hence, "action" and "actionListener" can be invoked, and reRendering some parts of
the page fired after calling function.
When using the <a4j:jsFunction> it's possible to initiate the Ajax request from the JavaScript
and perform partial update of a page and/or invoke the JavaScript function with data returned by
Ajax response.
...
<body onload="callScript()">
<h:form>
...
<a4j:jsFunction
name="callScript"
data="#{bean.someProperty1}"
reRender="someComponent"
oncomplete="myScript(data.subProperty1,
data.subProperty2)">
<a4j:actionparam name="param_name" assignTo="#{bean.someProperty2}"/>
</a4j:jsFunction>
...
</h:form>
...
</body>
...
Information about the "process" attribute usage you can find "Decide what to process" guide
section.
114
Chapter 6. The RichFaces Components
Name Value
component-type org.ajax4jsf.Function
component-family org.ajax4jsf.components.ajaxFunction
component-class org.ajax4jsf.component.html.HtmlajaxFunction
renderer-type org.ajax4jsf.components.ajaxFunctionRenderer
Useful articles:
6.1.9.1. Description
The <a4j:poll> component allows periodical sending of Ajax requests to a server and is used
for a page updating according to a specified time interval.
The <a4j:poll> componet is used for periodical polling of server data. In order to use the
component it's necessary to set an update interval. The "interval" attribute defines an interval
in milliseconds between the previous response and the next request. The total period beetween
two requests generated by the <a4j:poll> component is a sum of an "interval" attribute value
and server response time. Default value for "interval" attribute is set to "1000" milliseconds (1
second). See an example of definition in the "Creating the component with a Page Tag" section.
The "timeout" attribute defines response waiting time in milliseconds. If a response isn't received
during this period a connection is aborted and the next request is sent. Default value for "timeout"
attribute isn't set.
The "enabled" attribute defines should the <a4j:poll> send request or not. It's necessary to
render the <a4j:poll> to apply the current value of "enabled" attribute. You can use an EL-
115
Chapter 6. The RichFaces Components
expression for "enabled" attribute to point to a bean property. An example of usage of mentioned
above attributes is placed below:
Example:
...
<a4j:region>
<h:form>
<a4j:commandButtonstyle="width:120px"id="control"value="#{userBean.pollEnabled?'Stop':'Start'}
Polling" reRender="poll, grid">
<a4j:actionparam name="polling" value="#{!
userBean.pollEnabled}" assignTo="#{userBean.pollEnabled}"/>
</a4j:commandButton>
</h:panelGrid>
<h:outputText id="serverDate" style="font-size:16px" value="Server Date:
#{userBean.date}"/>
</h:panelGrid>
</h:form>
...
The example shows how date and time are updated on a page in compliance with data taken
from a server. The <a4j:poll> componet sends requests to the server every second. "reRender"
attribute of the <a4j:poll> contains poll's own Id. Hence, it is self rendered for applying the
current value of "enabled" attribute.
Notes:
116
Chapter 6. The RichFaces Components
Information about the "process" attribute usage you can find "Decide what to process" guide
section.
Name Value
component-type org.ajax4jsf.Poll
component-family org.ajax4jsf.components.AjaxPoll
component-class org.ajax4jsf.component.html.AjaxPoll
renderer-type org.ajax4jsf.components.AjaxPollRenderer
6.1.10.1. Description
The <a4j:push> periodically perform Ajax request to server, to simulate 'push' data.
The main difference between <a4j:push> and <a4j:poll> components is that <a4j:push>
makes request to minimal code only (not to JSF tree) in order to check the presence of messages
in the queue. If the message exists the complete request is performed. The component doesn't
poll registered beans but registers EventListener which receives messages about events.
117
Chapter 6. The RichFaces Components
The bean, for example, could be subscribed to Java Messaging Service (JMS [http://java.sun.com/
products/jms/]) topic or it could be implemented as Message Driven Bean (MDB) in order to send
a message to the <a4j:push> component about an event presence. In the presence of the event
some action occurs.
Thus, a work paradigm with the <a4j:push> component corresponds to an anisochronous model,
but not to pools as for <a4j:poll> component. See the simplest example below:
Example:
...
class MyPushEventListener implements PushEventListener {
public void onEvent(EventObject evt) {
System.out.println(evt.getSource());
//Some action
}
}
...
Example:
...
public void addListener(EventListener listener) {
synchronized (listener) {
if (this.listener != listener) {
this.listener = (PushEventListener) listener;
}
}
}
...
Example:
...
<a4j:status startText="in progress" stopText="done"/>
118
Chapter 6. The RichFaces Components
<a4j:form>
<a4j:region>
<a4j:push reRender="msg" eventProducer="#{pushBean.addListener}" interval="2000"/>
</a4j:region>
<a4j:outputPanel id="msg">
<h:outputText value="#{pushBean.date}">
<f:convertDateTime type="time"/>
</h:outputText>
</a4j:outputPanel>
<a4j:commandButton value="Push!!" action="#{pushBean.push}" ajaxSingle="true"/>
</a4j:form>
...
The example shows how date is updated on a page in compliance with data taken from a server. In
the example "interval" attribute has value "2000". This attribute defines an interval in milliseconds
between the previous response and the next request. Default value is set to "1000" milliseconds
(1 second). It's possible to set value equal to "0". In this case connection is permanent.
The "timeout" attribute defines response waiting time in milliseconds. If a response isn't received
during this period a connection is aborted and the next request is sent. Default value for "timeout"
attribute isn't set. Usage of "interval" and "timeout" attributes gives an opportunity to set short
polls of queue state or long connections.
Note:
Name Value
component-type org.ajax4jsf.Push
component-family org.ajax4jsf.components.AjaxPush
component-class org.ajax4jsf.component.html.AjaxPush
renderer-type org.ajax4jsf.components.AjaxPushRenderer
119
Chapter 6. The RichFaces Components
6.1.11.1. Description
The <a4j:queue> component enqueues set of Ajax requests sent from client. The RichFaces
components with built-in Ajax can reference the queue to optimize Ajax requests.
The RichFaces Queue has four different types: global default, view scoped default, view scoped
named and form-based default queue (general Queue principles are good documented in the
"Queue Principles" section). The current section will take closer to the form based queue. The
usage of other types is similar.
In order to disable or enable the <a4j:queue> component on the page you can use the "disabled"
attribute.
The "requestDelay" attribute defines delay time for all the requests fired by the action
components.
The "size" attribute specifies the number of requests that can be stored in the queue at a time. The
attribute helps to prevent server overloading. It is also possible to determine queue's behaviour
when it's size is exceeded. Use the "sizeExceededBehavior" for this purpose. There are four
possible strategies of exceeded queue's behavior:
Example:
<h:form>
<a4j:queue
size="2"
requestDelay="500"sizeExceededBehavior="dropNext"
onsizeexceeded="alert('The
size of the queue is exceeded')" />
<h:inputText value="#{bean.a}">
<a4j:support event="onkeyup" />
</h:inputText>
<h:inputText value="#{bean.b}">
120
Chapter 6. The RichFaces Components
In this example if the queue has more than 2 requests waiting to be processed the next event will
be dropped and a message (the "onsizeexceeded" attribute fires a JavaScript function) saying
that the queues is exceeded will be displayed.
The "ignoreDupResponses" attribute that takes a boolean value can also help optimize your
Ajax requests. If set to true, response processing for request will not occur if a similar request is
already waiting in the queue. New request will be fired immediately when the response from the
previous one returns.
Example:
<h:form>
<a4j:queue requestDelay="500" ignoreDupResponses="true" />
<h:inputText value="#{bean.a}">
<a4j:support event="onkeyup" />
</h:inputText>
</h:form>
In this example, the requests are glued together and only the last one is submitted.
Another key attribute that easies server load is "timeout" . The attribute specifies the amount of
time an item can be in the queue before the sent event is be aborted and dropped from the queue.
If the request is sent and response is not returned within the time frame defined in this attribute
- the request is aborted, and the next one is sent.
Example:
<h:form>
<a4j:queue timeout="1000" />
<h:inputText value="#{bean.a}">
<a4j:support event="onkeyup" />
</h:inputText>
</h:form>
In this case if the sever doesn't respond within a second the request will be aborted.
121
Chapter 6. The RichFaces Components
As you can see the implementation of the queue provides some custom event handlers that you
may use to call JavaScript functions.
The "oncomplete" is fired after request completed. In this event handler request object is be
passed as a parameter. Thus queue is be accessible using request.queue. And the element
which was a source of the request is available using this.
Example:
<h:form>
<a4j:queue oncomplete="alert(request.queue.getSize())" requestDelay="1000" />
<h:inputText value="#{bean.a}">
<a4j:support event="onkeyup" />
</h:inputText>
<h:selectBooleanCheckbox value="#{bean.check}">
<a4j:support event="onchange"/>
</h:selectBooleanCheckbox>
</h:form>
In this example you can see how the number of requests waiting in the queue change. You will
get a message with the number of the requests in the queue.
The "onbeforedomupdate" event handler called before updating DOM on a client side.
The "onrequestqueue" event handler called after the new request has been added to queue. And
the "onrequestdequeue" event handler called after the request has been removed from queue.
The "onsubmit" event handler called after request is completed. This attribute allows to invoke
JavaScript code before an Ajax request is sent.
122
Chapter 6. The RichFaces Components
Function Description
getMaximumSize() Returns the maximum size to the queue,
specified in the "size" attribute
Useful articles:
"Queue Principles" section of the RichFaces developer guide describes general Queue principles.
6.1.12.1. Description
The <a4j:status> component generates elements for displaying of the current Ajax requests
status. There are two status modes: Ajax request is in process or finished.
There are two ways for the components or containers definition, which Ajax requests status is
tracked by a component.
• Definition with the "for" attribute on the <a4j:status> component. Here "for" attribute should
point at an Ajax container ( <a4j:region> ) id, which requests are tracked by a component.
• Definition with the "status" attribute obtained by any RichFaces library action component. The
attribute should point at the <a4j:status> component id. Then this <a4j:status> component
shows the status for the request fired from this action component.
The component creates two <span> or <div> elements depending on attribute "layout" with
content defined for each status, one of the elements (start) is initially hidden. At the beginning of
an Ajax request, elements state is inversed, hence the second element is shown and the first is
hidden. At the end of a response processing, elements display states return to its initial values.
Example:
123
Chapter 6. The RichFaces Components
Started
</span>
<span id="j_id20:status.stop">
Stopped
</span>
<span id="j_id20:status.start">
Started
</span>
<span id="j_id20:status.stop" style="display: none">
Stopped
</span>
There is a possibility to group a <a4j:status> elements content into <div> elements, instead of
<span> . To use it, just redefine the "layout" attribute from "inline" (default) to "block".
Name Value
component-type org.ajax4jsf.Status
component-family javax.faces.Panel
component-class org.ajax4jsf.component.html.HtmlAjaxStatus
renderer-type org.ajax4jsf.components.AjaxStatusRenderer
124
Chapter 6. The RichFaces Components
6.2.1.1. Description
Internationalization and Localization are the processes of adaptation of web applications for
different languages and cultures. When you develop English and German versions of a site it
can be said that you localize the site for England and Germany. Language is not the only thing
that undergoes the localization — dates, times, numbers, currencies, phone numbers, addresses,
graphics, icons, colors, personal titles and even favourite sounds are also varies from country to
country. It means that an internationalized application may have lots of different types information,
which should be changed depending on user location.
There are several approaches of organizing the localization. The JSF <h:loadBundle> loads
bundles into the request scope when page is being rendered and updates all the needed areas
in a crowd. Bundle information loaded in such way becomes unavailable when dealing with
Ajax requests that work in their own request scopes. The approach provided by RichFaces
<a4j:loadBundle> component enriches one given by the JSF <h:loadBundle> with Ajax
capability: it allows to use reference to a particular bundle item during an Ajax update.
The <a4j:loadBundle> usage is pretty simple. Imagine a small application that says "Hello!"
in different languages, where switching between translations (localizations, in our case) occurs
when corresponding links are being clicked, like you have used to see on lots of sites. In our JSF
with RichFaces application (those who feel not strong with that should better read the "Getting
started with RichFaces" chapter) create resource bundles with "Hello!" message for three different
languages: English, German and Italian. Resource bundles are represented with *.properties
extention files that keep items in key(name) - value pairs. A key for an item should be the same
for all locales.
125
Chapter 6. The RichFaces Components
Figure 6.5. Resource bundles *.properties files with Keys and Values for
multi-language application.
<application>
<locale-config>
<default-locale>en</default-locale>
<supported-locale>en</supported-locale>
<supported-locale>de</supported-locale>
<supported-locale>it</supported-locale>
</locale-config>
<message-bundle>demo.message</message-bundle>
</application>
ChangeLocale Java class with three methods for setting the correponding Locale:
126
Chapter 6. The RichFaces Components
package demo;
import java.util.Locale;
import javax.faces.context.FacesContext;
<h:form>
<a4j:loadBundle var="msg" basename="demo.message"/>
<h:outputText id="messageBundle" value="#{msg.greeting}"/>
<a4j:commandLink
value="De"
action="#{changeLocale.germanAction}"
reRender="messageBundle"
/
>
<a4j:commandLink
value="Eng"
action="#{changeLocale.englishAction}"
reRender="messageBundle"
/
>
<a4j:commandLinkvalue="It"action="#{changeLocale.italianAction}"reRender="messageBundle"/
>
</h:form>
127
Chapter 6. The RichFaces Components
As an output we will get a simple application with English "Hello!" by default. Clicking on links
"De", "Eng" and "It" will show the messages specified within the corresponding *.properties
file. To reference to a particular bundle item during an Ajax update it is necessary to point
the component(s) that shold be re-rendered (in this example it is done with the help of
<a4j:commandLink> "reRender" attribute).
Name Value
component-type org.ajax4jsf.Bundle
component-family org.ajax4jsf.Bundle
component-class org.ajax4jsf.component.html.AjaxLoadBundle
128
Chapter 6. The RichFaces Components
6.2.2.1. Description
If a managed bean is declared with request scope in the configuration file with the help of
<managed-bean-scope> tag then the life-time of this bean instance is valid only for the current
request. Any attempts to make a reference to the bean instance after the request end will throw
in Illegal Argument Exception by the server. To avoid these kinds of Exceptions component
<a4j:keepAlive> is used to maintain the state of the whole bean object among subsequent
request.
Example:
The "beanName" attribute defines the request scope bean name you'd like to re-use. Note that
this attribute must point to a legal JSF EL expression which resolves to a managed mean instance.
For example for the above code the class definition may look like this one:
class MyClass{
...
private TestBean testBean;
// Getters and Setters for testBean.
...
}
The "ajaxOnly" attribute declares whether the value of the bean should be available during a
non-Ajax request. If the value of this attribute is "true" a request scope bean keeps the same value
during Ajax requests from the given page. If a non-Ajax request is sent from this page the bean
is re-created as a regular request scope bean.
129
Chapter 6. The RichFaces Components
Name Value
component-type org.ajax4jsf.components.KeepAlive
component-family org.ajax4jsf.components.AjaxKeepAlive
component-class org.ajax4jsf.components.AjaxKeepAlive
6.2.3.1. Description
The <a4j:loadScript> component allows to load scripts from alternative sources like a jar files,
etc.
The main attribute of the <a4j:loadScript> is "src" , wich defines the context relative path to the
script. The value of the attribute does not require a prefix of an application. Leading slash in the
path means the root of the web context. It is also possible to use resource:/// prefix to access
the script file using RichFaces resource framework.
Example:
The "src" attribute passses value to the getResourceURL() method of the ViewHandler
of the application, The result is passed through the encodeResourceURL() method of the
ExternalContext.
Name Value
component-type org.ajax4jsf.LoadScript
130
Chapter 6. The RichFaces Components
Name Value
component-family org.ajax4jsf.LoadScript
component-class org.ajax4jsf.component.html.HtmlLoadScript
renderer-type org.ajax4jsf.LoadScriptRenderer
6.2.4.1. Description
The <a4j:loadStyle> component allows to load a style sheet file from alternative sources like a
jar file, etc. It inserts stylesheet links to the head element.
The main attribute of the <a4j:loadStylet> is "src" , wich defines the context relative path to the
script. The value of the attribute does not require a prefix of an application. Leading slash in the
path means the root of the web context. It is also possible to use resource:/// prefix to access
the script file using RichFaces resource framework.
Example:
The "src" attribute passses value to the getResourceURL() method of the ViewHandler
of the application, The result is passed through the encodeResourceURL() method of the
ExternalContext.
Name Value
component-type org.ajax4jsf.LoadStyle
component-family org.ajax4jsf.LoadStyle
component-class org.ajax4jsf.component.html.HtmlLoadStyle
renderer-type org.ajax4jsf.LoadStyleRenderer
131
Chapter 6. The RichFaces Components
6.3.1.1. Description
The <rich:ajaxValidator> is a component designed to provide Ajax validation inside for JSF
inputs.
The following example demonstrates how the <rich:ajaxValidator> adds Ajax functionality
to standard JSF validators. The request is sent when the input field loses focus, the action is
determined by the "event" attribute that is set to "onblur".
...
<rich:panel>
<f:facet name="header">
<h:outputText value="User Info:" />
</f:facet>
<h:panelGrid columns="3">
<h:outputText value="Name:" />
<h:inputText value="#{userBean.name}" id="name" required="true">
<f:validateLength minimum="3" maximum="12"/>
<rich:ajaxValidator event="onblur"/>
132
Chapter 6. The RichFaces Components
</h:inputText>
<rich:message for="name" />
In the example above it's show how to work with standard JSF validators. The
<rich:ajaxValidator> component also works perfectly with custom validators enhancing their
usage with Ajax.
• Using Hibernate Validator, specifying a constraint for the data to be validated. A reference
on Hibernate Validator can be found in Hibernated documentation [http://www.hibernate.org/
hib_docs/validator/reference/en/html_single/].
The following example shows how the data entered by user can be validated using Hibernate
Validator.
...
<rich:panel>
<f:facet name="header">
<h:outputText value="User Info:" />
</f:facet>
<h:panelGrid columns="3">
<h:outputText value="Name:" />
133
Chapter 6. The RichFaces Components
package org.richfaces.demo.validation;
import org.hibernate.validator.Email;
import org.hibernate.validator.Length;
import org.hibernate.validator.Max;
import org.hibernate.validator.Min;
import org.hibernate.validator.NotEmpty;
import org.hibernate.validator.NotNull;
import org.hibernate.validator.Pattern;
@NotEmpty
@Pattern(regex=".*[^\\s].*", message="This string contain only spaces")
@Length(min=3,max=12)
private String name;
@Email
@NotEmpty
private String email;
134
Chapter 6. The RichFaces Components
@NotNull
@Min(18)
@Max(100)
private Integer age;
public ValidationBean() {
}
By default the Hibernate Validator generates an error message in 10 language, though you can
redefine the messages that are displayed to a user when validation fails. In the shows example it
was done by adding (message="wrong email format") to the @Email annotation.
Name Value
component-type org.richfaces.ajaxValidator
component-class org.richfaces.component.html.HtmlajaxValidator
component-family org.richfaces.ajaxValidator
renderer-type org.richfaces.ajaxValidatorRenderer
tag-class org.richfaces.taglib.ajaxValidatorTag
135
Chapter 6. The RichFaces Components
6.3.2.1. Description
The <rich:beanValidator> component designed to provide validation using Hibernate model-
based constraints.
The <rich:beanValidator> component is defined in the same way as any JSF validator. Look
at the example below.
<rich:panel>
<f:facet name="header">
<h:outputText value="#{validationBean.progressString}" id="progress"/>
</f:facet>
<h:panelGrid columns="3">
<h:outputText value="Name:" />
<h:inputText value="#{validationBean.name}" id="name">
<rich:beanValidator summary="Invalid name"/>
</h:inputText>
<rich:message for="name" />
136
Chapter 6. The RichFaces Components
</h:inputText>
<rich:message for="age" />
<f:facet name="footer">
<a4j:commandButtonvalue="Submit"action="#{validationBean.success}"reRender="progress"/
>
</f:facet>
</h:panelGrid>
</rich:panel>
Please play close attention on the bean code that contains the constraints defined with Hibernate
annotation which perform validation of the input data.
package org.richfaces.demo.validation;
import org.hibernate.validator.Email;
import org.hibernate.validator.Length;
import org.hibernate.validator.Max;
import org.hibernate.validator.Min;
import org.hibernate.validator.NotEmpty;
import org.hibernate.validator.NotNull;
import org.hibernate.validator.Pattern;
@NotEmpty
@Pattern(regex=".*[^\\s].*", message="This string contain only spaces")
@Length(min=3,max=12)
private String name;
@Email
@NotEmpty
private String email;
@NotNull
@Min(18)
@Max(100)
private Integer age;
public ValidationBean() {
137
Chapter 6. The RichFaces Components
As you can see from the example that in order to validate the <rich:beanValidator> should be
nested into a input JSF or RichFaces component.
The component has the only attribute - "summary" which displays validation messages about
validation errors.
Name Value
component-type org.richfaces.beanValidator
component-class org.richfaces.component.html.HtmlbeanValidator
138
Chapter 6. The RichFaces Components
Name Value
component-family org.richfaces.beanValidator
renderer-type org.richfaces.beanValidatorRenderer
tag-class org.richfaces.taglib.beanValidatorTag
6.3.3.1. Description
The <rich:graphValidator> component allows to register Hibernate Validators for multiple input
components.
The following example demonstrates a pattern of how the <rich:graphValidator> can be used:
...
<rich:graphValidator>
<h:panelGrid columns="3">
<h:outputText value="Name:" />
<h:inputText value="#{validationBean.name}" id="name">
<f:validateLength minimum="2" />
</h:inputText>
<rich:message for="name" />
<h:outputText value="Email:" />
<h:inputText value="#{validationBean.email}" id="email" />
<rich:message for="email" />
139
Chapter 6. The RichFaces Components
</h:panelGrid>
</rich:graphValidator>
...
The data validation can be also performed using Hibernate Validator, the same way as it is done
with <rich:beanValidator> .
The components's architecture provides an option to bind the component to a managed bean,
which is done with the "value" attribute. The attribute ensures that the entered data is valid after
the model is updated by revalidating the bean properties.
...
<rich:graphValidator summary="Invalid values: " value="#{dayStatistics}">
<a4j:repeat value="#{dayStatistics.dayPasstimes}" var="pt" id="table">
<h:outputText value="#{pt.title}" />
<rich:inputNumberSpinner minValue="0" maxValue="24" value="#{pt.time}" id="time" />
<rich:message for="time" />
</a4j:repeat>
</rich:graphValidator>
...
Hence, the given above code will provide the functionality that is illustrated on the images below.
As you can see from the picture the "Games" field did not pass validation, as
<rich:graphValidator> can be used to perform validation of a single input item.
140
Chapter 6. The RichFaces Components
The figure above shows that the entered data was revalidated after all fields were completed, and
the data did not pass revalidation since the total sum was incorrect.
6.4.1.1. Description
The <a4j:include> component is used to include one view as part of another and navigate there
using standard JSF navigation.
141
Chapter 6. The RichFaces Components
The component is used to include one view as part of another and may be put anywhere in the
page code. The 'viewID' attribute is used to point at the part to be included and should present
a full context-relative path of the resource in order to be used as from-view and to-view in the
JSF navigation cases. In general the component functions as Fecelets <ui:include> tag but with
partial page navigation in Ajax mode as an advantage.
Note:
Example:
...
<navigation-rule>
<from-view-id>/pages/include/first.xhtml</from-view-id>
<navigation-case>
<from-outcome>next</from-outcome>
<to-view-id>/pages/include/second.xhtml</to-view-id>
</navigation-case>
</navigation-rule>
...
Name Value
component-type org.ajax4jsf.Include
component-family javax.faces.Output
component-class org.ajax4jsf.component.html.Include
renderer-type org.ajax4jsf.components.AjaxIncludeRenderer
142
Chapter 6. The RichFaces Components
6.4.2.1. Description
The <a4j:mediaOutput> component is a facility for generating images, video, sounds and other
binary resources defined by you on-the-fly.
<a4j:mediaOutput
element="img"
cacheable="false"
session="false"
createContent="#{mediaBean.paint}"
value="#{mediaData}"
mimeType="image/
jpeg"/>
As You see from the example above, first it is necessary to specify the kind of media data You
want to generate. This can be done with the help of "element" attribute, which possible values
are img, object, applet, script, link or a.
The "cacheable" defines whether the response will be cached or not. In our case we don't need
our image to be cached, cause we need it to be changed every time we refresh the page.
The "mimeType" attribute defines the type of output content. It is used to define the corresponded
type in the header of an HTTP response.
• "createContent" specifies a method that will be used for content creating. The method accepts
two parameters. The first one — with an java.io.OutputStream type — is a reference to the
stream that should be used for output. An output stream accepts output bytes and sends them
to a recipient. The second parameter is a reference to the component's "value" attribute and
has java.lang.Object type. This parameter contains deserialized object with data specified
in the "value" attribute.
• "value" attribute specifies a bean class that keeps data for transmitting it into a stream in the
method specified with "createContent" .
Now let's create the MediaBean class and specify there a primitive random-number generator and
paint method that will convert the generated numbers into an output stream and give a JPEG
image as a result. The code for MediaBean class is going to look as following:
143
Chapter 6. The RichFaces Components
Example:
package demo;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;
import javax.imageio.ImageIO;
Now it is necessary to create a class that will keep transmissional data that will be used as input
data for a content creation method. The code for MediaData class is going to be as following:
Note:
A bean class transmitted into value should implement Serializable interface in
order to be encoded to the URL of the resource.
Example:
package demo;
144
Chapter 6. The RichFaces Components
import java.awt.Color;
import java.awt.Font;
import java.io.Serializable;
As a result the <a4j:mediaOutput> component will generate the following image that will be
updated on each page refresh:
Hence, when using the component it's possible to output your data of any type on a page with
Ajax requests.
Name Value
component-type org.ajax4jsf.MediaOutput
component-family org.ajax4jsf.Resource
component-class org.ajax4jsf.component.html.MediaOutput
renderer-type org.ajax4jsf.MediaOutputRenderer
145
Chapter 6. The RichFaces Components
6.4.3.1. Description
The component is used for components grouping in the Ajax output area, which offers several
additional output opportunities such as inserting of non-present in tree components, saving of
transient elements after Ajax request and some others.
The <a4j:outputPanel> component is used when one or more components should be always
updated. The component job is similar to that the "reRender" attribute does, but instead of
specifying a comma separated list of components it wraps the components to be updated. This
could be useful in cases when some components aren't rendered during the primary non-ajax
response.
Example:
<a4j:support reRender="mypanel"/>
...
<a4j:outputPanel id="mypanel">
<h:panelGrid rendered="#{not empty foo.bar}">
...
</h:panelGrid>
</a4j:outputPanel>
By default the <a4j:outputPanel> is rendered as opening and closing HTML <span> tags and
functions as container. With the help of the "layout" attribute this output way could be set to any
of three variants:
• "inline" (default)
• "block"
• "none"
If layout="block" is set, the component is rendered as a pair of opening and closing <div>
tags. In this case it is possible to apply available for <div> elements style attributes. layout
146
Chapter 6. The RichFaces Components
="none" helps to avoid an unnecessary tag around a context that is rendered or not according to
the "rendered" attribute value. In case an inner context isn't rendered the <a4j:outputPanel>
is rendered in a <span> tags with ID equal to ID of a child component and display:none style.
If a child component is rendered, <a4j:outputPanel> doesn't present at all in a final code.
Example:
<a4j:support reRender="mypanel"/>
...
<a4j:outputPanel layout="none">
<h:panelGrid id="mypanel" rendered="#{not empty foo.bar}">
...
</h:panelGrid>
</a4j:outputPanel>
As you see, the code is very similar to the one shown above, but "reRender " attribute refers
directly to the updating panelGrid and not to the framing outputPanel, and it's more semantically
correct.
The <a4j:outputPanel> allows to update a part of a page basing on its own flag. The flag is
defined by the "ajaxRendered" attribute. The flag is commonly used when a part of a page must
be updated or can be updated on any response.
Example:
<a4j:outputPanel ajaxRendered="true">
<h:messages/>
</a4j:outputPanel>
The <a4j:outPanel> should be used for non-JSF component part framing, which is to be updated
on Ajax response, as RichFaces specifies the list of updating areas as a list of an existing JSF
component.
On default non-JSF context isn't saved in a component tree, but is rendered anew every time.
To accelerate the processing speed and Ajax response input speed, RichFaces saves non-JSF
context in a component tree on default. This option could be canceled by "keepTransient" attribute
that cancels transient flag forced setting for child components. This flag setting keeps the current
value set by child components.
Note:
In JSF 1.1 implementation and lower, where non-JSF context should be framed
with the <f:verbatim> component, <a4j:outputPanel> doesn't improve this
147
Chapter 6. The RichFaces Components
JSF implementation option in any way, so you still have to use this tag where it's
necessary without RichFaces usage.
RichFaces allows setting Ajax responses rendering directly basing on component tree nodes
without referring to the JSP (XHTML) page code. It could be defined by "selfRendered" attribute
setting to "true" on <a4j:region> and could help considerably speed up a response output.
However, if a transient flag is kept as it is, this rapid processing could cause missing of transient
components that present on view and don't come into a component tree. Hence, for any particular
case you could choose a way for you application optimization: speed up processing or redundant
memory for keeping tree part earlier defined a transient.
Name Value
component-type org.ajax4jsf.OutputPanel
component-family javax.faces.Panel
component-type org.ajax4jsf.ajax.OutputPanel
component-class org.ajax4jsf.component.html.HtmlAjaxOutputPanel
renderer-type org.ajax4jsf.components.AjaxOutputPanelRenderer
Useful articles:
6.5.1.1. Description
The <a4j:page> component encodes the full HTML-page structure and used for solving some
incompatibility in JSP environment with MyFaces in early Ajax4Jsf versions.
148
Chapter 6. The RichFaces Components
The component solves the problem with MyFaces for early Ajax4Jsf versions: in MyFaces
implementation the <f:view> JSP tag doesn't get control for encoding contents during the
RENDER_RESPONSE phase, thus Ajax can't neiher get a control nor make a response. The
<a4j:page> solves this problem by wrapping the Ajax updatable areas. In the last versions of
both frameworks the problem is successfully fixed and no <a4j:page> usage is required.
The component uses facet "head" for defining the contents corresponding to the HTML HEAD.
There is no need to use "body" facet in order to define first body section. The attribute "format"
defines page layout format for encoding DOCTYPE. The attribute "pageTitle" is rendered as
title section.
149
Chapter 6. The RichFaces Components
Name Value
component-type org.ajax4jsf.components.Page
component-family org.ajax4jsf.components.AjaxRegion
component-class org.ajax4jsf.component.html.HtmlPage
renderer-type org.ajax4jsf.components.AjaxPageRenderer
6.5.2.1. Description
The main component purpose is realization of possibility to create several instances the same
portlet on one page. But clientId of elements should be different for each window. In that case
namespace is used for each portlet. The <a4j:portlet> implemets NaimingContainer interface
and adds namespace to all componets on a page. All portlet content should be wrapped by
<a4j:portlet> for resolving problems mentioned before.
Name Value
component-type org.ajax4jsf.Portlet
component-family org.ajax4jsf.component.Portlet
component-class org.ajax4jsf.component.html.HtmlPortlet
150
Chapter 6. The RichFaces Components
Useful publications:
6.5.3.1. Description
The <a4j:htmlCommandLink> component is very similar to the same component from the JSF
HTML library, the only slight difference is in links generation and problem solving that occurs when
an original component is used.
The difference with the original component is that all hidden fields required for command links with
the child <f:param> elements are always rendered and it doesn't depend on links rendering on
the initial page. It solves the problem with invalid links that weren't rendered on a page immediately,
but after some Ajax request.
Example:
<a4j:form>
...
<a4j:htmlComandLink action="action" value="link" rendered="#{bean.rendered}">
<f:param .../>
<a4j:htmlComandLink>
...
</a4j:form>
151
Chapter 6. The RichFaces Components
Name Value
component-type javax.faces.HtmlCommandLink
component-family javax.faces.Command
component-class javax.faces.component.html.HtmlCommandLink
renderer-type org.ajax4jsf.HtmlCommandLinkRenderer
6.5.4.1. Description
The <a4j:log > component generates JavaScript that opens a debug window with useful debug
information.
The <a4j:log > component generates JavaScript that opens a log window with useful debug
information, which contains data on requests and responses, DOM tree changes et al. The log
could be generated not only in a new window, but also on the current page in a separate <div>
element. This feature is controlled with the component "popup" attribute. The window is opened
on pressing of "CTRL+SHIFT+L", which is default registered key. The hot key could be changed
with the "hotkey" attribute, where it's necessary to define one letter that together with "CTRL
+SHIFT" opens a window.
The "level" attribute has several possible values "FATAL", "ERROR", "WARN", "INFO", "ALL"
and is used when it is necessary to change a logging level.
Example:
152
Chapter 6. The RichFaces Components
The component defined this way is decoded on a page as <div> inside a page, where all the
information beginning with informational message is generated.
Note:
Name Value
component-type org.ajax4jsf.Log
component-family org.ajax4jsf.Log
component-class org.ajax4jsf.component.html.AjaxLog
renderer-type org.ajax4jsf.LogRenderer
You can find some cases when <a4j:log> might cause JavaScript error on Ajax Core
Components Page. [http://www.jboss.org/community/wiki/AjaxCoreComponents]
6.6.1.1. Description
153
Chapter 6. The RichFaces Components
Important
The "colspan", "rowspan", and "breakbefore" attributes only affect columns in a
<rich:dataTable>, not those in a <rich:extendedDataTable>.
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" rows="5">
<rich:column>
<f:facet name="header">State Flag</f:facet>
154
Chapter 6. The RichFaces Components
<h:graphicImage value="#{cap.stateFlag}"/>
</rich:column>
<rich:column>
<f:facet name="header">State Name</f:facet>
<h:outputText value="#{cap.state}"/>
</rich:column>
<rich:column >
<f:facet name="header">State Capital</f:facet>
<h:outputText value="#{cap.name}"/>
</rich:column>
<rich:column>
<f:facet name="header">Time Zone</f:facet>
<h:outputText value="#{cap.timeZone}"/>
</rich:column>
</rich:dataTable>
...
Now, in order to group columns with text information into one row in one column with a flag, use
the "colspan" attribute, which is similar to an HTML one, specifying that the first column contains
3 columns. In addition, it's necessary to specify that the next column begins from the first row with
the help of breakBefore="true".
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" rows="5">
<rich:column colspan="3">
<h:graphicImage value="#{cap.stateFlag}"/>
</rich:column>
155
Chapter 6. The RichFaces Components
<rich:column breakBefore="true">
<h:outputText value="#{cap.state}"/>
</rich:column>
<rich:column >
<h:outputText value="#{cap.name}"/>
</rich:column>
<rich:column>
<h:outputText value="#{cap.timeZone}"/>
</rich:column>
</rich:dataTable>
...
The same way is used for columns grouping with the "rowspan" attribute that is similar to an
HTML one responsible for rows quantity definition occupied with the current one. The only thing
to add in the example is an instruction to move onto the next row for each next row after the
second column.
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" rows="5">
<rich:column rowspan="3">
<f:facet name="header">State Flag</f:facet>
156
Chapter 6. The RichFaces Components
<h:graphicImage value="#{cap.stateFlag}"/>
</rich:column>
<rich:column>
<f:facet name="header">State Info</f:facet>
<h:outputText value="#{cap.state}"/>
</rich:column>
<rich:column breakBefore="true">
<h:outputText value="#{cap.name}"/>
</rich:column>
<rich:column breakBefore="true">
<h:outputText value="#{cap.timeZone}"/>
</rich:column>
</rich:dataTable>
...
As a result:
Hence, additionally to a standard output of a particular row provided with the <h:column>
component, it becomes possible to group easily the rows with special HTML attribute.
The columns also could be grouped in a particular way with the help of the <h:columnGroup>
component that is described in the following chapter.
157
Chapter 6. The RichFaces Components
6.6.1.4.1. Sorting
In order to sort the columns you should use the "sortBy" attribute that indicates what values to
be sorted. This attribute can be used only with the <rich:dataTable> component. Expressions in
the "sortBy" attribute can refer only to the variable declared with the "var" attribute, not to those
declared with other attributes such as the "rowKeyVar" attribute. In order to sort the column you
should click on its header. See the following example.
Example:
...
<h:form>
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" width="300px">
<f:facet name="header">
<h:outputText value="Sorting Example"/>
</f:facet>
<rich:column sortBy="#{cap.state}">
<f:facet name="header">
<h:outputText value="State Name"/>
</f:facet>
<h:outputText value="#{cap.state}"/>
</rich:column>
<rich:column sortBy="#{cap.name}">
<f:facet name="header">
<h:outputText value="State Capital"/>
</f:facet>
<h:outputText value="#{cap.name}"/>
</rich:column>
</rich:dataTable>
</h:form>
...
This is result:
158
Chapter 6. The RichFaces Components
The "sortExpression" attribute defines a bean property which is used for sorting a column. This
attribute can be used only with the <rich:scrollableDataTable> component. See the example
of the attribute usage below.
Example:
...
<rich:scrollableDataTable
value="#{dataTableScrollerBean.allCars}" sortMode="single"
var="category">
<rich:column sortExpression="#{category.make}">
<f:facet name="header">
<h:outputText styleClass="headerText" value="Make" />
</f:facet>
<h:outputText value="#{category.make}" />
</rich:column>
<rich:column>
<f:facet name="header">
<h:outputText styleClass="headerText" value="Model" />
</f:facet>
<h:outputText value="#{category.model}" />
</rich:column>
<rich:column>
<f:facet name="header">
<h:outputText styleClass="headerText" value="Price" />
</f:facet>
<h:outputText value="#{category.price}" />
</rich:column>
</rich:scrollableDataTable>
159
Chapter 6. The RichFaces Components
...
The "selfSorted" attribute is meant for adding the possibility of automatic sorting by clicking on
the column header. Default value is "true". In the example below the second column is unavailable
for sorting.
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap">
<rich:column>
<f:facet name="header">
<h:outputText value="State Flag"/>
</f:facet>
<h:graphicImage value="#{cap.stateFlag}"/>
</rich:column>
<rich:column sortBy="#{cap.state}" selfSorted="false">
<f:facet name="header">
<h:outputText value="State Name"/>
</f:facet>
<h:outputText value="#{cap.state}"/>
</rich:column>
</rich:dataTable>
...
The "sortOrder" attribute is used for changing the sort order of columns by means of external
controls.
Example:
...
<h:form>
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" width="300px">
<f:facet name="header">
<h:outputText value="Sorting Example"/>
160
Chapter 6. The RichFaces Components
</f:facet>
<rich:column sortBy="#{cap.state}" sortOrder="ASCENDING">
<f:facet name="header">
<h:outputText value="State Name"/>
</f:facet>
<h:outputText value="#{cap.state}"/>
</rich:column>
<rich:column sortBy="#{cap.name}" sortOrder="DESCENDING">
<f:facet name="header">
<h:outputText value="State Capital"/>
</f:facet>
<h:outputText value="#{cap.name}"/>
</rich:column>
</rich:dataTable>
</h:form>
...
In the example above the first column is sorted in descending order. But if recurring rows appear
in the table the relative second column are sorted in ascending order.
If the values of the columns are complex, the "sortOrder" attribute should point to a bean
property containing the sort order. See how it's done in the LiveDemo [http://livedemo.exadel.com/
richfaces-demo/richfaces/columns.jsf?c=columns&tab=usage] for <rich:columns> .
You can customize the sorting's icon element using "rich-sort-icon" class.
161
Chapter 6. The RichFaces Components
Note
In order to sort a column with the values not in English you can add the
org.richfaces.datatableUsesViewLocale context parameter in your web.xml.
Its value should be "true".
Note:
6.6.1.4.2. Filtering
• Using built-in filtering. It uses startsWith() function to make filtering. In this case you need to
define the "filterBy" attribute at a column you want to be filterable. This attribute defines iterable
object property which is used when filtering performed. Expressions in the "filterBy" attribute
can refer only to the variable declared with the "var" attribute, not to those declared with other
attributes such as the "rowKeyVar" attribute.
The "filterValue" attribute is used to get or change current filtering value. It could be defined with
initial filtering value on the page or as value binding to get/change it on server. If the "filterValue"
attribute isn't empty from the beginning table is filtered on the first rendering.
You can customize the input form using "rich-filter-input" CSS class.
In order to change filter event you could use "filterEvent" attribute on column, e.g.
"onblur"(default value).
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" width="200px">
<f:facet name="header">
<h:outputText value="Sorting Example"/>
</f:facet>
162
Chapter 6. The RichFaces Components
• Using external filtering. In this case you need to write your custom filtering function or expression
and define controls.
The "filterExpression" attribute is used to define expression evaluated to boolean value. This
expression checks if the object satisfies filtering condition.
The "filterMethod" attribute is defined with method binding. This method accepts on Object
parameter and returns boolean value. Thus, this method also could be used to check if the object
satisfies filtering condition or not. The usage of this attribute is the best way for implementing
your own complex business logic.
163
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.Column
component-class org.richfaces.component.html.HtmlColumn
component-family org.richfaces.Column
renderer-type org.richfaces.renderkit.CellRenderer
tag-class org.richfaces.taglib.ColumnTag
Custom style classes as well as skin parameters for <rich:column> are the same as for the
<rich:dataTable> component.
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
See the example on how to use the "rendered" attribute of <rich:column> in the RichFaces
Cookbook article [http://www.jboss.org/community/docs/DOC-9607].
6.6.2.1. Description
The component combines columns in one row to organize complex subparts of a table.
164
Chapter 6. The RichFaces Components
The <rich:columnGroup> component combines columns set wrapping them into the <tr>
element and outputting them into one row. Columns are combined in a group the same way as
when the "breakBefore" attribute is used for columns to add a moving to the next rows, but the
first variant is clearer from a source code. Hence, the following simple examples are very same.
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" rows="5" id="sublist">
<rich:column colspan="3">
<f:facet name="header">State Flag</f:facet>
<h:graphicImage value="#{cap.stateFlag}"/>
</rich:column>
<rich:columnGroup>
165
Chapter 6. The RichFaces Components
<rich:column>
<h:outputText value="#{cap.state}"/>
</rich:column>
<rich:column >
<h:outputText value="#{cap.name}"/>
</rich:column>
<rich:column >
<h:outputText value="#{cap.timeZone}"/>
</rich:column>
</rich:columnGroup>
</rich:dataTable>
...
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" rows="5" id="sublist">
<rich:column colspan="3">
<f:facet name="header">State Flag</f:facet>
<h:graphicImage value="#{cap.stateFlag}"/>
</rich:column>
<rich:column breakBefore="true">
<h:outputText value="#{cap.state}"/>
</rich:column>
<rich:column>
<h:outputText value="#{cap.name}"/>
</rich:column>
<rich:column>
<h:outputText value="#{cap.timeZone}"/>
</rich:column>
</rich:dataTable>
....
166
Chapter 6. The RichFaces Components
It's also possible to use the component for output of complex headers in a table. For example,
adding of a complex header to a facet for the whole table looks the following way:
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" rows="5" id="sublist">
<f:facet name="header">
<rich:columnGroup>
<rich:column rowspan="2">
<h:outputText value="State Flag"/>
</rich:column>
<rich:column colspan="3">
<h:outputText value="State Info"/>
</rich:column>
<rich:column breakBefore="true">
<h:outputText value="State Name"/>
</rich:column>
<rich:column>
<h:outputText value="State Capital"/>
</rich:column>
<rich:column>
<h:outputText value="Time Zone"/>
</rich:column>
167
Chapter 6. The RichFaces Components
</rich:columnGroup>
</f:facet>
<rich:column>
<h:graphicImage value="#{cap.stateFlag}"/>
</rich:column>
<rich:column>
<h:outputText value="#{cap.state}"/>
</rich:column>
<rich:column>
<h:outputText value="#{cap.name}"/>
</rich:column>
<rich:column>
<h:outputText value="#{cap.timeZone}"/>
</rich:column>
</rich:dataTable>
...
Name Value
component-type org.richfaces.ColumnGroup
component-class org.richfaces.component.html.HtmlColumnGroup
component-family org.richfaces.ColumnGroup
168
Chapter 6. The RichFaces Components
Name Value
renderer-type org.richfaces.ColumnGroupRenderer
tag-class org.richfaces.taglib.ColumnGroupTag
Custom style classes as well as skin parameters for <rich:columnGroup> are the same as for
the <rich:dataTable> component.
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.6.3.1. Description
The <rich:columns> is a component, that allows you to create a dynamic set of columns from
your model.
169
Chapter 6. The RichFaces Components
The <rich:columns> component gets a list from data model and outputs a corresponding set of
columns inside <rich:dataTable> on a page. It is possible to use "header" and "footer" facets
with <rich:columns> component.
The "value" and "var" attributes are used to access the values of collection.
Example:
...
<rich:dataTable value="#{dataTableScrollerBean.model}" var="model" width="750">
<rich:columns value="#{dataTableScrollerBean.columns}" var="columns"
index="ind" id="column#{ind}">
<f:facet name="header">
<h:outputText value="#{columns.header}" />
</f:facet>
The "rowspan" attribute defines the number of rows to be displayed. If the value of this attribute
is zero, all remaining rows in the table are displayed on a page.
The "begin" attribute contains the first iteration item. Note, that iteration begins from zero.
With the help of the attributes described above you can customize the output, i.e. define which
columns and how many rows appear on a page.
The <rich:columns> component does not prevent to use <rich:column> . In the following
example one column renders in any way and another columns are picked from the model.
170
Chapter 6. The RichFaces Components
Example:
...
<rich:dataTable value="#{dataTableScrollerBean.model}" var="model" width="500px" rows="5">
<f:facet name="header">
<h:outputText value="Cars Available"></h:outputText>
</f:facet>
<rich:columns value="#{dataTableScrollerBean.columns}" var="columns" index="ind">
<f:facet name="header">
<h:outputText value="#{columns.header}" />
</f:facet>
<h:outputText value="#{model[ind].model} " />
</rich:columns>
<rich:column>
<f:facet name="header">
<h:outputText value="Price" />
</f:facet>
<h:outputText value="Price" />
</rich:column>
<rich:columns value="#{dataTableScrollerBean.columns}" var="columns" index="ind">
<f:facet name="header">
<h:outputText value="#{columns.header}" />
</f:facet>
<h:outputText value="#{model[ind].mileage}$" />
</rich:columns>
</rich:dataTable>
...
The grouping some columns into one column or one row with the help of the "colspan", "rowspan"
and "breakBefore" attributes can be perform for <rich:columns> the same way as for the
<rich:columnt> component [155].
Note:
171
Chapter 6. The RichFaces Components
...
<rich:dataTable value="#{bean.data}" var="var">
<rich:columns value="#{var.columns}">
...
</rich:columns>
</rich:dataTable>
...
...
<c:forEach items="#{bean.data}" var="var">
<rich:columns value="#{var.columns}">
...
</rich:columns>
</c:forEach>
...
Note:
...
<rich:columns value="#{bean.columns}" var="col" index="ind" ... >
<h:inputText id="input#{ind}" value="">
<a4j:support id="support#{ind}" event="onchange" reRender="someId" />
</h:inputText>
</rich:columns>
...
Only if "id" defined as shown above Ajax after onchange event will be processed
as expected.
172
Chapter 6. The RichFaces Components
Sorting and filtering for the <rich:columns> component works the same as for <rich:column>
. See the "Sorting and Filtering" section.
Name Value
component-type org.richfaces.Column
tag-class org.richfaces.taglib.ColumnsTagHandler
Custom style classes as well as skin parameters for <rich:columns> are the same as for the
<rich:dataTable> component.
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.6.4.1. Description
The component to render definition lists that allows choosing data from a model and obtains built-
in support of Ajax updates.
173
Chapter 6. The RichFaces Components
The component has the "term" facet, which corresponds to the "type" parameter for the <dt>
HTML element.
Here is an example:
...
<h:form>
174
Chapter 6. The RichFaces Components
...
This is a result:
In the example the "rows" attribute limits a number of output elements of the list.
The "first" attribute defines the first element for output. "title" is used for a popup title.
Name Value
component-type org.richfaces.DataDefinitionList
component-class org.richfaces.component.html.HtmlDataDefinitionList
component-family org.richfaces.DataDefinitionList
renderer-type org.richfaces.DataDefinitionListRenderer
tag-class org.richfaces.taglib.DataDefinitionListTag
175
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.6.5.1. Description
176
Chapter 6. The RichFaces Components
The dataFilterSlider component is bound to some UIData component using the "for" attribute
and filters data in a table.
Example:
...
<rich:dataFilterSlider sliderListener="#{mybean.doSlide}"
startRange="0"
endRange="50000"
increment="10000"
handleValue="1"
for="carIndex"
forValRef="inventoryList.carInventory"
filterBy="getMileage" />
...
<h:dataTable id="carIndex">
...
</h:dataTable>
...
• "forValRef" is a string which is used in a value attribute of the target UIData component. It's
designed for resetting the UIData component back to the original list provided by a backing bean.
• "filterBy" is a getter of an object member that is to be compared to a slider value. It's a value
that is used in results filtering.
"handleValue" is an attribute for keeping the current handle position on the dataFilterSlider
component. Based on the current value, appropriate values obtained from a getter method defined
in "filterBy" are filtered.
One more important attribute is a "storeResults" one that allows the dataFilterSlider component
to keep UIData target object in session.
177
Chapter 6. The RichFaces Components
If it's necessary the component submits a form on event of a handle state changing, use the
"submitOnSlide" attribute. When the attribute definition is "true", submission on this event is
defined.
Information about the "process" attribute usage you can find in the "Decide what to process "
guide section.
Name Value
component-type org.richfaces.DataFilterSlider
component-class org.richfaces.component.html.HtmlDataFilterSlider
component-family org.richfaces.DataFilterSlider
renderer-type org.richfaces.DataFilterSliderRenderer
tag-class org.richfaces.taglib.dataFilterSliderTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
178
Chapter 6. The RichFaces Components
6.6.6.1. Description
The component to render data as a grid that allows choosing data from a model and obtains built-
in support of Ajax updates.
The component takes a list from a model and outputs it the same way as with <h:panelGrid> for
inline data. To define grid properties and styles, use the same definitions as for <h:panelGrid>.
179
Chapter 6. The RichFaces Components
• Limit number of output elements ( "elements" attribute) and define first element for output (
"first" attribute)
Here is an example:
Example:
...
<rich:panel style="width:150px;height:200px;">
<h:form>
This is a result:
180
Chapter 6. The RichFaces Components
The component was created basing on the <a4j:repeat> component and as a result it could
be partially updated with Ajax. "ajaxKeys" attribute allows to define row keys that are updated
after an Ajax request.
Here is an example:
Example:
...
<rich:dataGrid value="#{dataTableScrollerBean.allCars}" var="car" ajaxKeys="#{listBean.list}"
binding="#{listBean.dataGrid}" id="grid" elements="4" columns="2">
...
</rich:dataGrid>
...
<a4j:commandButton action="#{listBean.action}" reRender="grid" value="Submit"/>
...
In the example "reRender" attribute contains value of "id" attribute for <rich:dataGrid>
component. As a result the component is updated after an Ajax request.
181
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.DataGrid
component-class org.richfaces.component.html.HtmlDataGrid
component-family org.richfaces.DataGrid
renderer-type org.richfaces.DataGridRenderer
tag-class org.richfaces.taglib.DataGridTag
Custom style classes as well as skin parameters for <rich:dataGrid> are the same as for the
<rich:dataTable> component.
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.6.7.1. Description
The component to render unordered lists that allows choosing data from a model and obtains
built-in support of Ajax updates.
182
Chapter 6. The RichFaces Components
The component has the "type" attribute, which corresponds to the "type" parameter for the
<ul> HTML element and defines a marker type. Possible values for "type" attribute are: "disc",
"circle", "square".
Here is an example:
...
<h:form>
<rich:dataListvar="car"value="#{dataTableScrollerBean.allCars}"rows="5"type="disc"title="Car
Store">
<h:outputText value="#{car.make} #{car.model}"/><br/>
<h:outputText value="Price:" styleClass="label"></h:outputText>
<h:outputText value="#{car.price} "/><br/>
<h:outputText value="Mileage:" styleClass="label"></h:outputText>
<h:outputText value="#{car.mileage} "/><br/>
</rich:dataList>
</h:form>
...
183
Chapter 6. The RichFaces Components
This is a result:
In the example the "rows" attribute limits a number of output elements of the list.
The "first" attribute defines the first element for output. "title" is used for a popup title. See the
picture below:
The <rich:dataList> component could be partially updated with Ajax. The "ajaxKeys" attribute
points to an Object (java.util.Set) that contains row keys to be updated after an Ajax request. See
an example of usage the attribute in the Using the ajaxKeys attribute for <rich:dataList> [http://
www.jboss.org/community/wiki/UsingtheajaxKeysattributeforrichdataList] article in the RichFaces
Cookbook.
184
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.DataList
component-class org.richfaces.component.html.HtmlDataList
component-family org.richfaces.DataList
renderer-type org.richfaces.DataListRenderer
tag-class org.richfaces.taglib.DataListTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.6.8.1. Description
The component to render ordered lists that allows choosing data from a model and obtains built-
in support of Ajax updates.
185
Chapter 6. The RichFaces Components
The component has the "type" attribute, which corresponds to the "type" parameter for the
<ol> HTML element and defines a marker type. Possible values for "type" attribute are: "A",
"a", "I", "i", "1".
Here is an example:
...
<h:form>
<rich:dataOrderedListvar="car"value="#{dataTableScrollerBean.allCars}"rows="5"type="1"
title="Car
Store">
<h:outputText value="#{car.make} #{car.model}"/><br/>
<h:outputText value="Price:" styleClass="label"></h:outputText>
<h:outputText value="#{car.price}" /><br/>
<h:outputText value="Mileage:" styleClass="label"></h:outputText>
<h:outputText value="#{car.mileage}" /><br/>
</rich:dataOrderedList>
</h:form>
...
This is a result:
186
Chapter 6. The RichFaces Components
In the example the "rows" attribute limits a number of output elements of the list.
The "first" attribute defines the first element for output. "title" is used for a popup title.
The <rich:dataOrderedList> component could be partially updated with Ajax. The "ajaxKeys"
attribute points to an Object (java.util.Set) that should contain row keys to be updated
after an Ajax request. See an example of usage the "ajaxKeys" attribute for the
<rich:dataList> component in the RichFacs Cookbook article [http://www.jboss.org/community/
wiki/UsingtheajaxKeysattributeforrichdataList].
Name Value
component-type org.richfaces.DataOrderedList
component-class org.richfaces.component.html.HtmlDataOrderedList
component-family org.richfaces.DataOrderedList
renderer-type org.richfaces.DataOrderedListRenderer
tag-class org.richfaces.taglib.DataOrderedListTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
187
Chapter 6. The RichFaces Components
6.6.9.1. Description
The component designed for providing the functionality of tables scrolling using Ajax requests.
• Skin support
188
Chapter 6. The RichFaces Components
The component should be placed into the footer of the parent table or be bound to it with the
"for" attribute. Note, that "for" is evaluated on view build, not on view render, that is why it will
ignore JSTL tags.
The table should also have the defined "rows" attribute limiting the quantity of inputted table rows.
The scroller could limit the maximum quantity of rendered links on the table pages with the help
of the "maxPages" attribute.
• The controls of fast switching: "first", "last", "next", "previous", "fastforward", "fastrewind"
The controls of fast switching are created adding the facets component with the corresponding
name:
Example:
...
<rich:datascroller for="table" maxPages="10">
<f:facet name="first">
<h:outputText value="First"/>
</f:facet>
<f:facet name="last">
<h:outputText value="Last"/>
</f:facet>
</rich:datascroller>
...
189
Chapter 6. The RichFaces Components
There are also facets used to create the disabled states: "first_disabled",
"last_disabled", "next_disabled", "previous_disabled", "fastforward_disabled",
"fastrewind_disabled".
The "page" is a value-binding attribute used to define and save the current page number. The
example is placed below.
Example:
...
<h:form id="myForm">
190
Chapter 6. The RichFaces Components
<h:column>
<h:outputText value="Price" />
</h:column>
</rich:columnGroup>
</f:facet>
<h:column>
<h:outputText value="#{category.make}" />
</h:column>
<h:column>
<h:outputText value="#{category.model}" />
</h:column>
<h:column>
<h:outputText value="#{category.price}" />
</h:column>
</rich:dataTable>
<rich:datascroller
id="sc2"
for="carList"
reRender="sc1"
maxPages="7"
page="#{dataTableScrollerBean.scrollerPage}"
/
>
<h:panelGrid>
<h:panelGroup>
<h:outputText value="Set current page number:" />
<h:inputText value="#{dataTableScrollerBean.scrollerPage}" id="sc1" size="1"/>
<h:commandButton value="Set" />
</h:panelGroup>
</h:panelGrid>
</h:form>
...
In the example above you can enter the page number you want and set it by clicking on the
<h:commandButton> . By the way, if you use <rich:datascroller> page links the input field
rerenders and current page number changes.
191
Chapter 6. The RichFaces Components
The "pageIndexVar" and "pagesVar" attributes define a request scope variables and provide
an ability to show the current page and the number of pages in the <rich:datascroller> .
These attributes are used for definition the names of variables, that is used in the facet with name
"pages" . An example can be found below:
Example:
...
<h:form>
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" rows="5">
<rich:column>
<h:outputText value="#{cap.name}" />
</rich:column>
<f:facet name="footer">
<rich:datascroller pageIndexVar="pageIndex" pagesVar="pages">
<f:facet name="pages">
<h:outputText value="#{pageIndex} / #{pages}" />
</f:facet>
</rich:datascroller>
</f:facet>
</rich:dataTable>
</h:form>
...
It's possible to insert optional separators between controls. For this purpose use a
"controlsSeparator" facet. An example is placed below.
192
Chapter 6. The RichFaces Components
...
<f:facet name="controlsSeparator">
<h:graphicImage value="/image/sep.png"/>
</f:facet>
...
Starting from 3.2.1 of RichFaces multiple <rich:datascroller> instances behavior and page
bindings are corrected. Incorrect page after model changes handling is added. Phase Listener
called before RenderResponce scans the page for the <rich:datascroller> and performs the
following operations:
• Checks if the <rich:datascroller> is rendered. (If the checking generates an exception, the
<rich:datascroller> is considered to be not rendered )
Information about the "process" attribute usage you can find in the " Decide what to process
" guide section.
Note:
Make sure, that all <rich:datascroller> components, defined for a table, have
same values for all "page" attributes. The page, specified in the last "page" , will
be rendered in browser.
Name Value
component-type org.richfaces.Datascroller
component-class org.richfaces.component.html.HtmlDatascroller
component-family org.richfaces.Datascroller
renderer-type org.richfaces.DataScrollerRenderer
tag-class org.richfaces.taglib.DatascrollerTag
193
Chapter 6. The RichFaces Components
Function Description
switchToPage(page) Switches to the defined page, "page" is
Number or String
next() Navigates to the next page
previous() Navigates to the previous page
first() Navigates to the first page
last() Navigates to the last page
fastForward() Navigates ahead over a certain number of
pages. The number of pages to traverse is
defined with fastStep attribute
fastRewind() Navigates backwards over a certain number
of pages. The number of pages to traverse is
defined with fastStep attribute
Facet Description
controlsSeparator Redefines optional separators between
controls
first Redefines the "first" button with the content set
first_disabled Redefines the disabled "first" button with the
content set
last Redefines the "last" button with the content set
last_disabled Redefines the disabled "last" button with the
content set
fastrewind Redefines the "fastrewind" button with the
content set
fastrewind_disabled Redefines the disabled "fastrewind" button with
the content set
fastforward Redefines the "fastforward" button with the
content set
fastforward_disabled Redefines the disabled "fastforward" button
with the content set
previous Redefines the "previous" button with the
content set
previous_disabled Redefines the disabled "previous" button with
the content set
next Redefines the "next" button with the content set
194
Chapter 6. The RichFaces Components
Facet Description
next_disabled Redefines the disabled "next" button with the
content set
pages Redefines the pages buttons with the content
set
195
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
The solution about how to do correct pagination using datascroller (load a part of data from
database) can be found on the RichFaces Users Forum [http://www.jboss.com/index.html?
module=bb&op=viewtopic&p=4060199#4060199].
Here [http://www.jboss.org/community/wiki/
HowtousepairofrichdatascrollersoutsidetheanydataTable] you can find out how to use pair of
<rich:datascrollers> outside the any dataTable.
6.6.10.1. Description
The component is meant for rendering tables. It allows choosing data from a model and obtains
built-in support of Ajax updates.
196
Chapter 6. The RichFaces Components
Extended table features, such as scrollable data, row selection, and column re-ordering, require
the use of the <rich:extendedDataTable> component instead of <rich:dataTable>. Refer to the
<rich:extendedDataTable> section for details on the differences between the two components.
Note:
If you need to render a table with some extended features like data scrolling, hiding
the columns with the help of the context menu and some others, then use the
<rich:extendedDataTable> component instead.
197
Chapter 6. The RichFaces Components
The component allows to use "header" , "footer" and "caption" facets for output. See an example
below:
Example:
...
<rich:dataTable value="#{capitalsBean.capitals}" var="cap" rows="5">
<f:facet name="caption">
<h:outputText value="United States Capitals" />
</f:facet>
<f:facet name="header">
<h:outputText value="Capitals and States Table" />
</f:facet>
<rich:column>
<f:facet name="header">State Flag</f:facet>
<h:graphicImage value="#{cap.stateFlag}"/>
<f:facet name="footer">State Flag</f:facet>
</rich:column>
<rich:column>
<f:facet name="header">State Name</f:facet>
<h:outputText value="#{cap.state}"/>
<f:facet name="footer">State Name</f:facet>
</rich:column>
<rich:column >
<f:facet name="header">State Capital</f:facet>
<h:outputText value="#{cap.name}"/>
<f:facet name="footer">State Capital</f:facet>
</rich:column>
<rich:column>
<f:facet name="header">Time Zone</f:facet>
<h:outputText value="#{cap.timeZone}"/>
<f:facet name="footer">Time Zone</f:facet>
</rich:column>
<f:facet name="footer">
<h:outputText value="Capitals and States Table" />
</f:facet>
</rich:dataTable>
...
This is a result:
198
Chapter 6. The RichFaces Components
Information about sorting and filtering you can find in the corresponding section.
You can find information how to remove header's gradient in the "How to remove rich:dataTable
header background " article [http://wiki.jboss.org/wiki/RichFacesDataTableBackgroundOut].
Name Value
component-type org.richfaces.DataTable
component-class org.richfaces.component.html.HtmlDataTable
component-family org.richfaces.DataTable
renderer-type org.richfaces.DataTableRenderer
tag-class org.richfaces.taglib.DataTableTag
Facet Description
header Redefines the header content
199
Chapter 6. The RichFaces Components
Facet Description
footer Redefines the footer content
caption Defines the caption content
200
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
The article about <rich:dataTable> flexibility can be found in the "rich:dataTable Flexibility "
article [http://www.jboss.org/community/docs/DOC-11847].
201
Chapter 6. The RichFaces Components
6.6.11.1. Description
The component is used for inserting subtables into tables with opportunity to choose data from a
model and built-in Ajax updates support.
202
Chapter 6. The RichFaces Components
The <rich:subTable> component is similar to the <h:dataTable> one, except Ajax support
and skinnability. One more difference is that the component doesn't add the wrapping <table>
and <tbody> tags. Ajax support is possible, because the component was created basing
on the <a4j:repeat> component and as a result it could be partially updated with Ajax.
The "ajaxKeys" attribute allows to define row keys which are updated after an Ajax request.
You can find an example which demonstrate the usage of the "ajaxKeys" attributes for data
iteration components in the RichFaces Cookbook article [http://www.jboss.org/community/wiki/
UsingtheajaxKeysattributeforrichdataList].
The component allows to use "header" and "footer" facets for output. See an example for
<rich:dataTable> component [198].
Name Value
component-type org.richfaces.SubTable
component-class org.richfaces.component.html.HtmlSubTable
component-family org.richfaces.SubTable
renderer-type org.richfaces.SubTableRenderer
tag-class org.richfaces.taglib.SubTableTag
203
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.6.12.1. Description
The component is meant for rendering tables and differs from the standard <rich:dataTable>
component in that supports some extended features.
204
Chapter 6. The RichFaces Components
• Possibility to add an attribute to set the kind of selection (none, single line or multiple lines)
• Possibility to change the sequence of the displayed columns by dragging the column-header
to another position
• Possibility to save the current settings (visible columns, column width, sequence of the columns)
to be reused the next time the page will be shown
• activeClass
• activeRowKey
• enableContextMenu
• groupingColumn
• height
• noDataLabel
• onselectionchange
• selectedClass
205
Chapter 6. The RichFaces Components
• selection
• selectionMode
• tableState
• columns
• columnsWidth
• onRowContextMenu
Here is an example:
Example:
...
<rich:extendedDataTable id="edt" value="#{extendedDT.dataModel}" var="edt" width="500px" height="500px" sel
206
Chapter 6. The RichFaces Components
Information about sorting and filtering can be found in RichFaces Developer Guide section on
sorting.
For external filtering the <rich:extendedDataTable> component supports the "filter" facet for
<rich:column> . In this facet you can define your own controls for filtering which will be positioned
like built-in filter controls. Rest of the filter scenario is the same as described in the RichFaces
Developer Guide section on filtering.
In the example the "selection" attribute contains an object with selected rows.
Note:
The "height" attribute is mandatory. The default value is "500px" .
207
Chapter 6. The RichFaces Components
Menu on the right side of the column header is used to perform actions like sorting, grouping,
hiding columns.
This is an example:
After selecting a "Group by this column" option, you can see the data grouped. You can collapse
and expand groups by clicking on a group header.
This is an example:
The "label" attribute in <rich:column> sets the name of the column, which is used when
dragging columns (in drag window) and in context menu, in "Columns" submenu.
Example:
...
<rich:column id="name" label="#{msg['name']}"
...
208
Chapter 6. The RichFaces Components
The "tableState" attribute can be used to bind state of the table (column width, column position,
visible, sequence, grouping...) to a backing-bean string property, for a later used. This state can be
for example saved to a database, and it is different from standard JSF state saving mechanisms.
Example:
...
209
Chapter 6. The RichFaces Components
<rich:extendedDataTable tableState="#{extendedDT.tableState}">
...
Name Value
component-type org.richfaces.ExtendedDataTable
component-class org.richfaces.component.html.HtmlExtendedDataTable
component-family org.richfaces.ExtendedDataTable
renderer-type org.richfaces.ExtendedDataTableRenderer
tag-class org.richfaces.taglib.ExtendedDataTableTag
Facet Description
header Redefines the header content
footer Redefines the footer content
caption Redefines the caption content
210
Chapter 6. The RichFaces Components
211
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
Some additional information about the component usage can be found on its
LiveDemo page [http://livedemo.exadel.com/richfaces-demo/richfaces/extendedDataTable.jsf?
c=extendedDataTable].
212
Chapter 6. The RichFaces Components
6.6.13.1. Description
The <a4j:repeat> component implements a basic iteration component that allows to update a
set of its children with Ajax.
The <a4j:repeat> component is similar to Facelets <ui:repeat> tag, which is used to iterate
through a collection of objects binded with JSF page as EL expression. The main difference of the
<a4j:repeat> is a possibility to update particular components (it's children) instead of all using
Ajax requests. The feature that makes the component different is a special "ajaxKeys" attribute
that defines row that are updated after an Ajax request. As a result it becomes easier to update
several child components separately without updating the whole page.
...
<table>
<tbody>
The example above points to a method that contains row keys to be updated.
Note:
The <a4j:repeat> component is defined as fully updated, but really updated there
are only the row keys which defined in the "ajaxKeys" attribute.
One more benefit of this component is absence of strictly defined markup as JSF HTML DataTable
and TOMAHAWK DataTable have. Hence the components could be used more flexibly anywhere
where it's necessary to output the results of selection from some collection.
If you want to output a collection as a plain HTML list, use the following structure:
213
Chapter 6. The RichFaces Components
...
<ul>
<a4j:repeat ...>
<li>...<li/>
...
<li>...<li/>
</a4j:repeat>
</ul>
...
All other general attributes of the component are defined according to the similar attributes of
iterative components ( <h:dataTable> or <ui:repeat> ) and are used in the same way.
Name Value
component-type org.ajax4jsf.Repeat
component-family javax.faces.Data
component-class org.ajax4jsf.component.html.HtmlAjaxRepeat
renderer-type org.ajax4jsf.components.RepeatRenderer
6.6.14.1. Description
214
Chapter 6. The RichFaces Components
• Dynamically fetching the rows from the server when the table is scrolled up and down
• activeClass
• activeRowKey
215
Chapter 6. The RichFaces Components
• bypassUpdates
• data
• eventsQueue
• frozenColCount
• height
• hideWhenScrolling
• ignoreDupResponses
• onselectionchange
• requestDelay
• scriptVar
• selectedClass
• selection
• selectionMode
• similarityGroupingId
• sortOrder
• status
• timeout
• align
• bgcolor
• border
• captionClass
• captionStyle
• cellpadding
• cellspacing
• columns
• columnsWidth
216
Chapter 6. The RichFaces Components
• dir
• frame
• lang
• onRowContextMenu
• onRowMouseMove
• onRowMouseOut
• onRowMouseOver
• onclick
• ondblclick
• onkeydown
• onkeypress
• onkeyup
• onmousedown
• onmousemove
• onmouseout
• onmouseover
• onmouseup
• rules
• sortPriority
• title
Using <rich:column>
The component represents on a page as a scrollable table with some fixed (non-scrollable) rows
( with header and footer) and columns. Like other tables <rich:scrollableDataTable> also has
217
Chapter 6. The RichFaces Components
optional footer and header that could be implemented using the corresponding facets. Columns
of the table are optionally resizable. Resizing is available using "drag and drop" of the column
vertical borders. You can define the number of the fixed columns from the left side using the
"frozenColCount" attribute that is not scrolled via horizontal scroll.
It's possible to select the whole row with onclick on the row or some set of rows. Selection is
optional and availability of such feature is defined on the component. There are two ways to select
a few rows:
• Clicking some row with the SHIFT button hold. In this case all the rows starting from last selected
up to clicked should be selected.
It's possible to sort the table content after clicks on the header. The feature is optional (to disable it,
use the "sortable" attribute in <rich:column>). Every column should be pointed to the comparator
method that is used for sorting the table. In case the <rich:scrollableDataTable> is already
sorted by some column and the header of this column has been clicked again - the sorting is
reversed.
...
<rich:scrollableDataTable value="#{modelBuilder.model}" var="issues"
frozenColCount="1"
first="0"
rows="40"
width="300px"
height="396px">
<rich:column width="100px">
<f:facet name="header" >
<h:outputText value="State"/>
</f:facet>
<h:outputText value="#{issues.cell1}"/>
<f:facet name="footer">
<h:outputText value="State"/>
</f:facet>
</rich:column>
<!--Set of columns and header/footer facets-->
</rich:scrollableDataTable>
...
218
Chapter 6. The RichFaces Components
The "selection" attribute allows to get the row data when using one and multi-selection rows
mode.
In the following example when you submit the form, the current collection of the selected objects
is placed in the object's property. Then on complete action the <rich:modalPanel> with selected
data is shown.
Example:
...
<h:form>
<rich:spacer height="30" />
<rich:scrollableDataTable rowKeyVar="rkv" frozenColCount="1" height="200px"
width="300px" id="carList" rows="40" columnClasses="col"
value="#{dataTableScrollerBean.allCars}" var="category" sortMode="single"
selection="#{dataTableScrollerBean.selection}">
<rich:column id="make">
<f:facet name="header"><h:outputText styleClass="headerText" value="Make" /
></f:facet>
<h:outputText value="#{category.make}" />
</rich:column>
<rich:column id="model">
<f:facet name="header"><h:outputText styleClass="headerText" value="Model" /
></f:facet>
<h:outputText value="#{category.model}" />
</rich:column>
<rich:column id="price">
<f:facet name="header"><h:outputText styleClass="headerText" value="Price" /
></f:facet>
<h:outputText value="#{category.price}" />
</rich:column>
</rich:scrollableDataTable>
<rich:spacer height="20px"/>
<a4j:commandButton value="Show Current Selection" reRender="table"
action="#{dataTableScrollerBean.takeSelection}"
oncomplete="javascript:Richfaces.showModalPanel('panel');"/>
</h:form>
<rich:modalPanel id="panel" autosized="true">
<f:facet name="header">
<h:outputText value="Selected Rows"/>
</f:facet>
219
Chapter 6. The RichFaces Components
<f:facet name="controls">
<span style="cursor:pointer" onclick="javascript:Richfaces.hideModalPanel('panel')">X</
span>
</f:facet>
<rich:dataTable value="#{dataTableScrollerBean.selectedCars}" var="sel" id="table">
<rich:column>
<f:facet name="header"><h:outputText value="Make" /></f:facet>
<h:outputText value="#{sel.make}" />
</rich:column>
<rich:column id="model">
<f:facet name="header"><h:outputText value="Model" /></f:facet>
<h:outputText value="#{sel.model}" />
</rich:column>
<rich:column id="price">
<f:facet name="header"><h:outputText value="Price" /></f:facet>
<h:outputText value="#{sel.price}" />
</rich:column>
</rich:dataTable>
</rich:modalPanel>
...
This is a result:
The <rich:scrollableDataTable> component has the following extra attributes for event
processing on the client:
220
Chapter 6. The RichFaces Components
• "onselectionchange"
• "onRowClick"
• "onRowDblClick"
• "onRowMouseUp"
• "onRowMouseDown"
Starting with the 3.3.1 version of the components framework it becomes possible to switch
selection mode with the "selectionMode" attribute.
Information about sorting and filtering you can find in the RichFaces Developer guide section
about sorting.
Information on the "process" attribute usage you can find in the "Decide what to process" guide
section.
Note:
If you want to use specific features such as pagination on database level you should
pass to the "value" of the <rich:scrollableDataTable> component an object
which class extends org.richfaces.model.ScrollableTableDataModel.
Name Value
component-type org.richfaces.component.ScrollableDataTable
component-class org.richfaces.component.html.HtmlScrollableDataTable
component-family org.richfaces.component.ScrollableDataTable
renderer-type org.richfaces.renderkit.html.ScrollableDataTableRenderer
tag-class org.richfaces.taglib.ScrollableDataTableTag
Facet Description
header Defines the header content
footer Defines the footer content
221
Chapter 6. The RichFaces Components
222
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.7.1.1. Description
This is a component for defining what appears under the mouse cursor during drag-and-drop
operations. The displayed drag indicator can show information about the dragged elements.
223
Chapter 6. The RichFaces Components
For indicator customization you need to define one of the following facets:
Note:
The current implementation of the <rich:dragIndicator> component does not
support multiple items selection. The feature is described for future releases.
Thus for specify a look-and-feel you have to define one of these facets and include into it a content
that should be shown in indicator.
To place some data from drag or drop zones into component you can use macro definitions. They
are being defining in the following way:
• <rich:dndParam> component with a specific name and value is being included into a drag/
drop support component (an image can be defined as placed inside <rich:dndParam> without
defining a value).
• in needed place a parameter value is included into the marking of indicator using syntax (name
of parameter)
...
<rich:dropSupport...>
<rich:dndParam name="testDrop">
<h:graphicImage value="/images/file-manager.png" />
</rich:dndParam>
</rich:dropSupport>
...
...
<f:facet name="single">
{testDrop}
</f:facet>
...
224
Chapter 6. The RichFaces Components
• marker
• label
Thus including one of these elements in the marking of indicator, in other words after setting up
appropriate parameters in DnD components and defining only default indicator - without specifying
facets - a developer gets these parameters values displayed in indicator in the order "marker -
label".
The macro definition "marker" can be customized depending on what a draggable element is
located over. For that you should define one of these three parameters (specify a parameter with
one of three names):
• accept
Parameter will be set instead of {marker} into indicator when a draggable element is positioned
over drop zone that accept this type of elements
• reject
Parameter is set instead of {marker} into indicator when a draggable element is positioned over
drop zone that doesn't accept this type of elements
• default
Parameter is set instead of {marker} into indicator when a draggable element is positioned over
all the rest of page elements
Note:
If you use <rich:dragIndicator> inside a form do not forget to use id like
formId:indicatorID defined in <rich:dragSupport> indicator attribute.
225
Chapter 6. The RichFaces Components
Name Value
component-family org.richfaces.DragIndicator
renderer-type org.richfaces.DragIndicatorRenderer
tag-class org.richfaces.taglib.DragIndicatorTag
6.7.2.1. Description
This component defines a subtree of the component tree as draggable for drag-and-drop
operations. Within such a "drag zone," you can click the mouse button on an item and drag it
to any component that supports drop operations (a "drop zone"). It encodes all the necessary
JavaScript for supporting drag-and-drop operations.
226
Chapter 6. The RichFaces Components
• Can be used within any component type that provides the required properties for drag operations
The dragSupport tag inside a component completely specifies the events and JavaScript required
to use the component and it's children for dragging as part of a drag-and-drop operation. In order
to work, though, dragSupport must be placed inside a wrapper component that outputs child
components and that has the right events defined on it. Thus, this example won't work, because
the <h:column> tag doesn't provide the necessary properties for redefining events on the client:
Example:
...
<h:column>
<rich:dragSupport dragIndicator=":form:iii" dragType="text">
<a4j:actionparam value="#{caps.name}" name="name"/>
</rich:dragSupport>
<h:outputText value="#{caps.name}"/>
</h:column>
...
However, using a4j:outputPanel as a wrapper inside <h:column> , the following code could be
used successfully:
Example:
...
<h:column>
<a4j:outputPanel>
<rich:dragSupport dragIndicator=":form:iii" dragType="text">
<a4j:actionparam value="#{caps.name}" name="name"/>
</rich:dragSupport>
<h:outputText value="#{caps.name}"/>
</a4j:outputPanel>
</h:column>
...
One of the main attributes for dragSupport is "dragType" , which associates a name with the
drag zone. Only drop zones with this name as an acceptable type can be used in drag-and-drop
operations. Here is an example:
227
Chapter 6. The RichFaces Components
Example:
...
<h:panelGrid id="drag1">
<rich:dragSupport dragType="singleItems" .../>
<!--Some content to be dragged-->
</h:panelGrid>
...
<h:panelGrid id="drag2">
<rich:dragSupport dragType="groups" .../>
<!--Some content to be dragged-->
</h:panelGrid>
...
<h:panelGrid id="drop1">
<rich:dropSupport acceptedTypes="singleItems" .../>
<!--Drop zone content-->
</h:panelGrid>
...
In this example, the drop1 panel grid is a drop zone that invokes drag-and-drop for drops of
items from the first drag1 panel grid, but not the second drag2 panel grid. In the section about
dropSupport , you will find an example that shows more detailed information about moving data
between tables with drag and drop.
The dragSupport component also has a "value" attribute for passing data into the processing
after a drop event.
One more important attribute for <rich:dragSupport> is the "dragIndicator" attribute that point
to the component id of the <rich:dragIndicator> component to be used for dragged items from
this drag zone. If it isn't defined, a default indicator for drag operations is used.
Finally, the component has the following extra attributes for event processing on the client:
• "ondragstart"
• "ondragend"
You can use your own custom JavaScript functions to handle these events.
Note:
If you define width for a outputPanel, in Internet Explorer 6 you can perform a drag
and drop operation, placing the mouse cursor on the text in the outputPanel only.
228
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.DragSupport
component-class org.richfaces.component.html.HtmlDragSupport
component-family org.richfaces.DragSupport
renderer-type org.richfaces.DragSupportRenderer
tag-class org.richfaces.taglib.DragSupportTag
6.7.3.1. Description
The <rich:dragListener> represents an action listener method that is notified after a drag
operation.
• Allows to define some drag listeners for the components with "Drag and Drop" support
Attribute "type" defines the fully qualified Java class name for a listener. This class should
implement org.richfaces.event.DropListener [../../apidoc_framework/org/richfaces/event/
DropListener.html] interface.
...
<h:panelGrid id="dragPanel">
229
Chapter 6. The RichFaces Components
<rich:dragSupport dragType="item">
<rich:dragListener type="demo.ListenerBean"/>
</rich:dragSupport>
<!--Some content to be dragged-->
</h:panelGrid>
...
package demo;
import org.richfaces.event.DragEvent;
Name Value
listener-class org.richfaces.event.DragListener
event-class org.richfaces.event.DragEvent
tag-class org.richfaces.taglib.DragListenerTag
6.7.4.1. Description
The <rich:dropListener> represents an action listener method that is notified after a drop
operation.
• Allows to define some drop listeners for the components with "Drag and Drop" support
230
Chapter 6. The RichFaces Components
Attribute "type" defines the fully qualified Java class name for the listener. This class should
implement org.richfaces.event.DropListener [../../apidoc_framework/org/richfaces/event/
DropListener.html] interface. .
...
<rich:panel style="width:100px;height:100px;">
<f:facet name="header">Drop Zone</f:facet>
<rich:dropSupport acceptedTypes="text">
<rich:dropListener type="demo.ListenerBean"/>
</rich:dropSupport>
</rich:panel>
...
package demo;
import org.richfaces.event.DropEvent;
Name Value
listener-class org.richfaces.event.DropListener
event-class org.richfaces.event.DropEvent
231
Chapter 6. The RichFaces Components
Name Value
tag-class org.richfaces.taglib.DropListenerTag
6.7.5.1. Description
This component transforms a parent component into a target zone for drag-and-drop operations.
When a draggable element is moved and dropped onto the area of the parent component, Ajax
request processing for this event is started.
• Can be used within any component type that provides the required properties for drop operations
232
Chapter 6. The RichFaces Components
<rich:panel styleClass="dropTargetPanel">
<f:facet name="header">
<h:outputText value="PHP Frameworks" />
</f:facet>
<rich:dropSupport
id="php"
acceptedTypes="PHP"
dropValue="PHP"
dropListener="#{eventBean.processDrop}"
reRender="phptable,
src">
</rich:dropSupport>
...
</rich:panel>
Figure 6.52. Drop zone accepts dragable item with "PHP" type only
Using the "typeMapping" attribute. Previous example shows that a drop zone could accept a
dragable item or not. Special markers, which are placed at <rich:dragIndicator> , inform user
about drop zone’s possible behaviors: "checkmark" appears if drop is accepted and "No" symbol
if it is not. Moreover, some extra information (e.g. text message) could be put into the Indicator
to reinforce the signal about drop zone’s behavior or pass some other additional sense. This
reinforcement could be programmed and attributed to drop zone via "typeMapping" attribute
using JSON syntax. The type of dragged zone (dragType) should be passed as "key" and name
of <rich:dndParam> that gives needed message to Indicator as "value":
<rich:panel styleClass="dropTargetPanel">
<f:facet name="header">
<h:outputText value="PHP Frameworks" />
233
Chapter 6. The RichFaces Components
</f:facet>
<rich:dropSupport
id="php"
acceptedTypes="PHP"
dropValue="PHP"
dropListener="#{eventBean.processDrop}"
reRender="phptable,
src"
typeMapping="{PHP: text_for_accepting, DNET: text_for_rejecting}">
<rich:dndParam name="text_for_accepting" value="Drop accepted!" />
<rich:dndParam name="text_for_rejecting" value="Drop is not accepted!" />
</rich:dropSupport>
...
</rich:panel>
Here is an example of moving records between tables. The example describes all the pieces for
drag-and-drop. As draggable items, this table contains a list of such items designated as being
of type "text" :
234
Chapter 6. The RichFaces Components
<h:outputText value="#{caps.name}"/>
</a4j:outputPanel>
</h:column>
</rich:dataTable>
As a drop zone, this panel will accept draggable items of type text and then rerender an element
with the ID of box :
<rich:panel style="width:100px;height:100px;">
<f:facet name="header">Drop Zone</f:facet>
<rich:dropSupport acceptedTypes="text" reRender="box"
dropListener="#{capitalsBean.addCapital2}"/>
</rich:panel>
As a part of the page that can be updated in a partial page update, this table has an ID of box :
And finally, as a listener, this listener will implement the dropped element:
Here is the result after a few drops of items from the first table:
235
Chapter 6. The RichFaces Components
In this example, items are dragged element-by-element from the rendered list in the first table and
dropped on a panel in the middle. After each drop, a drop event is generated and a common Ajax
request is performed that renders results in the third table.
As with every Ajax action component, <rich:dropSupport> has all the common attributes (
"timeout" , "limitToList" , "reRender" , etc.) for Ajax request customization.
Finally, the component has the following extra attributes for event processing on the client:
• "ondragenter"
• "ondragexit"
• "ondrop"
• "ondropend"
Developers can use their own custom JavaScript functions to handle these events.
Information about the "process" attribute usage you can find in the "Decide what to process"
guide section .
Name Value
component-type org.richfaces.DropSupport
236
Chapter 6. The RichFaces Components
Name Value
component-class org.richfaces.component.html.HtmlDropSupport
component-family org.richfaces.DropSupport
renderer-type org.richfaces.DropSupportRenderer
tag-class org.richfaces.taglib.DropSupportTag
6.7.6.1. Description
The component is used for passing parameters during drag-and-drop operations.
Variants of usage:
• Passing parameters for indicator's drag icon. The <rich:dndParam> can define the indicator's
drag icon that will be used during dragging instead of indicator's default icon. For example,
a drag icon may be represented with a minimized image of a dragged element. In this case
type="drag":
...
<rich:dragSupport ... >
<rich:dndParam type="drag" name="dragging">
<h:graphicImage value="/img/product1_small.png"/>
</rich:dndParam>
<h:graphicImage value="product1.png"/>
</rich:dragSupport>
...
• Passing parameters for indicator's informational part. The <rich:dndParam> can transmit it's
value into indicator's. In this case type="drag":
237
Chapter 6. The RichFaces Components
...
<rich:dragSupport ... >
<rich:dndParam type="drag" name="label" value="#{msg.subj}"/>
...
</rich:dragSupport>
...
• Passing parameters to a component that supports drop after drop happens. The
<rich:dndParam> can pass icons into an indicator, if dragged content of a comp type is above
the given drop zone that processes it on the next drop event. In this case type="drop":
...
<rich:dropSupport ... >
<rich:dndParam type="drop" name="comp" >
<h:graphicImage height="16" width="16" value="/images/comp.png"/>
</rich:dndParam>
...
</rich:dropSupport >
...
Name Value
component-type org.richfaces.DndParam
component-class org.richfaces.component.html.HtmlDndParam
tag-class org.richfaces.taglib.DndParamTag
6.8.1.1. Description
The <rich:contextMenu> component is used for creation of multilevelled context menus that
are activated after defined events like "onmouseover" , "onclick" etc. The component could be
applied to any element on the page.
238
Chapter 6. The RichFaces Components
• Disablement support
By default, the <rich:contextMenu> disables right mouse click on a page in the context menu
area only. But if you want to disable browser's context menu completely you should set the
"disableDefaultMenu" attribute value to "true".
If "attached" value is "true" (default value), component is attached to the parent component or to
the component, which "id" is specified in the "attachTo" attribute:
239
Chapter 6. The RichFaces Components
<script type="text/javascript">
function enlarge(){
document.getElementById('pic').width=document.getElementById('pic').width*1.1;
document.getElementById('pic').height=document.getElementById('pic').height*1.1;
}
function decrease(){
document.getElementById('pic').width=document.getElementById('pic').width*0.9;
document.getElementById('pic').height=document.getElementById('pic').height*0.9;
}
</script>
In the example a picture zooming possibility with <rich:contextMenu> component usage was
shown. The picture is placed on the <h:panelGroup> component. The <rich:contextMenu>
component is not nested to <h:panelGroup> and has a value of the "attachTo" attribute defined
as "pic1". Thus, the context menu is attached to the component, which "id" is "pic1". The
context menu has two items to zoom in (zoom out) a picture by "onclick" event. For earch item
corresponding JavaScript function is defined to provide necessary action as a result of the clicking
on it. For the menu is defined an "oncontextmenu" event to call the context menu on a right
click mouse event.
In the example the context menu is defined for the parent <h:panelGroup> component with a
value of "id" attribute equal to "picture" You should be careful with such definition, because
a client context menu is looked for a DOM element with a client Id of a parent component
on a server. If a parent component doesn't encode an Id on a client, it can't be found by the
<rich:contextMenu> and it's attached to its closest parent in a DOM tree.
If the "attached" attribute has "false" value, component activates via JavaScript API with
assistance of <rich:componentControl> . An example is placed below.
Example:
<h:form id="form">
<rich:contextMenu attached="false" id="menu" submitMode="ajax">
<rich:menuItem ajaxSingle="true">
<b>{car} {model}</b> details
240
Chapter 6. The RichFaces Components
<h:panelGrid columns="2">
241
Chapter 6. The RichFaces Components
This is a result:
In the example the context menu is activated (by clicking on the left mouse button) on the table
via JavaScript API with assistance of <rich:componentControl> . The attribute "for" contains a
value of the <rich:contextMenu> Id. For menu appearance Java Script API function "show()"
is used. It is defined with "operation" attribute for the <rich:componentControl> component.
Context menu is recreated after the every call on a client and new {car} and {model} values are
inserted in it. In the example for a menu customization macrosubstitutions were used.
The <rich:contextMenu> component can be defined once on a page and can be used as
shared for different components (this is the main difference from the <rich:dropDownMenu>
component). It's necessary to define it once on a page (as it was shown in the example
above [240]) and activate it on required components via JavaScript API with assistance of
<rich:componentControl> .
242
Chapter 6. The RichFaces Components
The "action" and "actionListener" item's attributes are ignored. Menu items don't fire any submits
themselves. The behavior is fully defined by the components nested inside items.
Notes:
Name Value
component-type org.richfaces.ContextMenu
component-class org.richfaces.component.html.ContextMenu
component-family org.richfaces.ContextMenu
renderer-type org.richfaces.DropDownMenuRenderer
tag-class org.richfaces.taglib.ContextMenuTagHandler
243
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.8.2.1. Description
All attributes except "value" are optional. The "value" attribute defines text to be represented.
If you can use the "label" facet, you can even not use the "value" attribute.
244
Chapter 6. The RichFaces Components
Here is an example:
Example:
...
<f:facet name="label">
<h:graphicImage value="/images/img1.png"/>
</f:facet>
...
Use the "event" attribute to define an event for the represented element that triggers a menu
appearance. An example of a menu appearance on a click can be seen below.
Example:
...
<rich:dropDownMenu event="onclick" value="Item1">
<!--Nested menu components-->
</rich:dropDownMenu>
...
• Server (default)
• Ajax
• None
The "action" and "actionListener" item's attributes are ignored. Menu items don't fire any submits
themselves. The behavior is fully defined by the components nested into items.
Note:
245
Chapter 6. The RichFaces Components
The "direction" and "jointPoint" attributes are used for defining aspects of menu appearance.
Here is an example:
Example:
...
<rich:dropDownMenu value="File" direction="bottom-right" jointPoint="bl">
<rich:menuItem submitMode="ajax" value="New" action="#{ddmenu.doNew}"/>
<rich:menuItem submitMode="ajax" value="Open" action="#{ddmenu.doOpen}"/>
<rich:menuGroup value="Save As...">
<rich:menuItem submitMode="ajax" value="Text File" action="#{ddmenu.doSaveText}"/>
<rich:menuItem submitMode="ajax" value="PDF File" action="#{ddmenu.doSavePDF}"/>
</rich:menuGroup>
<rich:menuItem submitMode="ajax" value="Close" action="#{ddmenu.doClose}"/>
<rich:menuSeparator id="menuSeparator11"/>
<rich:menuItem submitMode="ajax" value="Exit" action="#{ddmenu.doExit}"/>
</rich:dropDownMenu>
...
246
Chapter 6. The RichFaces Components
You can correct an offset of the pop-up list relative to the label using the following attributes:
"horizontalOffset" and "verticalOffset" .
Here is an example:
Example:
...
<rich:dropDownMenu value="File" direction="bottom-
right" jointPoint="tr" horizontalOffset="-15" verticalOffset="0">
<rich:menuItem submitMode="ajax" value="New" action="#{ddmenu.doNew}"/>
<rich:menuItem submitMode="ajax" value="Open" action="#{ddmenu.doOpen}"/>
<rich:menuGroup value="Save As...">
<rich:menuItem submitMode="ajax" value="Text File" action="#{ddmenu.doSaveText}"/>
<rich:menuItem submitMode="ajax" value="PDF File" action="#{ddmenu.doSavePDF}"/>
</rich:menuGroup>
<rich:menuItem submitMode="ajax" value="Close" action="#{ddmenu.doClose}"/>
<rich:menuSeparator id="menuSeparator11"/>
<rich:menuItem submitMode="ajax" value="Exit" action="#{ddmenu.doExit}"/>
</rich:dropDownMenu>
...
247
Chapter 6. The RichFaces Components
The "disabled" attribute is used for disabling whole <rich:dropDownMenu> component. In this
case it is necessary to define "disabled" attribute as "true". An example is placed below.
Example:
...
<rich:dropDownMenu value="File" disabled="true">
...
</rich:dropDownMenu>
...
248
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.8.3.1. Description
The <rich:menuGroup> component is used to define an expandable group of items inside a
pop-up list or another group.
249
Chapter 6. The RichFaces Components
The "icon" attribute defines an icon for the component. The "iconDisabled" attribute defines an
icon for when the group is disabled. Also you can use the "icon" and "iconDisabled" facets. If
the facets are defined, the corresponding "icon" and "iconDisabled" attributes are ignored and
the facets' contents are used as icons. This could be used for an item check box implementation.
Here is an example:
...
<f:facet name="icon">
<h:selectBooleanCheckbox value="#{bean.property}"/>
</f:facet>
...
The "iconFolder" and "iconFolderDisabled" attributes are defined for using icons as folder
icons. The "iconFolder" and "iconFolderDisabled" facets use their contents as folder icon
representations in place of the attribute values.
The "direction" attribute is used to define which way to display the menu as shown in the example
below:
• "left - down" - a submenu is attached to the left side of the menu and is dropping down
• "left - up" - a submenu is attached to the left side of the menu and is dropping up
• "right - down" - a submenu is attached to the right side of the menu and is dropping down
• "right - up" - a submenu is attached to the right side of the menu and is dropping up
Here is an example:
...
<rich:menuGroup value="Save As..." direction="left-down">
<rich:menuItem submitMode="ajax" value="Text File" action="#{ddmenu.doSaveText}"/>
<rich:menuItem submitMode="ajax" value="PDF File" action="#{ddmenu.doSavePDF}"/>
</rich:menuGroup>
...
250
Chapter 6. The RichFaces Components
Note:
Name Value
component-type org.richfaces.MenuGroup
component-class org.richfaces.component.html.HtmlMenuGroup
component-family org.richfaces.DropDownMenu
renderer-type org.richfaces.MenuGroupRenderer
tag-class org.richfaces.taglib.MenuGroupTag
Facet Description
icon Redefines the icon for the enabled item state.
Related attribute is "icon"
iconFolder Redefines the folder icon for the enabled item
state. Related attribute is "iconFolder"
251
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.8.4.1. Description
The <rich:menuItem> component is used for the definition of a single item inside a pop-up list.
This component can be used not only within <rich:dropDownMenu> and <rich:contextMenu> ,
but also it can used as a standalone component. For example, you can use it as nested component
of the <rich:toolBar> .
252
Chapter 6. The RichFaces Components
The "value" attribute defines the text representation for an item element.
There are two icon-related attributes. The "icon" attribute defines an icon. The "iconDisabled"
attribute defines an icon for a disabled item. Also you can use the "icon" and "iconDisabled"
facets. If the facets are defined, the corresponding "icon" and "iconDisabled" attributes are
ignored and the facets content is shown as an icon. It could be used for an item check box
implementation.
Here is an example:
...
<f:facet name="icon">
<h:selectBooleanCheckbox value="#{bean.property}"/>
</f:facet>
...
• Server (default)
• Ajax
• None
The "action" and "actionListener" item's attributes are ignored. Menu items don' fire any submits
themselves. The behavior is fully defined by the components nested into items.
253
Chapter 6. The RichFaces Components
For example, you can put any content into an item, but, in this case, you should set the
"submitMode" attribute as "none" .
Here is an example:
...
<rich:dropDownMenu>
...
<rich:menuItem submitMode="none">
<h:outputLink value="www.jboss.org"/>
</rich:menuItem>
...
<rich:dropDownMenu>
...
You can use the "disabled" attribute to set the item state.
Here is an example:
...
<rich:dropDownMenu>
<rich:menuItem value="Disable" disabled="true"/>
<rich:dropDownMenu>
...
Note:
The <rich:menuItem> component was designed to be used only for pop-up menu
list creation.
Information about the "process" attribute usage you can find RichFaces Developer Guide section
about "process" attribute .
Name Value
component-type org.richfaces.MenuItem
component-class org.richfaces.component.html.HtmlMenuItem
254
Chapter 6. The RichFaces Components
Name Value
component-family org.richfaces.DropDownMenu
renderer-type org.richfaces.MenuItemRenderer
tag-class org.richfaces.taglib.MenuItemTag
Facet Description
icon Redefines the icon for the enabled item state.
Related attribute is "icon"
iconDisabled Redefines the folder icon the disabled item
state. Related attribute is "iconDisabled"
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
255
Chapter 6. The RichFaces Components
6.8.5.1. Description
The <rich:menuSeparator> component is used for the definition of a horizontal separator that
can be placed between groups or items.
Name Value
component-type org.richfaces.MenuSeparator
component-class org.richfaces.component.html.HtmlMenuSeparator
component-family org.richfaces.DropDownMenu
renderer-type org.richfaces.MenuSeparatorRenderer
tag-class org.richfaces.taglib.MenuSeparatorTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
256
Chapter 6. The RichFaces Components
6.9.1.1. Description
The component is designed for hierarchical data presentation and is applied for building a tree
structure with a drag-and-drop capability.
• Built-in drag and drop capability, than enable relocating tree nodes within the tree
257
Chapter 6. The RichFaces Components
Actually you can develop and use your own implementation of the "TreeNode"
interface or use a default one, which is defined with a default class
"TreeNodeImpl" ( org.richfaces.model.TreeNodeImpl [../../apidoc_framework/org/richfaces/
model/TreeNodeImpl.html]).
The "value" attribute of the <rich:tree> component contains a nodes structure defined in a
bean property.
When the <rich:tree> component is being rendered it iterates over the model nodes and renders
them using one of its immediate <rich:treeNode> children. Data property of the current model
TreeNode is exposed using "var" attribute, so if var="station" you can refer to that data using
#{station} syntax.
...
private TreeNodeImpl<String> stationRoot = new TreeNodeImpl<String>();
private TreeNodeImpl<String> stationNodes = new TreeNodeImpl<String>();
private String[] kickRadioFeed = { "Hall & Oates - Kiss On My List",
"David Bowie - Let's Dance", "Lyn Collins - Think (About It)",
"Kim Carnes - Bette Davis Eyes",
"KC & the Sunshine Band - Give It Up" };
...
stationRoot.setData("KickRadio");
stationNodes.addChild(0, stationRoot);
for (int i = 0; i < kickRadioFeed.length; i++){
TreeNodeImpl<String> child = new TreeNodeImpl<String>();
child.setData(kickRadioFeed[i]);
stationRoot.addChild(i, child);
}
...
258
Chapter 6. The RichFaces Components
...
<rich:tree value="#{stations.stationNodes}" var="station">
<rich:treeNode>
<h:outputText value="#{station}" />
</rich:treeNode>
</rich:tree>
...
This is a result:
Let's try to build a simple <rich:tree> from a local XML file. In the following example a simple
XML file (stations.xml) is used as a radio station playlist:
<?xml version="1.0"?>
<station name="KickRadio">
<feed date="today">
<song time="07:00">Hall & Oates - Kiss On My List</song>
<song time="07:03">David Bowie - Let's Dance</song>
<song time="07:06">Lyn Collins - Think (About It)</song>
<song time="07:10">Kim Carnes - Bette Davis Eyes</song>
<song time="07:15">KC & the Sunshine Band - Give It Up</song>
</feed>
</station>
259
Chapter 6. The RichFaces Components
...
private TreeNode data;
...
FacesContext context = FacesContext.getCurrentInstance();
data = XmlTreeDataBuilder.build(new InputSource(getClass().getResourceAsStream("stations.xml")));
...
Finally you should set the "value" attribute to the data bean property and define the "var" attribute
in order to refer to the data of nodes:
...
<rich:tree id="treeXML" value="#{stations.data}" var="vardata">
<rich:treeNode>
<h:outputText value="#{vardata.attributes['name']}" />
<h:outputText value="#{vardata.attributes['date']}" />
<h:outputText value="#{vardata.attributes['time']}" />
<h:outputText value=" #{vardata.text}" />
</rich:treeNode>
</rich:tree>
...
This is a result:
It's possible to define a visual representation of a node data model (to define a node icon) and
its behavior in correspondence with the data contained in this node (with a value of the "var"
attribute). The node behavior is defined by the components nested into the <rich:treeNode>
(e.g. links or buttons). For these purposes you should use "nodeFace" attribute. For each tree
node a value of "nodeFace" attribute is evaluated and <rich:treeNode> with a value of "type"
attribute equal to a value of "nodeFace" is used for node representation. See an example below.
Example:
260
Chapter 6. The RichFaces Components
...
<h:form>
<rich:tree style="width:300px" value="#{library.data}" var="item" nodeFace="#{item.type}">
<rich:treeNode type="artist" iconLeaf="/images/tree/singer.png" icon="/images/tree/
singer.png">
<h:outputText value="#{item.name}" />
</rich:treeNode>
<rich:treeNode type="album" iconLeaf="/images/tree/disc.png" icon="/images/tree/
disc.png">
<h:outputText value="#{item.title}" />
</rich:treeNode>
<rich:treeNode type="song" iconLeaf="/images/tree/song.png" icon="/images/tree/
song.png">
<h:outputText value="#{item.title}" />
</rich:treeNode>
</rich:tree>
</h:form>
...
This is a result:
In the example above, when each node of data model is processed, data contained in the "data"
property of "TreeNode" interface is assigned to a request scope variable, which name is defined
with "var" attribute. The value of the "nodeFace" attribute is evaluated in correspondence with
the data assigned to the "var" attribute. The corresponding <rich:treeNode> component (with
a value of "type" attribute equal to a value of "nodeFace" ) is used for the node representation.
For example, during data model processing, an object with a name "Chris Rea" was inserted in
the "var" attribute. Then the value of "nodeFace" attribute was evaluated as "artist". Thus,
for the node representation the <rich:treeNode> with "type" equal to "artist" was used.
You can also assign an EL-expression as value of the "nodeFace" attribute. See an example
below:
261
Chapter 6. The RichFaces Components
Example:
There are some essential points in a "nodeFace" attribute usage: you need to define notions for
typeless and a default nodes.
The typeless node is the first <rich:treeNode> component (from all children nodes nested to the
<rich:tree> component) with not defined "type" attribute and defined "rendered" attribute. The
typeless node is used for representation when "nodeFace" attribute is null.
Example:
...
<h:outputText value="#{varAttributeName}">
...
• "nodeFace" attribute is defined, but its value isn't equal to any "type" attribute value from all
children nodes;
• "nodeFace" attribute is defined and its value is equal to a value of some "type" attribute from
all children nodes, but the value of "rendered" attribute for this node is "false".
There is also one thing that has to be remembered using "type" and "rendered" attributes: it's
possible to define several <rich:treeNode> components with equal values of "type" attribute and
different values of "rendered" attribute. It provides a possibility to define different representation
styles for the same node types. In the example with artists and their albums (see above [260])
it's possible to represent albums that are available for sale and albums that are not available.
Please study the example below:
Example:
...
<h:form>
<rich:tree style="width:300px" value="#{library.data}" var="item" nodeFace="#{item.type}">
262
Chapter 6. The RichFaces Components
...
<rich:treeNode type="album" iconLeaf="/images/tree/album.gif" icon="/images/tree/
album.gif"
rendered="#{item.exist}">
<h:outputText value="#{item.name}" />
</rich:treeNode>
<rich:treeNode type="album" iconLeaf="/images/tree/album_absent.gif" icon="/images/
tree/album_absent.gif"
rendered="#{not item.exist}">
<h:outputText value="#{item.name}" />
</rich:treeNode>
...
</rich:tree>
</h:form>
...
In the example the <rich:treeNode> components has equal values of the "type" attribute.
Depending on value of the "rendered" attribute the corresponding <rich:treeNode> component
is selected for node representation. If an album is available for sale the value of the "rendered"
for the first <rich:treeNode> component is "true", for the second one is "false". Thus, the first
<rich:treeNode> is selected for node representation.
Tree node can be run in tree modes. Modes can be specified with "switchType" attribute for
<rich:tree> component.
• Ajax (default value) - Ajax submission is used performing the functionality. Note, that for
collapse/expand operations an Ajax request is sent to the server and it can cause a short delay.
263
Chapter 6. The RichFaces Components
• Client – all operations are performed totally on the client; no interaction with a server is
involved. Full page content is reloaded after every action.
The "icon" , "iconCollapsed" , "iconExpanded" , "iconLeaf" attributes set the icons' images for
the component. You can also define icons using facets with the same names. If the facets are
defined, the corresponding attributes are ignored and facets' content is used as icons. By default
the width of a rendered facet area is 16px.
Example:
...
<rich:tree value="#{library.data}" var="item">
...
<f:facet name="icon">
<h:graphicImage value="/images/tree/singer.png "/>
</f:facet>
<f:facet name="iconCollapsed">
<h:graphicImage value="/images/tree/singer.png" />
</f:facet>
<f:facet name="iconExpanded">
<h:graphicImage value="/images/tree/singer.png" />
</f:facet>
<f:facet name="iconLeaf">
<h:graphicImage value="/images/tree/song.png" />
</f:facet>
...
</rich:tree>
...
The <rich: tree> component can be used together with <rich: treeNodeAdaptor> . In this
case there is no need to specify the attributes "value" and "var" . Besides, visual representation
shouldn't be defined right in the tree. In this case a <rich: tree> tag is applied mainly for defining
common attributes such as "ajaxSubmitSelection" etc.
Information about the "process" attribute usage you can find in the "Decide what to process"
guide section.
As it's mentioned before, the <rich:tree> component uses a data model to represent the tree-
like nodes structure on the page. To identify a particular node during a client request, the model
provides a set of unique keys for tree nodes. The <rich:tree> can use strings as keys values
which may contain special characters not allowed by browsers, such as the left angle bracket (<),
ampersand (&), ant etc. Thus, to have a possibility to use unallowed characters in the tree nodes
keys, the following converters are provided:
264
Chapter 6. The RichFaces Components
The converters can be extended in order to have a possibility for implementing custom converters.
To apply a converter to the <rich:tree> component, you should define it as a value of the
"rowKeyConverter" attribute.
Have a look at the example of a tree which contains the RichFaces components as its nodes
and the components attributes as the nodes child elements. As the components have unallowed
characters (< and >) in their names, the org.richfaces.TreeRowKeyConverter is used here.
Example:
...
<rich:tree value="#{treeBean.data}" var="node" switchType="ajax" rowKeyConverter="org.richfaces.TreeRowK
<rich:treeNode ajaxSingle="true">
<h:outputText value="#{node}"/>
</rich:treeNode>
</rich:tree>
...
...
String[ ] components = {"< a4j:ajaxListener >", "< a4j:keepAlive >", "< a4j:actionparam >" };
String[ ][ ] attributes = {{"type"},
{"ajaxOnly", "beanName"},
{"actionListener", "assignTo", "binding", "converter", "id", "name", "noEscape", "value"}};
265
Chapter 6. The RichFaces Components
Words "built-in" in this context mean, that <rich:tree> component has its own attributes, that
provide drag-and-drop capability. These attributes can be divided into two groups: those ones
which provide drag and those which provide drop operations (see the tables below).
Consider drag-and-drop inside a tree. All zones, which are assumed to be dragged, must be
marked. In terms of <rich:tree> these zones completely correspond to tree nodes. So, all
dragging nodes should be marked with "dragType" attribute. Then, to mark zone(-s), where the
dragging node could be dropped, pass the type of dragging node to the "acceptedTypes" attribute
of the drop zone. It would be good to itemize, that each tree node in the <rich:tree> component’s
structure has its own key. Depending on how the component is used, these keys can be generated
266
Chapter 6. The RichFaces Components
by the component itself or can be taken from the component’s data model. Keys help to identify
each node in a tree; key is what exactly being passing from one node to another in drag-and-
drop operations. Finally, the method binding, that will process drag-and-drop operation, should be
pointed via "dropListener" attribute of the <rich:tree> .
Chapters "6.40 <dragIndicator>" and "6.39 <dndParam>" describes how to apply visual element,
that show some additional information (e.g. dragging item name) while operating with drag-and-
drop.
Page code, that describes a tree with built in drag-and-drop in the way it is considered, is shown
below.
Example:
...
<h:form>
267
Chapter 6. The RichFaces Components
Listeners classes that process events on the server side are defined with the help of:
• nodeSelectListener is called during request sending on a node selecting event (if request
sending on this event is defined)
Listener methods can be defined using the following attributes or using nested tags.
• "ondragexit" is a script expression to invoke when an element passing out from a tree zone
Standart HTML event attributes like "onclick" , "onmousedown" , "onmouseover" etc. can be also
used. Event handlers of a <rich:tree> component capture events occured on any tree part. But
event handlers of treeNode capture events occured on treeNode only, except for children events.
268
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.Tree
component-class org.richfaces.component.html.HtmlTree
component-family org.richfaces.Tree
renderer-type org.richfaces.TreeRenderer
tag-class org.richfaces.taglib.TreeTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
How to Expand/Collapse Tree Nodes from code, see in thiswiki article [http://labs.jboss.com/wiki/
ExpandCollapseTreeNodes].
269
Chapter 6. The RichFaces Components
6.9.2.1. Description
The <rich:treeNode> component is designed for creating sets of tree elements within a
<rich:tree> component.
• Possibility to assign different icon images for each node within a tree
• Look-and-Feel customization
...
<rich:tree ...>
...
<rich:treeNode>
<f:facet name="icon">
270
Chapter 6. The RichFaces Components
<outputText value="A"/>
</f:facet>
<f:facet name="iconCollapsed">
<outputText value="B"/>
</f:facet>
<f:facet name="iconExpanded">
<outputText value="C"/>
</f:facet>
<f:facet name="iconLeaf">
<outputText value="D"/>
</f:facet>
</rich:treeNode>
...
</rich:tree>
...
As it has been mentioned above, <rich:treeNode> defines a template for nodes rendering in a
tree. Thus, during XML document rendering (a web.xml application) as a tree, the following nodes
output (passed via var="data" on a tree) happens:
Example:
...
<rich:tree faceNode="simpleNode" value="#{bean.data}" var="data">
<rich:treeNode type="simpleNode">
<h:outputText value="context-param:"/>
<h:inputText value="#{data.name}"/>
</rich:treeNode>
</rich:tree>
...
Hence, <h:outputText /> tag outputs the "context-param" string and then the <h:inputText /
> outputs the data.name element of this node.
Different nodes for rendering could be defined depending on some conditions on the tree
level. Each condition represents some rendering template. To get more information on various
treeNodesAdaptorAdaptor definition for nodes, see the tree component chapter.
271
Chapter 6. The RichFaces Components
Switching between expanded/collapsed modes is also managed on the tree level and defined in
the corresponding section.
Default nodes of the tree level as well as the ones defined with the treeNodesAdaptorAdaptor
component could send Ajax requests when selected with the mouse, it's managed with the
"ajaxSubmitSelection" attribute (true/false).
Information about the "process" attribute usage you can find " Decide what to process " guide
section.
The main information on Drag and Drop operations is given in the corresponding paragraph of
the tree component chapter. It's only necessary to mention that each node could also be a Drag
element as well as a Drop container, i.e. the container and the element have all attributes, listeners
and ways of behavior similar to the ones of the <rich:dragSupport > and <rich:dropSupport
> components simultaneously.
Just as Drag and Drop operations it corresponds to the one described on the tree component
level for a default Node.
Name Value
component-type org.richfaces.TreeNode
component-class org.richfaces.component.html.HtmlTreeNode
component-family org.richfaces.TreeNode
renderer-type org.richfaces.TreeNodeRenderer
tag-class org.richfaces.taglib.TreeNodeTag
272
Chapter 6. The RichFaces Components
Table 6.99. Classes names that define states for a node element
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
How to Expand/Collapse Tree Nodes from code see in thiswiki article [http://labs.jboss.com/wiki/
ExpandCollapsetreeNodesAdaptor].
6.9.3.1. Description
The <rich:treeNodesAdaptor> provides the possibility to define data models and create
representations for them.
273
Chapter 6. The RichFaces Components
Collections are allowed to include lists, arrays, maps, XML NodeList and NamedNodeMap either
as a single object.
The <rich:treeNodesAdaptor> component can be nested without any limitations. See the
following example.
Example:
...
<rich:tree adviseNodeOpened="#{treeModelBean.adviseNodeOpened}" switchType="client">
<rich:treeNodesAdaptor id="project" nodes="#{loaderBean.projects}" var="project">
<rich:treeNode>
<h:commandLink action="#{project.click}" value="Project: #{project.name}" />
</rich:treeNode>
<rich:treeNodesAdaptor id="srcDir" var="srcDir" nodes="#{project.srcDirs}">
<rich:treeNode>
<h:commandLink action="#{srcDir.click}" value="Source directory: #{srcDir.name}" />
</rich:treeNode>
274
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.TreeNodesAdaptor
component-class org.richfaces.component.html.HtmlTreeNodesAdaptor
component-family org.richfaces.TreeNodesAdaptor
tag-class org.richfaces.taglib.TreeNodesAdaptorTag
6.9.4.1. Description
275
Chapter 6. The RichFaces Components
Example:
...
<rich:tree adviseNodeOpened="#{treeModelBean.adviseNodeOpened}" switchType="client">
<rich:treeNodesAdaptor id="project" nodes="#{loaderBean.projects}" var="project">
<rich:treeNode>
<h:commandLink action="#{project.click}" value="Project: #{project.name}" />
</rich:treeNode>
276
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.RecursiveTreeNodesAdaptor
component-class org.richfaces.component.html.HtmlRecursiveTreeNodesAdaptor
component-family org.richfaces.RecursiveTreeNodesAdaptor
tag-class org.richfaces.taglib.RecursiveTreeNodesAdaptorTag
277
Chapter 6. The RichFaces Components
6.9.5.1. Description
...
<rich:tree switchType="server" value="#{project.data}" var="item" nodeFace="#{item.type}">
<rich:changeExpandListener type="demo.ListenerBean"/>
...
<!-- Tree nodes -->
...
</rich:tree>
...
package demo;
import org.richfaces.event.NodeExpandedEvent;
public class ListenerBean implements org.richfaces.event.NodeExpandedListener{
...
public void processExpansion(NodeExpandedEvent arg0){
//Custom Developer Code
}
...
278
Chapter 6. The RichFaces Components
}
...
Name Value
listener-class org.richfaces.event.NodeExpandedListener
event-class org.richfaces.event.NodeExpandedEvent
tag-class org.richfaces.taglib.ChangeExpandListenerTag
6.9.6.1. Description
Attribute "type" defines the fully qualified Java class name for listener. This class
should implement org.richfaces.event.NodeSelectedListener [../../apidoc_framework/org/
richfaces/event/NodeSelectedListener.html]. interface
...
<rich:tree switchType="server" value="#{project.data}" var="item" nodeFace="#{item.type}">
<rich:nodeSelectListener type="demo.ListenerBean"/>
...
<!-- Tree nodes -->
...
279
Chapter 6. The RichFaces Components
</rich:tree>
...
package demo;
import org.richfaces.event.NodeSelectedEvent;
public class ListenerBean implements org.richfaces.event.NodeSelectedListener{
...
public void processSelection(NodeSelectedEvent arg0){
//Custom Developer Code
}
...
}
Name Value
listener-class org.richfaces.event.NodeSelectedListener
event-class org.richfaces.event.NodeSelectedEvent
tag-class org.richfaces.taglib.NodeSelectListenerTag
6.10.1.1. Description
The component implements a modal window that blocks user interaction with the main application
while active.
280
Chapter 6. The RichFaces Components
Important:
In order to avoid a bug in IE, the root node of the dialog is moved on the top of
a DOM tree.
281
Chapter 6. The RichFaces Components
Position the <rich:modalPanel> on the screen by specifying coordinates of it's top-left corner. Set
values for "top" and "left" attributes in pixels for Y and X coordinates correspondingly. By default
the component is autopositionable.
The modal window can be moved and resized by the end user. To disable those features (which
are enabled by default) set "moveable" and "resizeable" attributes to false. Resizing may be
limited by specifying window's minimal sizes with the "minWidth" and "minHeight" attributes.
To open and close the <rich:modalPanel> use one of three JS API functions (offset to the
"Reference Data" below in this chapter):
The result:
282
Chapter 6. The RichFaces Components
Besides client ID it is possible to pass other parameters while opening and closing the
<rich:modalPanel> with the JS API function. For example, you can pass top and left indents or
panel size:
Also the <rich:modalPanel> allows to handle its own opening and closing events on the client
side. Custom parameters passed with JS API are also obtained in this case:
<rich:modalPanel onshow="alert(event.parameters.param1)">
...
</rich:modalPanel>
283
Chapter 6. The RichFaces Components
The component can restore its previous state (including position on the screen) after submitting
and reloading. Set "keepVisualState" to true to submit and pass <rich:modalPanel> current
parameters to a new page. The "showWhenRendered" boolean attribute is used in cases when
component should be rendered after first page loading.
The "trimOverlayedElements" boolean attribute can be used to determine if the modal panel will
expand to show other components inside it. Set the attribute to false to ensure components are
not cut off.
Notes:
To avoid overlapping by an embed object (inserted with HTML <embed> tag) set
the "overlapEmbedObjects" to true.
The "label" attribute is a generic one. It provides an association between a component and
message the component produces. This attribute defines parameters of localized error and
informational messages that occur as a result of conversion, validation or other application actions
during the request processing lifecycle. With this attribute you can replace the last parameter
substitution token shown in the message. For example, DoubleRangeValidator.MAXIMUM or
ShortConverter.SHORT.
The <rich:modalPanel> supports two facets. The header facet defines header and text label on it:
...
<rich:modalPanel id="pnl">
<f:facet name="header">
<h:outputText value="I'm panel header" />
</f:facet>
284
Chapter 6. The RichFaces Components
<p>The <rich:modalPanel> accepts different types of information: from simple text to iterative components such as
</p>
<a onclick="Richfaces.hideModalPanel('pnl');" href="#">Hide ModalPanel</a>
</rich:modalPanel>
...
The result:
The controls facet places any control on a header, defines image, style and function for it. For
example, "Close" control:
<rich:modalPanel id="pnl">
...
<f:facet name="controls">
<h:graphicImage value="/pages/
close.png" style="cursor:pointer" onclick="Richfaces.hideModalPanel('pnl')" />
</f:facet>
...
285
Chapter 6. The RichFaces Components
</rich:modalPanel>
The result:
<a4j:form>
<rich:modalPanel>
<h:form>
<h:commandButton value="Test" action="#{TESTCONTROLLER.test}" />
</h:form>
</rich:modalPanel>
</a4j:form>
286
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.ModalPanel
component-class org.richfaces.component.html.HtmlModalPanel
component-family org.richfaces.ModalPanel
renderer-type org.richfaces.ModalPanelRenderer
tag-class org.richfaces.taglib.ModalPanelTag
Function Description
Richfaces.showModalPanel('ID'); Opens the modal panel with specified ID
Richfaces.hideModalPanel('ID'); Closes the modal panel with specified ID
Richfaces.hideTopModalPanel('ID'); Closes the current top visible modal panel with
specified ID
Facet Description
header Defines header content
controls Defines a control on the header
287
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
Useful articles:
288
Chapter 6. The RichFaces Components
6.10.2.1. Description
Create image by painting from a managed bean method, same as "paint" (Graphics2D) in
"SWING" components.
• Fully supports "JPEG" (24-bit, default), "GIF" (8-bit with transparency), and "PNG" (32-bit
with transparency) formats for sending generated images
289
Chapter 6. The RichFaces Components
• "paint"
Specify a method receiving an object specified in data as a parameter and sending graphical
information into the stream
• "data"
Note:
The "format" attribute of the component defines a format of visual data passing to the server.
Generated data can be used as a cacheable or non-cacheable resource. It's defined with
"cacheable" attribute. If cache support is turned on, a key is created in URI with a mix of size
(width/height), "paint" method, "format" and "data" attributes.
Example:
paintBean.java:
dataBean.java:
page.xhtml:
...
290
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.Paint2D
component-class org.richfaces.component.html.HtmlPaint2D
component-family javax.faces.Output
renderer-type org.richfaces.Paint2DRenderer
tag-class org.richfaces.taglib.Paint2DTag
6.10.3.1. Description
291
Chapter 6. The RichFaces Components
<rich:panel />
The result:
The <rich:panel> supports header facet that defines header and text label on it. Besides that
there is "header" attribute that does the same job. The following two entries
<-- A -->
<rich:panel header="I'm panel header" />
<-- B -->
<rich:panel>
<f:facet name="header">
<h:outputText value="I'm panel header"/>
</f:facet>
</rich:panel>
292
Chapter 6. The RichFaces Components
Name Value
component-family org.richfaces.panel
renderer-type org.richfaces.PanelRenderer
tag-class org.richfaces.taglib.PanelTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
293
Chapter 6. The RichFaces Components
If you have any questions or ideas regarding the <rich:panel> tell about them at the RichFaces
Users Forum [http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4064191].
available since 3.0.0
6.10.4. < rich:panelBar >
6.10.4.1. Description
The component is designed to group one or more <rich:panelBarItem> components into one
interactive panel.
In contrast to <rich:panel> the component has "width" and "height" attributes that control it size
(by default they both have 100%).
294
Chapter 6. The RichFaces Components
Name Value
component-family org.richfaces.PanelBar
renderer-type org.richfaces.PanelBarRenderer
tag-class org.richfaces.taglib.PanelBarTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
295
Chapter 6. The RichFaces Components
If you have any questions or ideas regarding the <rich:panel> tell about them at the RichFaces
Users Forum [http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4064191].
available since 3.0.0
6.10.5. <rich:panelBarItem>
6.10.5.1. Description
The component is designed to be used as a part of <rich:panelBar>. The <rich:panelBarItem>
used separately from <rich:panelBar> will not be rendered.
The <rich:panelBarItem> supports label facet that defines text label on it's header. Besides
that there is "label" attribute that does the same job. By default the component is rendered with
a header and text label "auto generated label". The following two entries
<-- A -->
<rich:panelBar>
296
Chapter 6. The RichFaces Components
<-- B -->
<rich:panelBar>
<rich:panelBarItem>
<f:facet name="label">
<h:outputText value="Olympus EVOLT E-500"/>
</f:facet>
</rich:panelBarItem>
</rich:panelBar>
Name Value
component-type org.richfaces.PanelBarItem
component-class org.richfaces.component.html.HtmlPanelBarItem
component-family org.richfaces.PanelBarItem
renderer-type org.richfaces.PanelBarItemRenderer
tag-class org.richfaces.taglib.PanelBarItemTag
297
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
If you have any questions or ideas regarding the <rich:panel> tell about them at the RichFaces
Users Forum [http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4064191].
6.10.6.1. Description
The <rich:panelMenu> component defines vertical menu on a page. Used together with
<rich:panelMenuItem> and <rich:panelMenuGroup>, which form <rich:panelMenu> content.
298
Chapter 6. The RichFaces Components
• Can be disabled
<rich:panelMenu event="onmouseover">
...
</rich:panelMenu>
Switching mode could be chosen with the "mode" attribute for all panelMenu items except
ones where this attribute was redefined. By default all items send traditional request. The
"expandMode" attribute defines the submission modes for all collapsing/expanding panelMenu
groups except ones where this attribute was redefined. The "mode" and "expandMode" attributes
could be used with three possible parameters. The "mode" attribute defines parameters for all
included <rich:panelMenuItem> elements.
• Server (default) the common submission of the form is performed and page is completely
refreshed:
...
<rich:panelMenu mode="server">
<rich:panelMenuGroup label="test Group" action="#{bean.action}">
<rich:panelMenuItem label="test" action="#{capitalsBean.action}">
<f:param value="test value" name="test"/>
</rich:panelMenuItem>
</rich:panelMenuGroup>
</rich:panelMenu>
...
• Ajax an Ajax form submission is performed, and additionally specified elements in the
"reRender" attribute are reRendered:
...
<rich:panelMenu mode="ajax">
<rich:panelMenuGroup label="test Group" action="#{bean.action}">
299
Chapter 6. The RichFaces Components
• None "Action" and "ActionListener" item's attributes are ignored. Items don't fire any submits
itself. Behavior is fully defined by the components nested into items:
...
<rich:panelMenu event="onclick" submitMode="none">
<rich:panelMenuItem label="Link to external page">
<h:outputLink ... >
<rich:panelMenuItem>
</rich:panelMenu>
...
Note:
The "expandSingle" attribute is defined for expanding more than one submenu on the same
level. The default value is "false" . If it's true the previously opened group on the top level closes
before opening another one. See the picture below.
300
Chapter 6. The RichFaces Components
The "selectedChild" attribute is used for defining the name of the selected group or item. An
example for group is placed below:
Here is an example:
...
<rich:panelMenu selectedChild="thisChild">
<rich:panelMenuGroup label="Group1" name="thisChild">
<!--Nested panelMenu components-->
</rich:panelMenuGroup>
</rich:panelMenu>
...
The "label" attribute is a generic attribute. The "label" attribute provides an association between
a component, and the message that the component (indirectly) produced. This attribute defines
the parameters of localized error and informational messages that occur as a result of conversion,
validation, or other application actions during the request processing lifecycle. With the help of
this attribute you can replace the last parameter substitution token shown in the messages. For
example, {1} for "DoubleRangeValidator.MAXIMUM", {2} for "ShortConverter.SHORT".
Name Value
component-type org.richfaces.PanelMenu
component-class org.richfaces.component.html.HtmlPanelMenu
component-family org.richfaces.PanelMenu
renderer-type org.richfaces.PanelMenuRenderer
tag-class org.richfaces.taglib.PanelMenuTag
Function Description
expand() Expands group element
collapse() Collapses group element
301
Chapter 6. The RichFaces Components
302
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.7.1. Description
The <rich:panelMenuGroup> defines an expandable group of <rich:panelMenuItem>
components inside the <rich:panelMenu>.
303
Chapter 6. The RichFaces Components
• Can be disabled
Switching mode could be chosen with the"expandMode" attribute for the concrete panelMenu
group. The "expandMode" attribute could be used with three possible parameters:
• None.
"Action" and "actionListener" attributes are ignored. Items don't fire any submits itself. Behavior
is fully defined by the components nested into items.
There are three icon-related attributes. The "iconExpanded" attribute defines an icon for an
expanded state. The "iconCollapsed" attribute defines an icon for a collapsed state. The
"iconDisabled" attribute defines an icon for a disabled state. Default icons are shown on the
picture below:
Here is an example:
...
<rich:panelMenu>
<rich:panelMenuGroup label="Group1" iconExpanded="disc" iconCollapsed="chevron">
<!--Nested panelMenu components-->
</rich:panelMenuGroup>
</rich:panelMenu>
...
As the result the pictures are shown below. The first one represents the collapsed state, the
second one - expanded state:
304
Chapter 6. The RichFaces Components
It's also possible to define a path to the icon. Simple code is placed below.
...
<rich:panelMenu>
<rich:panelMenuGroup label="Group1" iconExpanded="\images
\img1.png" iconCollapsed="\images\img2.png">
<!--Nested menu components-->
</rich:panelMenuGroup>
</rich:panelMenu>
...
Information about the "process" attribute usage you can find "Decide what to process" guide
section.
305
Chapter 6. The RichFaces Components
Function Description
expand() Expands group
collapse() Collapses group
306
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.8.1. Description
The <rich:panelMenuItem> defines a single item inside <rich:panelMenuGroup>.
• Can be disabled
307
Chapter 6. The RichFaces Components
• None
"Action" and "actionListener" attributes are ignored. Items don't fire any submits itself. Behavior is
fully defined by the components nested into items. Here is an example for value none:
...
<rich:panelMenu>
...
<rich:panelMenuItem mode="none" onclick="document.location.href='http://labs.jboss.com/
jbossrichfaces/">
<h:outputLink value="http://labs.jboss.com/jbossrichfaces/">
<h:outputText value="RichFaces Home Page"></h:outputText>
</h:outputLink>
</rich:panelMenuItem>
...
</rich:panelMenu>
...
There are two icon-related attributes. The "icon" attribute defines an icon. The "iconDisabled"
attribute defines an icon for a disabled item.
...
<rich:panelMenu>
...
308
Chapter 6. The RichFaces Components
It's also possible to define a path to the icon. Simple code is placed below.
...
<rich:panelMenu>
...
<rich:panelMenuItem value="Item 1.1" icon="\images\img1.png" />
...
</rich:panelMenu>
...
Information about the "process" attribute usage you can find in the "Decide what to process" guide
section.
Name Value
component-type org.richfaces.PanelMenuItem
component-class org.richfaces.component.html.HtmlPanelMenuItem
component-family org.richfaces.PanelMenuItem
renderer-type org.richfaces.PanelMenuItemRenderer
tag-class org.richfaces.taglib.PanelMenuItemTag
309
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.9.1. Description
The <rich:progressBar> component is designed for displaying a progress bar which shows the
current status of the process.
310
Chapter 6. The RichFaces Components
As it was mentioned above, the <rich:progressBar> component displays the status of the
ongoing process.
The <rich:progressBar> component can run in two modes: Ajax (default) and Client.
• Ajax - In this mode the component works the same way as <a4j:poll/> which gets the current
progress value from the sever, repeating after a set time interval.
• Client - The current progress value in Client mode is set using JavaScript API
One of the key attributes of the component is "interval" which defines the frequency of status
polling and rerenders the component when the value is updated.
Example:
...
<rich:progressBar value="#{bean.incValue}" id="progrs" interval="900" enabled="true"/>
...
With the help of "timeout" attribute you can define the waiting time on a particular request. If a
response is not received during this time the request is aborted.
311
Chapter 6. The RichFaces Components
Example:
...
<rich:progressBar value="#{bean.incValue}" minValue="50" maxValue="400"/>
...
Example:
...
<rich:progressBar value="#{bean.incValue}" id="progrs" label="#{bean.incValue}"/>
...
• Using any child(nested) components. One of the components that can be used is
<h:outputText />
Example:
...
<rich:progressBar value="#{bean.incValue}">
<h:outputText value="#{bean.incValue} %"/>
</rich:progressBar>
...
312
Chapter 6. The RichFaces Components
Example:
...
<rich:progressBar value="#{bean.incValue1}" minValue="400" maxValue="900">
<h:outputText value="Min value is {minValue}, current value is {value}, max value
is {maxValue}"/>
</rich:progressBar>
...
The "parameters" is also a special attribute which defines parameters that can be to get additional
data from server (e.g. additional info about process status). All you need is to define the value
of your own parameter (e.g parameters="param:'#{bean.incValue1}'") and you can use it to
pass the data.
Example:
...
<rich:progressBar value="#{bean.incValue}" parameters="param:'#{bean.dwnlSpeed}'">
<h:outputText value="download speed {param} KB/s"/>
</rich:progressBar>
...
The "progressVar" attribute (deprecated) defines request scoped variable that could be used for
substitution purpose. This variable contains the data taken from "value" attribute. Please, study
carefully the following example.
Example:
...
<rich:progressBar value="#{bean.incValue1}" enabled="#{bean.enabled1}" id="progrs1" progressVar="progress">
<h:outputText value="{progress}%"/>
313
Chapter 6. The RichFaces Components
</rich:progressBar>
...
In the shown example "progressVar" attribute defines a variable "progress" with the value taken
from "value" attribute of the <rich:progressBar> component. The "progress" variable performs
substitution passing the current progress value to the "value" attribute of the <h:outputText> .
This is how the current value of a progress appears on the label of <rich:progressBar> .
As the "progressVar" attribute is deprecated, it's better to use the predefined macrosubstitution
parameter {value} instead. See how you can rewrite the above example with the help of {value}.
Example:
...
<rich:progressBar value="#{bean.incValue1}" enabled="#{bean.enabled1}" id="progrs1">
<h:outputText value="{value}%"/>
</rich:progressBar>
...
The component can also employ "initial" and "complete" facets to display the states of the
process: "initial" facet is displayed when the progress value is less or equal to "minValue" , and
the "complete" facet is shown when the value is greater or equal to "maxValue" . Please see
an example below.
Example:
...
<rich:progressBar value="#{bean.incValue1}">
<f:facet name="initial">
<h:outputText value="Process not started"/>
</f:facet>
<f:facet name="complete">
<h:outputText value="Process completed"/>
</f:facet>
</rich:progressBar>
...
Information about the "process" attribute usage you can find " Decide what to process " guide
section.
314
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.ProgressBar
component-class org.richfaces.component.html.HtmlProgressBar
component-family org.richfaces.ProgressBar
renderer-type org.richfaces.renderkit.ProgressBarRenderer
tag-class org.richfaces.taglib.ProgressBarTag
Function Description
enable() Begins polling for Ajax mode
disable() Stops polling for Ajax mode
setValue(value) Updates the progress of the process
setLabel(label) Update the label for the process
315
Chapter 6. The RichFaces Components
Note:
It's necessary to define width of the component in pixels only.
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.10.1. Description
A horizontal line to use as a separator in a layout. The line type can be customized with the
"lineType" parameter.
316
Chapter 6. The RichFaces Components
The line type can be customized with the "lineType" parameter. For example, different
line types are shown after rendering with the following initial settings lineType="double"and
lineType="solid".
• "onmouseover"
• "onclick"
• "onmouseout"
• etc.
Name Value
component-type org.richfaces.separator
317
Chapter 6. The RichFaces Components
Name Value
component-class org.richfaces.component.html.HtmlSeparator
component-family org.richfaces.separator
renderer-type org.richfaces.SeparatorRenderer
tag-class org.richfaces.taglib.SeparatorTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.11.1. Description
318
Chapter 6. The RichFaces Components
• Server
• Client
• Ajax
The component is a simplified version of toggle panel that initially has a defined layout as a panel
with a header playing a role of a mode switching control. On a component header element, it's
possible to define a label using an attribute with the same name.
Switching mode could be defined with the "switchType" attribute with three possible parameters.
• Server (DEFAULT)
• Ajax
AJAX form submission is performed around the panel, content of the called panel is uploaded
on Ajax request and additionally specified elements in the "reRender" attribute are rendered.
Only one at a time panel is uploaded on the client side.
• Client
All panels are uploaded on the client side. Switching from the active to the hidden panel is
performed with client JavaScript.
• "onmouseover "
• "onclick "
• "onmouseout "
• etc.
319
Chapter 6. The RichFaces Components
With help of "openMarker" and "closeMarker" facets you can set toggle icon for
simpleTogglePanel .
Information about the "process" attribute usage you can find " Decide what to process " guide
section.
Name Value
component-type org.richfaces.SimpleTogglePanel
component-class org.richfaces.component.html.HtmlSimpleTogglePanel
component-family org.richfaces.SimpleTogglePanel
renderer-type org.richfaces.SimpleTogglePanelRenderer
tag-class org.richfaces.taglib.SimpleTogglePanelTag
320
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.12.1. Description
321
Chapter 6. The RichFaces Components
<rich:spacer> is a simple layout component which represents a transparent spacer. Thus, the
main attributes that define its style are "style" and "styleClass".
In addition, the attributes are responsible for the component size: "width" and "height".
Moreover, to add e.g. some JavaScript effects, events defined on it are used.
• "onmouseover "
• "onclick "
• "onmouseout "
• etc.
Name Value
component-type org.richfaces.spacer
component-class org.richfaces.component.html.HtmlSpacer
component-family org.richfaces.spacer
renderer-type org.richfaces.SpacerRenderer
tag-class org.richfaces.taglib.SpacerTag
322
Chapter 6. The RichFaces Components
6.10.13.1. Description
The component defines a tab panel displaying tabs for grouping content of the panel.
• Customizable headers
• Each tab has a unique name for direct access (e.g. for switching between tabs)
• Server
• Client
• Ajax
• Switch methods can be selected for the whole tab panel and for the each tab separately
Note:
All tabPanels should be wrapped into a form element so as content is correctly
submitted inside. If a form is placed into each tab, the Action elements of Tab
323
Chapter 6. The RichFaces Components
controls appear to be out of the form and content submission inside the panels
could be performed only for Action components inside tabs.
Switching mode could be chosen with the tabPanel attribute "switchType" with three possible
parameters.
• server (DEFAULT)
The common submission is performed around tabPanel and a page is completely rendered on
a called panel. Only one at a time tabPanel is uploaded onto the client side.
• ajax
AJAX form submission is performed around the tabPanel, content of the called tabPanel is
uploaded on Ajax request. Only one at a time tabPanel is uploaded on the client.
• client
All tabPanels are uploaded on the client side. The switching from the active to the hidden panel
is performed with client JavaScript.
As a result, the tabPanel is switched to the second tab according to the action returning outcome
for moving onto another page and switching from the second to the first tab is performed.
There is also the "selectedTab" attribute. The attribute keeps an active tab name; therefore, an
active tabPanel could be changed with setting a name of the necessary tab to this attribute.
There is also the "headerAlignment" attribute responsible for rendering of tabPanel components.
The attribute has several values: "left" (Default), "right", "center", which specify Tabs components
location on the top of the tabPanel.
Example:
...
<rich:tabPanel width="40%" headerAlignment="right">
<rich:tab label="Canon">
...
</rich:tab>
<rich:tab label="Nikon">
...
</rich:tab>
<rich:tab label="Olympus">
...
</rich:tab>
</rich:tabPanel>
324
Chapter 6. The RichFaces Components
...
The "label" attribute is a generic attribute. The "label" attribute provides an association between
a component, and the message that the component (indirectly) produced. This attribute defines
the parameters of localized error and informational messages that occur as a result of conversion,
validation, or other application actions during the request processing lifecycle. With the help of
this attribute you can replace the last parameter substitution token shown in the messages. For
example, {1} for "DoubleRangeValidator.MAXIMUM", {2} for "ShortConverter.SHORT".
Except the specific attributes, the component has all necessary attributes for JavaScript events
definition.
• "onmouseover"
• "onmouseout"
• etc.
Name Value
component-type org.richfaces.tabPanel
component-class org.richfaces.component.html.HtmltabPanel
component-family org.richfaces.tabPanel
renderer-type org.richfaces.tabPanelRenderer
tag-class org.richfaces.taglib.tabPanelTag
325
Chapter 6. The RichFaces Components
Table 6.145. Classes names that define different tab header states
(corresponds to rich-tabhdr-side-cell)
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
If you have any questions or ideas regarding the <rich:tab> tell about them at the RichFaces
Users Forum [http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4064191].
6.10.14.1. Description
326
Chapter 6. The RichFaces Components
• Each tab has a unique name for a direct access (e.g. for switching between tabs)
• Switch methods can be easily customized for every tab separately with attribute to:
• Server
• Client
• AJAX
The main component function is to define a content group that is rendered and processed when
the tab is active, i.e. click on a tab causes switching onto a tab containing content corresponded
to this tab.
The "label" attribute defines text to be represented. If you can use the "label" facet, you can
even not use the "label" attribute.
<rich:tab>
<f:facet name="label">
<h:graphicImage value="/images/img1.png"/>
</f:facet>
<!--Any Content inside-->
327
Chapter 6. The RichFaces Components
</rich:tab>
A marker on a tab header defined with the "label" attribute. Moreover, each tab could be disabled
(switching on this tab is impossible) with the "disable" attribute.
<rich:tabPanel width="20%">
<tabs:tab label="Canon">
<h:outputText value="Canon EOS Digital Rebel XT" />
...
</tabs:tab>
<tabs:tab label="Nikon">
<h:outputText value="Nikon D70s" />
...
</tabs:tab>
<tabs:tab label="Olympus">
<h:outputText value="Olympus EVOLT E-500" />
...
</tabs:tab>
<tabs:tab disabled="true" name="disabled" label="Disabled"/>
</rich:tabPanel>
With this example it's possible to generate the tab panel with the last disabled and three active
tabs (see the picture).
328
Chapter 6. The RichFaces Components
Switching mode could be defined not only for the whole panel tab, but also for each particular tab,
i.e. switching onto one tab could be performed right on the client with the corresponding JavaScript
and onto another tab with an Ajax request on the server. Tab switching modes are the same as
tabPanel ones.
Each tab also has an attribute name (alias for "id" attribute). Using this attribute value it's possible
e.g. to set an active tab on a model level specifying this name in the corresponding attribute of
the whole tab.
Except the specific component attributes it has all necessary attributes for JavaScript event
definition.
• onmouseover
• onmouseout
• etc.
Some event could be performed on the tab which has been entered/left using ""ontabenter"" and
"ontableave" attributes. See the example below:
<rich:tabPanel>
<rich:tab label="Tab1" ontabenter="alert()">
...
329
Chapter 6. The RichFaces Components
</rich:tab>
...
</rich:tabPanel>
The following example shows how on the client side to get the names of entered/left tabs.
ontabenter="alert(leftTabName)"
Information about the "process" attribute usage you can find in the "Decide what to process"
guide section.
Name Value
component-type org.richfaces.Tab
component-class org.richfaces.component.html.HtmlTab
component-family org.richfaces.Tab
renderer-type org.richfaces.TabRenderer
tag-class org.richfaces.taglib.TabTag
330
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
If you have any questions or ideas regarding the <rich:tab> tell about them at the RichFaces
Users Forum [http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4064191].
6.10.15.1. Description
A wrapper component with named facets, where every facet is shown after activation of the
corresponding toggleControl (the other is hidden).
331
Chapter 6. The RichFaces Components
• Server
• Client
• Ajax
The initial component state is defined with "initialState" attribute, where a facet name that is
shown at first is defined.
Note:
It's also possible to define an "empty" facet to implement the functionality as drop-
down panels have and make the facet active when no content is required to be
rendered.
332
Chapter 6. The RichFaces Components
Switching mode could be defined with the "switchType" attribute with three possible parameters:
• Server (DEFAULT)
The common submission is performed around togglePanel and a page is completely rendered
on a called panel. Only one at a time the panel is uploaded onto the client side.
• Ajax
AJAX form submission is performed around the panel, content of the called panel is uploaded
on an Ajax request . Only one at a time the panel is uploaded on the client side.
• Client
All panels are uploaded on the client side. The switching from the active to the hidden panel
is performed with client JavaScript.
Example:
...
<rich:togglePanel id="panel" initialState="panelB" switchType="client"
stateOrder="panelA,panelB,panelC">
<f:facet name="panelA">
...
</f:facet>
<f:facet name="panelB">
...
</f:facet>
<f:facet name="panelC">
...
</f:facet>
</rich:togglePanel>
<rich:toggleControl for="panel" value="Switch"/>
...
The example shows a togglePanel initial state when the second facet (panelB) is rendered and
successive switching from the first to the second happens.
The "label" attribute is a generic attribute. The "label" attribute provides an association between
a component, and the message that the component (indirectly) produced. This attribute defines
333
Chapter 6. The RichFaces Components
the parameters of localized error and informational messages that occur as a result of conversion,
validation, or other application actions during the request processing lifecycle. With the help of
this attribute you can replace the last parameter substitution token shown in the messages. For
example, {1} for "DoubleRangeValidator.MAXIMUM", {2} for "ShortConverter.SHORT".
Name Value
component-type org.richfaces.TogglePanel
component-class org.richfaces.component.html.HtmlTogglePanel
component-family org.richfaces.TogglePanel
renderer-type org.richfaces.TogglePanelRenderer
tag-class org.richfaces.Taglib.togglePanelTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.16.1. Description
A link type control for switching between togglePanel facets. Target Panel is specified with
"for" attribute. It can be located inside or outside the togglePanel. As the result of switching
between facets previous facet is hidden and another one (specified with "switchToState" or panel
"stateOrder" attributes) is shown.
334
Chapter 6. The RichFaces Components
• Server
• Client
• Ajax
As it was mentioned above, the control could be in any place in layout and linked to a switching
panel that is managed with "for" attribute (in the "for" attribute the full component "id" is specified
according to naming containers).
The togglePanel could be also switched from the side of the control instead of being strictly defined
in "switchOrder" attribute of <rich:togglePanel>.
Example:
...
<rich:togglePanel id="panel" initialState="empty" switchType="client">
<f:facet name="first">
<h:panelGroup>
<rich:toggleControl for="helloForm:panel" value="Empty" switchToState="empty"/>
335
Chapter 6. The RichFaces Components
In this example the switching is performed on facets specified in the "switchToState" attribute.
Information about the "process" attribute usage you can find " Decide what to process " guide
section.
Name Value
component-type org.richfaces.ToggleControl
component-class org.richfaces.component.html.HtmlToggleControl
component-family org.richfaces.ToggleControl
renderer-type org.richfaces.ToggleControlRenderer
tag-class org.richfaces.taglib.ToggleControlTag
336
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.17.1. Description
A horizontal bar with Action items on it that accepts any JSF components as children.
• Standard top menu bar that can be used in accordance with a menu component
• Easily place content on any side of a menu bar using predefined group layout
A toolBar is a wrapper component that facilitates creation of menu and tool bars. All components
defined inside are located on a stylized bar with possibility to group, arrange on the both bar sides,
and place predefined separators between them.
Grouping and an input side definition is described for toolBarGroup that defines this functionality.
Separators are located between components with the help of the "itemSeparator" attribute with
four predefined values:
• "none"
• "line"
• "square"
• "disc"
For example, when setting a separator of a disc type, the following result is produced:
337
Chapter 6. The RichFaces Components
Moreover, for toolBar style "width" and "height" attributes are placed above all.
Example:
...
<f:facet name="itemSeparator">
<rich:separator width="2" height="14" />
</f:facet>
...
Custom separator can be also specified by URL to the separator image in the attribute
"itemSeparator" of the <rich:toolBar> .
Example:
...
<rich:toolBar id="toolBar" width="#{bean.width}" height="#{bean.height}" itemSeparator="/
images/separator_img.jpg"/>
...
This is a result:
338
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.ToolBar
component-class org.richfaces.component.html.HtmlToolBar
component-family org.richfaces.ToolBar
renderer-type org.richfaces.ToolBarRenderer
tag-class org.richfaces.taglib.ToolBarTag
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.18.1. Description
339
Chapter 6. The RichFaces Components
• Easily place content on either side of tool bar using a predefined group layout
Separators are located between components with the help of the "itemSeparator" attribute with
four predefined values:
• "none"
• "line"
• "square"
• "disc"
To control the group location inside, use the "location" attribute with "left" (DEFAULT) and "right"
values.
Example:
...
<rich:toolBar itemSeparator="disc" width="500">
<rich:toolBarGroup itemSeparator="line">
<h:commandLink value="Command 1.1"/>
<h:commandLink value="Command 2.1"/>
</rich:toolBarGroup>
<rich:toolBarGroup itemSeparator="line" location="right">
<h:commandLink value="Command 1.2"/>
<h:commandLink value="Command 2.2"/>
</rich:toolBarGroup>
</rich:toolBar>
...
340
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.10.19.1. Description
The <rich:toolTip> component is used for creation of event-triggered non modal popup, that
contains information regarding the page element, that event was applied to.
• Disablement support
341
Chapter 6. The RichFaces Components
Text information, labeled on the <rich:toolTip> , is specified with "value" attribute. Text that
is put between tooltip start and end tags will also be rendered as tooltip content and could be
marked with HTML tags. Images, links, buttons and other RichFaces components are also may
be put and composed inside the <rich:toolTip> . The <rich:toolTip> borders are stretched
automatically to enclose the contents.
There are three ways to attach the <rich:toolTip> to a page element. The first and simplest
one is when the <rich:toolTip> is nested into a page element the tooltip is applied to. This way
is shown on example in the Creating the Component with a Page Tag section. The "attached"
attribute is "true" by default in this case, which means that the tolltip will be invoked automatically
when the mouse cursor is hovered above the parent component.
The second one uses <rich:toolTip> "for" attribute. In this case the <rich:toolTip> is defined
separately from a component it is applied to.
Example:
<rich:panel id="panelId">
...
</rich:panel>
<rich:toolTip value="This is a tooltip." for="panelId"/>
These two ways are also applicable for HTML elements that are not presented in components
tree built by facelets. Use "for" attribute to attach the <rich:toolTip> in both cases.
Example:
<!-- The <rich:toolTip> is nested into the parent HTML element -->
<div id="para1">
<p>This paragraph and tooltip are nested into the same <div> element.</p>
<rich:toolTip for="para1">This is a tooltip.</rich:toolTip>
</div>
The third way to invoke the <rich:toolTip> uses JS API function. List of JS API functions
available for <rich:toolTip> is listed below. JS API functions are defined for a component the
342
Chapter 6. The RichFaces Components
<rich:toolTip> is applied to. The <rich:toolTip> "attached" attribute should be set to "false"
in this case.
Example:
Notes:
To provide <rich:toolTip> component proper work in complex cases do the
following:
• define the <rich:toolTip> as last child, when nesting it into the component the
<rich:toolTip> is applied to;
• put the <rich:toolTip> into <a4j:form> when invoking it with JS API function.
The "mode" attribute is provided you to control the way of data loading to <rich:toolTip> . The
component works properly in client and Ajax modes. In client mode <rich:toolTip> content is
rendered once on the server and could be rerendered only via external submit. In Ajax mode
<rich:toolTip> content is requested from server for every activation. For Ajax mode there is
possibility to define a facet "defaultContent" , which provides default <rich:toolTip> content to
be displayed, while main content is loading into the <rich:toolTip> (see the example below).
Example:
...
<h:commandLink value="Simple Link" id="link">
<rich:toolTip followMouse="true" direction="top-
right" mode="ajax" value="#{bean.toolTipContent}" horizontalOffset="5"
verticalOffset="5" layout="block">
<f:facet name="defaultContent">
<f:verbatim>DEFAULT TOOLTIP CONTENT</f:verbatim>
</f:facet>
</rich:toolTip>
</h:commandLink>
...
343
Chapter 6. The RichFaces Components
<rich:toolTip> appears attached to the corner dependent on the "direction" attribute. By default
it is positioned bottom-right. <rich:toolTip> activation occurs after an event, defined on the
parent component, takes into consideration the "delay" attribute or after calling JS API function
show(). "hideEvent" attribute defines the way how <rich:toolTip> disappears. It default value
is "none", so the <rich:toolTip> does not disappears. Deactivation may be set for example on
mouseout event on the parent component (excepting the situation when the mouse is hovered
onto the <rich:toolTip> itself) or after calling JS API function hide().
By default, <rich:toolTip> appears smart positioned. But as you can see from the previous
example, you can define an appearance direction via the corresponding attribute "direction" . And
also it's possible to define vertical and horizontal offsets relatively to a mouse position.
Disabled <rich:toolTip> is rendered to a page as usual but JS that responds for its activation
is disabled until enable() is called.
Moreover, to add some JavaScript effects, client events defined on it are used:
Standart:
• "onclick"
• "ondblclick"
• "onmouseout"
• "onmousemove"
• "onmouseover"
Special:
• "onshow" - Called after the tooltip is called (some element hovered) but before its request
344
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.component.toolTip
component-class org.richfaces.component.html.HtmlToolTip
component-family org.richfaces.component.toolTip
renderer-type org.richfaces.renderkit.html.toolTipRenderer
tag-class org.richfaces.taglib.HtmlToolTipTag
Function Description
show() Shows the corresponding toolTip
hide() Hides the corresponding toolTip
enable() Enables the corresponding toolTip
disable() Disables the corresponding toolTip
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
345
Chapter 6. The RichFaces Components
6.11.1.1. Description
The <rich:calendar> component is used to create inputs for date and time and enter them inline
or using pup-up calendar that allows to navigate through months and years.
• Popup representation
• Disablement support
• Cells customization
346
Chapter 6. The RichFaces Components
• client — the default mode. In this mode calendar loads an initial portion of data within
a definite date range. The range is specified with the help of "preloadDateRangeBegin"
and "preloadDateRangeEnd" attributes that are designed for this mode only! Additional data
requests are not sent.
• ajax — in this mode the <rich:calendar> requests portions of data for element rendering
from special Data Model. The default calendar Data Model could be redefined with the help
of dataModel attribute that points to the object that implements CalendarDataModel
[../../apidoc_framework/org/richfaces/model/CalendarDataModel.html] interface.
If "dataModel" attribute has "null" value, data requests are not sent. In this case the "ajax"
mode is equal to the "client".
The <rich:calendar> could be represented on a page in two ways (a) the calendar itself without
input field and button and (b) date input with button and popping-up calendar. This is defined with
"popup" attribute, which is "true" by default. For popup rendering a "lazy" loading is implemented:
a client side script method builds the popup after request is completed. Such improvement speeds
up page loading time.
By default the <rich:calendar> is rendered as input filed with a button and calendar hidden in
a pop-up. The button is represented with calendar pictogramm. This pictogramm could be easily
changed with the help of "buttonIcon" and "buttonIconDisabled" attributes, which specify the
icon for button enabled and disabled states respectively. To change the button appearance from
347
Chapter 6. The RichFaces Components
icon to usual button define the value for the "buttonLabel" attribute. In this case "buttonIcon"
and "buttonIconDisabled" attributes are ignored.
There are two attributes that specify the place where the popup calendar is rendered relative to the
input field and icon: "jointPoint" and "direction" attributes. By default the pop-up calendar appears
under input and aligned with it left border (see Fig. 6.211, b). Speaking in terms of RichFaces it
means that <rich:calendar> jointPoint="bottom-left" and direction="bottom-right". There are
four possible joint-points and four possible directions for each joint-point. Besides that, the values
of "jointPoint" and "direction" could be set to "auto" that activates smart pop-up positioning.
Figure 6.119. Four possible positions of joint-points (red) and four possible
directions (black) shown for bottom-left joint-point.
With help of the "currentDate" attribute you can define month and year which will be displayed
currently.
348
Chapter 6. The RichFaces Components
The "todayControlMode" attribute defines the mode for "today" control. Possible values are:
• "select" - (default) in this state "Today" button activation will scroll the calendar to the current
date and it become selected date
• "scroll" - in this mode "Today" activation will simply scroll the calendar to current month without
changing selected day.
With the help of the "readonly" attribute you can make date, time and input field unavailable, but
you can look through the next/previous month or the next/previous year.
In order to disable the component, use the "disabled" attribute. With its help both controls are
disabled in the "popup" mode.
The "onchanged" attribute is used to define an event that is triggered from date selection, as
shown in the example below:
...
<rich:calendar id="date" value="#{bean.dateTest}">
<a4j:support event="onchanged" reRender="mainTable"/>
</rich:calendar>
...
The "ondateselect" attribute is used to define an event that is triggered before date selection. It
could be used for possibility of date selection canceling. See an example below:
...
<rich:calendar id="date" value="#{bean.dateTest}" ondateselect="if (!confirm('Are you sure to
change date?')){return false;}"/>
...
The "ondateselected" attribute is used to define an event that is triggered after date selection.
"oncurrentdateselect" event is fired when the "next/previous month" or "next/previous year" button
is pressed, but the value is not applied yet (you can change the logic of applying the value). Also
349
Chapter 6. The RichFaces Components
this event could be used for possibility of "next/previous month" or "next/previous year" selection
canceling. See an example below:
Example:
...
<rich:calendar id="date" value="#{bean.dateTest}" oncurrentdateselect="if (!confirm('Are you
sure to change month(year)?')){return false;}"
oncurrentdateselected="alert('month(year) select:'+event.rich.date.toString());"/>
...
How to use these attributes see also on the RichFaces Users Forum [http://www.jboss.com/
index.html?module=bb&op=viewtopic&p=4092275#4092275].
Information about the "process" attribute usage you can find in the corresponding section .
The "label" attribute is a generic attribute. The "label" attribute provides an association between
a component, and the message that the component (indirectly) produced. This attribute defines
the parameters of localized error and informational messages that occur as a result of conversion,
validation, or other application actions during the request processing lifecycle. With the help of
this attribute you can replace the last parameter substitution token shown in the messages. For
example, {1} for "DoubleRangeValidator.MAXIMUM", {2} for "ShortConverter.SHORT".
The "defaultTime" attribute to set the default time value for the current date in two cases:
• If another date is selected and the value of the "resetTimeOnDateSelect" attribute is set to
"true"
Also you can use "weekNumber" facet with available {weekNumber}, {elementId}
elements and "weekDay" facet with {weekDayLabel}, {weekDayLabelShort},
{weekDayNumber}, {isWeekend}, {elementId} elements. {weekNumber}, {weekDayLabel},
{weekDayLabelShort}, {weekDayNumber} elements could be used for labels output,
{isWeekend}, {elementId} - for additional processing in JavaScript code.
350
Chapter 6. The RichFaces Components
Example:
...
<!-- Styles for cells -->
<style>
.width100{
width:100%;
}
.talign{
text-align:center;
}
</style>
...
...
<rich:calendar id="myCalendar" popup="true" locale="#{calendarBean.locale}" value="#{bean.date}"
preloadRangeBegin="#{bean.date}" preloadRangeEnd="#{bean.date}" cellWidth="40px" cellHe
351
Chapter 6. The RichFaces Components
This is a result:
352
Chapter 6. The RichFaces Components
It is possible to show and manage date. Except scrolling controls you can use quick month and
year selection feature. It's necessary to click on its field, i.e. current month control, and choose
required month and year.
353
Chapter 6. The RichFaces Components
Also the <rich:calendar> component allows to show and manage time. It's necessary to define
time in a pattern (for example, it could be defined as "d/M/yy HH:mm"). Then after you choose
some data in the calendar, it becomes possible to manage time for this date. For time editing it's
necessary to click on its field (see a picture below). To clean the field click on the "Clean".
It's possible to handle events for calendar from JavaScript code. A simplest example of usage
JavaScript API is placed below:
Example:
...
354
Chapter 6. The RichFaces Components
Also the discussion about this problem can be found on the RichFaces Users Forum [http://
www.jboss.com/index.html?module=bb&op=viewtopic&p=4078301#4078301].
Note:
Name Value
component-type org.richfaces.Calendar
component-class org.richfaces.component.html.HtmlCalendar
component-family org.richfaces.Calendar
renderer-type org.richfaces.CalendarRenderer
tag-class org.richfaces.taglib.CalendarTag
355
Chapter 6. The RichFaces Components
Function Description
selectDate(date) Selects the date specified. If the date isn't in
current month - performs request to select
isDateEnabled(date) Checks if given date is selectable (to be
implemented)
enableDate(date) Enables date cell control on the calendar (to be
implemented)
disableDate(date) Disables date cell control on the calendar (to
be implemented)
enableDates(date[]) Enables dates cell controls set on the calendar
(to be implemented)
disableDates(date[]) Disables dates cell controls set on the calendar
(to be implemented)
nextMonth() Navigates to next month
nextYear() Navigates to next year
prevMonth() Navigates to previous month
prevYear() Navigates to previous year
today() Selects today date
getSelectedDate() Returns currently selected date
Object getData() Returns additional data for the date
getCurrentMonth() Returns number of the month currently being
viewed
getCurrentYear() Returns number of the year currently being
viewed
doCollapse() Collapses calendar element
doExpand() Expands calendar element
resetSelectedDate() Clears a selected day value
doSwitch() Inverts a state for the popup calendar
Facet Description
header Redefines calendar header. Related attribute
is "showHeader"
footer Redefines calendar footer. Related attribute is
"showFooter"
optionalHeader Defines calendar's optional header
356
Chapter 6. The RichFaces Components
Facet Description
optionalFooter Defines calendar's optional footer
weekNumber Redefines week number
weekDay Redefines names of the week days.
Related attributes are "weekDayLabels" and
"weekDayLabelsShort"
357
Chapter 6. The RichFaces Components
358
Chapter 6. The RichFaces Components
359
Chapter 6. The RichFaces Components
360
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
How to use JavaScript API see on the RichFaces Users Forum [http://www.jboss.com/index.html?
module=bb&op=viewtopic&p=4078301#4078301].
361
Chapter 6. The RichFaces Components
6.11.2.1. Description
The <rich:colorPicker> component lets you visually choose a color or define it in hex, RGB,
or HSB input fields.
• Flat/inline representation
The <rich:colorPicker> component allows you easily select a color or define it in hex, RGB,
or HSB input fields. There are two squares in the widget that help you to compare the currently
selected color and the already selected color.
The value of the <rich:colorPicker> component could be saved in hex or RGB color models.
You can explicitly define a color model in the "colorMode" attribute.
Example:
...
<rich:colorPicker value="#{bean.color}" colorMode="rgb" />
...
362
Chapter 6. The RichFaces Components
The <rich:colorPicker> component has two representation states: flat and inline. With the help
of the "flat" attribute you can define whether the component is rendered flat.
Example:
...
<rich:colorPicker value="#{bean.color}" flat="true" />
...
The component specific event handler "onbeforeshow" captures the event which occurs before
the <rich:colorPicker> widget is opened. The "onbeforeshow" attribute could be used in order
to cancel this event. See the example below:
...
<rich:colorPicker value="#{bean.color}" onbeforeshow="if (!confirm('Are you sure you want to
change a color?')){return false;}" />
...
The "showEvent" attribute defines the event that shows <rich:colorPicker> widget. The default
value is "onclick".
...
<rich:colorPicker value="#{bean.color}">
<f:facet name="icon">
<h:graphicImage value="/pages/colorPicker_ico.png" />
363
Chapter 6. The RichFaces Components
</f:facet>
<f:facet name="arrows">
<f:verbatim>
<div style="width: 33px; height: 5px; border: 1px solid #bed6f8; background:none;" />
</f:verbatim>
</f:facet>
</rich:colorPicker>
...
Name Value
component-type org.richfaces.ColorPicker
component-class org.richfaces.component.html.HtmlColorPicker
component-family org.richfaces.ColorPicker
renderer-type org.richfaces.ColorPickerRenderer
tag-class org.richfaces.taglib.ColorPickerTag
Facet Description
arrows Redefines colorPicker arrows
icon Redefines colorPicker icon
364
Chapter 6. The RichFaces Components
365
Chapter 6. The RichFaces Components
366
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.11.3.1. Description
The <rich:comboBox> component allows to create a combobox element with the built-in Ajax
capability.
• Client-side suggestions
• Disablement support
The <rich:comboBox> is a simplified suggestion box component, that provides input with client-
side suggestions. The component could be in two states:
367
Chapter 6. The RichFaces Components
There are two ways to get values for the popup list of suggestions:
...
<rich:comboBox value="#{bean.state}" suggestionValues="#{bean.suggestions}" />
...
...
<rich:comboBox value="#{bean.state}" valueChangeListener="#{bean.selectionChanged}">
<f:selectItems value="#{bean.selectItems}"/>
<f:selectItem itemValue="Oregon"/>
<f:selectItem itemValue="Pennsylvania"/>
<f:selectItem itemValue="Rhode Island"/>
<f:selectItem itemValue="South Carolina"/>
</rich:comboBox>
...
Note:
These JSF components consider only the "value" attribute for this component.
Popup list content loads at page render time. No additional requests could be performed on the
popup calling.
The "directInputSuggestions" attribute defines, how the first value from the suggested one
appears in an input field. If it's "true" the first value appears with the suggested part highlighted.
...
<rich:comboBox
value="#{bean.state}"
suggestionValues="#{bean.suggestions}"
directInputSuggestions="true"
/
>
...
368
Chapter 6. The RichFaces Components
This is a result:
The "selectFirstOnUpdate" attribute defines if the first value from suggested is selected in a popup
list. If it's "false" nothing is selected in the list before a user hovers some item with the mouse.
...
<rich:comboBox
value="#{bean.state}"
suggestionValues="#{bean.suggestions}"
selectFirstOnUpdate="false"
/
>
...
This is a result:
The "defaultLabel" attribute defines the default label of the input element. Simple example is
placed below.
...
<rich:comboBox value="#{bean.state}"
suggestionValues="#{bean.suggestions}"
defaultLabel="Select
a city..." />
...
This is a result:
369
Chapter 6. The RichFaces Components
With the help of the "disabled" attribute you can disable the whole <rich:comboBox>
component. See the following example.
...
<rich:comboBox value="#{bean.state}"
suggestionValues="#{bean.suggestions}"
defaultLabel="Select
a city..." disabled="true" />
...
This is a result:
• "onlistcall" which is fired before the list opening and gives you a possibility to cancel list popup/
update
• "onselect" which gives you a possibility to send Ajax request when item is selected
• "listWidth" and "listHeight" attributes specify popup list sizes with values in pixels
• "width" attribute customizes the size of input element with values in pixels.
Name Value
component-type org.richfaces.ComboBox
component-class org.richfaces.component.html.HtmlComboBox
component-family org.richfaces.ComboBox
renderer-type org.richfaces.renderkit.ComboBoxRenderer
370
Chapter 6. The RichFaces Components
Name Value
tag-class org.richfaces.taglib.ComboBoxTag
Function Description
showList() Shows the popup list
hideList() Hides the popup list
enable() Enables the control for input
disable() Disables the control for input
371
Chapter 6. The RichFaces Components
372
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.11.4.1. Description
The <rich:editor> component is used for creating a WYSIWYG editor on a page.
373
Chapter 6. The RichFaces Components
Example:
Implementation of <rich:editor> provides three ways to define the properties of the component:
1. Using attributes
3. Using configuration files that allow you to set up multiple configurations for all editors in your
application and change them in the runtime
The most important properties are implemented as attributes and you can define them as any other
attribute. The attributes of the <rich:editor> component match the corresponding properties of
TinyMCE editor.
For example, a theme for the editor can be defined using the "theme" attribute like this:
Example:
Setting a different skin for the editor can be done using the "skin" attribute.
Another useful property that is implemented at attribute level is "viewMode" . The attribute
switches between "visual" and "source" modes, toggling between modes is performed setting the
attribute to "visual" and "source" respectively. Implementation of <rich:editor> also implies that
you can change the modes dynamically setting the value of the "viewMode" attribute using EL-
expression.
Example:
...
<rich:editor value="#{editor.submit}" theme="advanced" viewMode="#{editor.viewMode}" >
...
<h:selectOneRadio value="#{editor.viewMode}" onchange="submit();">
<f:selectItem itemValue="visual" itemLabel="visual" />
<f:selectItem itemValue="source" itemLabel="source" />
374
Chapter 6. The RichFaces Components
</h:selectOneRadio>
...
</rich:editor>
...
Most configuration options that TinyMCE provides can be applied using <f:param> JSF tag.
The syntax is quite simple: the "name" attribute should contain the option, the "value" attribute
assigns some value to the option.
For example, this code adds some buttons to the editor and positions the toolbar.
Example:
...
<rich:editor value="#{bean.editorValue}" theme="advanced" plugins="save,paste" >
<f:param name="theme_advanced_buttons1" value="bold,italic,underline,
cut,copy,paste,pasteword"/>
<f:param name="theme_advanced_toolbar_location" value="top"/>
<f:param name="theme_advanced_toolbar_align" value="left"/>
</rich:editor>
...
The third way to configure the <rich:editor> is to use configuration file (.properties)
This method eases your life if you need to configure multiple instances of the <rich:editor> : you
configure the editor once and in one spot and the configuration properties can be applied to any
<rich:editor> in your application.
375
Chapter 6. The RichFaces Components
• Create a configuration file (.properties) in the classpath folder and add some properties to it. Use
standard syntax for the .properties files: parameter=value. Here is an example of configuration
file:
Example:
theme="advanced"
plugins="save,paste"
theme_advanced_buttons1="bold,italic,underline, cut,copy,paste,pasteword"
theme_advanced_toolbar_location="top"
theme_advanced_toolbar_align="left"
• The properties stored in configuration file are passed to the <rich:editor> via "configuration"
attribute which takes the name of the configuration file as a value (with out .properties
extension).
For example, if you named the configuration file "editorconfig", you would address it as follows:
Example:
...
<rich:editor value="#{bean.editorValue}" configuration="editorconfig"/>
...
• Alternately, you can use a EL-expression to define a configuration file. This way you can
dynamically change the sets of configuration properties.
To do this you need to bind "configuration" attribute to the appropriate bean property like this.
Example:
...
<rich:editor value="#{bean.editorValue}" configuration="#{editor.configuration}" />
...
...
String configuration;
376
Chapter 6. The RichFaces Components
You also might want to add some custom plug-ins to your editor. You can read about how to create
a plugin in TinyMCE Wiki article [http://wiki.moxiecode.com/index.php/TinyMCE:Creating_Plugin].
Adding a custom plugin also requires a few steps to take. Though, the procedure is very similar
to adding a configuration file.
• Create a .properties file and put the name of the plug-in and a path to it into the file. The file can
contain multiple plug-in declarations. Your .properties file should be like this.
Example:
...
pluginName=/mytinymceplugins/plugin1Name/editor_plugin.js
...
• Use the "customPlugins" attribute to specify the .properties file with a plugin name and a path
to it.
If your .properties file is named "myPlugins", then your will have this code on the page.
Example:
...
<rich:editor theme="advanced" customPlugins="myPlugins" plugins="pluginName" />
...
Note:
Some plug-ins which available for download might have some dependencies on
TinyMCE scripts. For example, dialog pop-ups require tiny_mce_popup.js script
file. Assuming that you will not plug custom plugins to the RF jar with editor
377
Chapter 6. The RichFaces Components
component (standard TinyMCE plugins creation implies that plugins are put into
TinyMCE's corresponding directory) you should manually add required TinyMCE
scripts to some project folder and correct the js includes.
The implementation of the <rich:editor> component has two methods for handling events.
The attributes take some function name as a value with is triggered on the appropriate event. You
need to use standard JavaScript function calling syntax.
Example:
...
<rich:editor value="#{bean.editorValue}" onchange="myCustomOnChangeHandler()" />
...
• Using <f:param> as a child element defining the "name" attribute with one of the TinyMCE's
callbacks and the "value" attribute takes the function name you want to be called on the
corresponding event as the value. Note, that the syntax in this case is a bit different: parentheses
are not required.
Example:
...
<rich:editor value="#{bean.editorValue}">
<f:param name="onchange" value="myCustomOnChangeHandler" />
</rich:editor>
...
The <rich:editor> component has a build-in converter that renders HTML code generated
by the editor to Seam text (you can read more on Seam in Seam guide [http://docs.jboss.org/
seam/1.1.5.GA/reference/en/html/text.html].), it also interprets Seam text passed to the
<rich:editor> and renders it to HTML. The converter can be enable with the "useSeamText"
attribute.
Example:
...
<p><a href="http://mysite.com">Lorem ipsum</a> <i>dolor sit</i> amet, ea <u>commodo</
u> consequat.</p>
378
Chapter 6. The RichFaces Components
...
...
[Lorem ipsum=>http://mysite.com] *dolor sit* amet, ea _commodo_ consequat.
...
Accordingly, if the Seam text is passed to the component it will be parsed to HTML code.
Name Value
component-type org.richfaces.component.Editor
component-class org.richfaces.component.html.Htmleditor
component-family org.richfaces.component.Editor
renderer-type org.richfaces.renderkit.html.EditorRenderer
tag-class org.richfaces.taglib.EditorTag
379
Chapter 6. The RichFaces Components
380
Chapter 6. The RichFaces Components
381
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
The <rich:editor> is based on TinyMCE editor and supports almost all its features and properties
some of which are not described here since you can find more detailed documentation on them
on the official web site. [http://wiki.moxiecode.com/index.php/TinyMCE:Index]
6.11.5.1. Description
382
Chapter 6. The RichFaces Components
• Automatic uploads
• Disablement support
• List of files which contains the list of currently chosen files to upload with possibility to manage
every file
• Component controls - the bar with controls for managing the whole component
There are two places where the uploaded files are stored:
• In the temporary folder (depends on OS) if the value of the createTempFile parameter in
Ajax4jsf Filter (in web.xml) section is "true" (by Default)
...
<init-param>
<param-name>createTempFiles</param-name>
383
Chapter 6. The RichFaces Components
<param-value>true</param-value>
</init-param>
...
• In the RAM if the value of the createTempFile parameter in Ajax4jsf Filter section is "false".
This is a better way for storing small-sized files.
The "uploadData" attribute defines the collection of files uploaded. See the example below.
Example:
...
<rich:fileUpload uploadData="#{bean.data}"/>
...
The "fileUploadedListener" is called at server side after every file uploaded and used for the
saving files from temporary folder or RAM.
Example:
...
<rich:fileUpload uploadData="#{bean.data}" fileUploadListener="#{bean.listener}"/>
...
The following methods for processing the uploaded files are available:
• getUploadItems(). It returns the list of the uploaded files. If one file was uploaded, the
getUploadItems() method will return the list consisting of one file
• getUploadItem(). It returns the whole list in case of uploading one file only. If several files were
uploaded, the getUploadItem() method will return the first element of the uploaded files list.
Example:
...
<rich:fileUpload
uploadData="#{bean.data}"
fileUploadListener="#{bean.listener}"
immediateUpload="true"/
>
384
Chapter 6. The RichFaces Components
...
The "autoclear" attribute is used to remove automatically files from the list after upload completed.
See the simple example below.
Example:
...
<rich:fileUpload uploadData="#{bean.data}" autoclear="true"/>
...
Each file in list waiting for upload has link "Cancel" opposite its name. Clicking this link invokes
JS API remove() function, which gets $('id').component.entries[i] as a parameter and
removes the particular file from list and from the queue for upload. After a file has been uploaded
the link "Cancel" changes to "Clear". Clicking "Clear" invokes clear() JS API function, which
also gets ID of the particular entry and removes it from the list. Uploaded to server file itself is
kept untouched.
• On file types, use "acceptedTypes" attribute to define file types accepted by component. In
the example below only files with "html" and "jpg" extensions are accepted to upload.
Example:
...
<rich:fileUpload acceptedTypes="html, jpg"/>
...
• On file size, use the maxRequestSize parameter(value in bytes) inside Ajax4jsf Filter section
in web.xml:
...
<init-param>
<param-name>maxRequestSize</param-name>
<param-value>1000000</param-value>
</init-param>
...
• On max files quantity, use the "maxFilesQuantity" attribute to define max number of files
allowed to be uploaded. After a number of files in the list equals to the value of this attribute
"Add" button is disabled and nothing could be uploaded even if you clear the whole list. In order
385
Chapter 6. The RichFaces Components
to upload files again you should rerender the component. As it could be seen in the example
below, only 2 files are accepted for uploading.
Example:
...
<rich:fileUpload maxFilesQuantity="2"/>
...
• The "onupload" which gives you a possibility to cancel the upload at client side
• The "onuploadcomplete" which is called after all files from the list are uploaded
• The "onuploadcanceled" which is called after upload has been canceled via cancel control
• The "onerror" which is called if the file upload was interrupted according to any errors
The <rich:fileUpload> component has an embedded Flash module that adds extra functionality
to the component. The module is enabled with "allowFlash" attribute set to "true".
These are the additional features that the Flash module provides:
• Permitted file types are specified in the "Open File" dialog window;
• A number of additional entry object properties are also available, which can be found RichFaces
Developer Guide section on object properties.
Apart from uploading files to the sever without using Ajax, the Flash module provides a number
of useful API functions that can be used to obtain information about the uploaded file.
386
Chapter 6. The RichFaces Components
There are 2 ways to obtain the data stored in the FileUploadEntry object.
• By means of JavaScript on the client side. Use the following syntax for that
entries[i].propertyName. For example entries[0].state will return the state of the file
that is being processed or has just been processed.
The given bellow code sample demonstrates how the properties can be used. Please study it
carefully.
...
<head>
<script>
function _onaddHandler (e) {
var i = 0;
for (; i < e.memo.entries.lenght; i++) {
alert(e.memo.entries[i].creator); //Shows creators of the added files
}
}
function _onerrorhandle(e) {
alert(e.memo.entry.fileName + "file was not uploaded due transfer error");
}
</script>
</head>
...
Moreover, embedded Flash module provides a smoother representation of progress bar during
the uploading process: the polling is performed is not by Ajax, but by means of the flash module.
387
Chapter 6. The RichFaces Components
However, the Flash module doesn't perform any visual representation of the component.
In order to customize the information regarding the ongoing process you could use "label" facet
with the following macrosubstitution:
• {B}, {KB}, {MB} contains the size of file uploaded in bytes, kilobytes, megabytes respectively
• {_B}, {_KB}, {_MB} contains the remain file size to upload in bytes, kilobytes, megabytes
respectively
• {ss}, {mm}, {hh} contains elapsed time in seconds, minutes and hours respectively
Example:
...
<rich:fileUpload uploadData="#{bean.data}" fileUploadListener="#{bean.listener}">
<f:facet name="label">
<h:outputText value="{_KB}KB from {KB}KB uploaded --- {mm}:{ss}" />
</f:facet>
</rich:fileUpload>
...
You could define labels of the component controls with the help of "addControlLabel" ,
"clearAllControlLabel" , "clearControlLabel" , "stopEntryControlLabel" , "uploadControlLabel"
attributes. See the following example.
Example:
...
<rich:fileUpload addControlLabel="Add file..." clearAllControlLabel="Clear
all" clearControlLabel="Clear"
stopEntryControlLabel="Stop process" uploadControlLabel="Upload file"/>
...
388
Chapter 6. The RichFaces Components
In order to disable the whole component you could use the "disabled" attribute. See the following
example.
Example:
...
<rich:fileUpload disabled="true"/>
...
It's possible to handle events for fileUpload using JavaScript code. A simplest example of
JavaScript API usage is placed below:
Example:
...
<rich:fileUpload id="upload" disabled="false"/>
389
Chapter 6. The RichFaces Components
The <rich:fileUpload> component also provides a number of JavaScript properties, that can
be used to process uploaded files, file states etc. The given below example illustrates how the
entries[0].state property can be used to get access to the file state. Full list of JavaScript
properties can be found below.
...
<rich:fileUpload fileUploadListener="#{fileUploadBean.listener}"
maxFilesQuantity="#{fileUploadBean.uploadsAvailable}"
id="upload"
immediateUpload="#{fileUploadBean.autoUpload}"
acceptedTypes="jpg, gif, png, bmp"/>
<a4j:support event="onuploadcomplete" reRender="info" />
</rich:fileUpload>
<h:commandButton onclick="if($('j_id232:upload').component.entries[0].state ==
FileUploadEntry.UPLOAD_SUCCESS) alert ('DONE');" value="Check file state"/>
...
To make <rich:fileUpload> component work properly with MyFaces extensions, the order in which
filters are defined and mapped in web.xml is important. See corresponding FAQ chapter [http://
www.jboss.org/community/docs/DOC-13537].
Name Value
component-type org.richfaces.component.FileUpload
component-class org.richfaces.component.html.HtmlFileUpload
component-family org.richfaces.component.FileUpload
390
Chapter 6. The RichFaces Components
Name Value
renderer-type org.richfaces.renderkit.html.FileUploadRenderer
tag-class org.richfaces.taglib.FileUploadTag
Function Description
beforeSubmit() Sets up necessary request parameters for
file uploading and submits form to server by
command button. This method should be used
together with commands.
clear() Removes all files from the list. The function can
also get the $('id').component.entries[i]
as a parameter to remove a particular file.
disable() Disables the component
enable() Enables the component
remove() Cancels the request for uploading
a file by removing this file from
upload list and upload queue. Gets
$('id').component.entries[i] as a
parameter.
stop() Stops the uploading process
submitForm() Submits form to server. All added files will be
put to model and event.
Property Description
entries Returns a array of all files in the list
entries.length Returns the number of files in the list
entries[i].fileName Returns the file name, that is retrieved by the
array index
entries[i].state Returns the file state. Possible states are
391
Chapter 6. The RichFaces Components
Property Description
• "ready" - uploading is in process,
corresponds to FileUploadEntry.READY
constant The file will be uploaded on queue
order.
Property Description
entry.state Returns the file state. Possible states are
392
Chapter 6. The RichFaces Components
Property Description
• "progress" - the file is
being uploaded, corresponds to
FileUploadEntry.UPLOAD_IN_PROGRESS
constant
393
Chapter 6. The RichFaces Components
394
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
<rich:fileUpload> with MyFaces [] article describes how to avoid problems with <rich:fileUpload>
compenent caused by wrong application configuration.
395
Chapter 6. The RichFaces Components
6.11.6.1. Description
The <rich:inplaceInput> is an input component used for displaying and editing data inputted.
• Edit mode activation when the component gets focus with the "Tab"
• Controls customization
The <rich:inplaceInput> component was designed to facilitate displaying and inputting (editing)
some data.
The "value" attribute is a value-binding expression for the current value of the component.
• View state displays the default label with the value taken from the "value" or "defaultLabel"
attributes.
396
Chapter 6. The RichFaces Components
If the initial value of the "value" attribute is "null" or empty string the "defaultLabel" attribute
is used to define default label.
Example:
...
<rich:inplaceInput value="#{bean.value}" defaultLabel="click to edit"/>
...
In the example above the "value" attribute is not initialized therefore the "click to edit" text,
that "defaultLabel" contains, is displayed.
The "editEvent" attribute provides an option to assign a JavaScript action to initiate the change
of the state from view/changed to edit. The default value is "onclick".
Example:
...
<rich:inplaceInput value="#{bean.value}" editEvent="ondblclick"/>
...
397
Chapter 6. The RichFaces Components
Example:
...
<rich:inplaceInput value="#{bean.value}" oneditactivation="if (!confirm('Are you sure you want
to change the value?')){return false;}" />
...
The given code illustrates how "oneditactivation" attribute works, namely when the state is being
changed from view to edit, a confirmation window with a message "Are you sure you want
to change value?" comes up.
Using the boolean "selectOnEdit" attribute set to true, the text in the input field will be selected
when the change from view/changed state to edit occurs.
If the <rich:inplaceInput> loses focus, input data is saved automatically and the component
displays a new value. Additionally, the data is saved when "Enter" is pressed. Nevertheless, you
can use the "showControls" attribute, which makes "Save" and "Cancel" buttons appear next
to the input field. If the controls are used, data is not saved automatically when the form loses
focus: user has to confirm that he/she wants to save/discard the data explicitly. In both cases (with
controls or without them) the input data can be discarded by pressing "Esc" key.
Example:
...
<rich:inplaceInput value="#{bean.value}" showControls="true"/>
...
398
Chapter 6. The RichFaces Components
You can also position the controls relatively to the input field, by means of
• the "controlsVerticalPosition " attribute with "bottom", "center" and "top" definitions
Example:
...
<rich:inplaceInput
value="#{bean.value}"
showControls="true"
controlsVerticalPosition="bottom"
controlsHorizontalPosition="left"/
>
...
It is also possible to use "controls" facet in order to replace the default controls with facets content.
See the example below.
Example:
...
<rich:inplaceInput defaultLabel="Click here to
edit" showControls="true" controlsHorizontalPosition="left" controlsVerticalPosition="bottom" id="inplaceInpu
<f:facet name="controls">
<h:commandButtonvalue="Save"onclick="#{rich:component('inplaceInput')}.save();"type="button"/
>
<h:commandButton
value="Cancel"
onclick="#{rich:component('inplaceInput')}.cancel();"
type="button"
/
>
399
Chapter 6. The RichFaces Components
</f:facet>
</rich:inplaceInput>
...
Note:
The "controls" facet also implies using "showControls" attribute and it has to be
defined as "true".
Redefinition of the "save" and "cancel" icons can be performed using "saveControlIcon" and
"cancelControlIcon" attributes. You need to define the path to where your images are located.
Example:
...
<rich:inplaceInput value="#{bean.value}" defaultLabel='click to edit'
showControls="true"
controlsHorizontalPosition="left"
controlsVerticalPosition="top"
saveControlIcon="/images/cancel.gif"
cancelControlIcon="/images/save.gif"/>
...
The <rich:inplaceInput> component supports the standard "tabindex" attribute. When the
component gets focus the edit mode is activated.
400
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.inplaceInput
component-class org.richfaces.component.html.HtmlInplaceInput
component-family org.richfaces.inplaceInput
renderer-type org.richfaces.renderkit.inplaceInputRenderer
tag-class org.richfaces.taglib.inplaceInputTag
Function Description
edit() Changes the state to edit
cancel() Changes its state to the previous one before
editing (changed or view)
save() Changes its state to changed with a new value
getValue() Gets the current value
setValue(newValue) Sets the current value (to be implemented)
401
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
402
Chapter 6. The RichFaces Components
6.11.7.1. Description
The <rich:inplaceSelect> is used for the creation of select based inputs: it shows the value as
a text in one state and enables editing the value, providing a list of options in another state
• Edit mode activation when the component got focus with the "Tab"
• View state displays default label with the value taken from "value" or "defaultLabel" attributes.
403
Chapter 6. The RichFaces Components
If the initial value of the "value" attribute is "null" or empty string, the "defaultLabel" attribute
is used to define a default label.
Example:
...
<rich:inplaceSelect value="#{bean.value}" defaultLabel="click to edit">
<f:selectItems value="#{bean.selectItems}" />
</rich:inplaceSelect>
...
In the example above the "value" attribute is not initialized, therefore the "click to edit"
text, that "defaultLabel" contains, is displayed.
404
Chapter 6. The RichFaces Components
You can form the list of the options using <f:selectItem/> and <f:selectItems/> JSF
components.
Example:
...
<rich:inplaceSelect value="#{bean.inputValue}" defaultLabel="click to edit">
<f:selectItems value="#{bean.selectItems}"/>
<f:selectItem itemValue="1" itemLabel="factory"/>
<f:selectItem itemValue="2" itemLabel="newspaper"/>
</rich:inplaceSelect>
...
In the example above the value of the selected item is available via "value" attribute.
The "editEvent" attribute provides an option to assign a JavaScript action that initiates the change
of the state from view to edit. The default value is "onclick".
Example:
...
<rich:inplaceSelect value="#{bean.inputValue}" defaultLabel="Double Click to
edit" editEvent="ondblclick">
<f:selectItems value="#{demo.selectItems}" />
</rich:inplaceSelect>
...
Example:
...
<rich:inplaceSelect value="#{bean.inputValue}" oneditactivation="if (!confirm('Are you sure you
want to change the value?')){return false;}">
405
Chapter 6. The RichFaces Components
The given code illustrates how "oneditactivation" attribute works, namely when the state is being
changed from view to edit, a confirmation window with a message "Are you sure you want
to change value?" comes up.
To prevent opening the drop-down list by default, once edit state is activated, set the "openOnEdit"
attribute to "false". The default value is "true".
Example:
...
<rich:inplaceSelect value="#{bean.inputValue}" showControls="true" openOnEdit="false">
<f:selectItems value="#{bean.selectItems}"/>
</rich:inplaceSelect>
...
Nowever, if you want to confirm the data saving explicitly you can use the "showControls"
attribute, which makes "Save" and "Cancel" buttons (displayed as icons) appear next to the input
field. Edit state can be deactivated by pressing "Esc" key. An option in the drop-drown list can be
also selected by pressing "Enter".
Example:
...
<rich:inplaceSelect value="#{bean.inputValue}" showControls="true">
<f:selectItems value="#{bean.selectItems}"/>
</rich:inplaceSelect>
...
406
Chapter 6. The RichFaces Components
You can also position the controls relatively to the input field, by means of
Example:
...
<rich:inplaceSelect value="#{bean.inputValue}" controlsHorizontalPosition="left" controlsVerticalPosition="cen
<f:selectItems value="#{bean.selectItems}"/>
</rich:inplaceSelect>
...
It is also possible to use "controls" facet in order to replace the default controls with facets content.
See the example below.
Example:
...
<rich:inplaceSelect value="#{bean.inputValue}" showControls="true">
<f:facet name="controls">
<button onclick="#{rich:component('inplaceSelect')}.save();" type="button">Save</button>
<button onclick="#{rich:component('inplaceSelect')}.cancel();" type="button">Cancel</
button>
407
Chapter 6. The RichFaces Components
</f:facet>
<f:selectItems value="#{bean.selectItems}"/>
</rich:inplaceSelect>
...
Note:
The "controls" facet also implies using "showControls" attribute and it has to be
defined as "true".
The <rich:inplaceSelect> component supports the standard "tabindex" attribute. When the
component gets focus the edit mode is activated and drop-down list is opened.
In order to specify the height and width parameters for the list items of the component, you can
use "listHeight" and " listWidth" attributes.
Name Value
component-type org.richfaces.InplaceSelect
component-class org.richfaces.component.html.HtmlInplaceSelect
component-family org.richfaces.InplaceSelect
renderer-type org.richfaces.renderkit.InplaceSelectRenderer
tag-class org.richfaces.taglib.InplaceSelectTag
408
Chapter 6. The RichFaces Components
Function Description
edit() Changes the state to edit
cancel() Changes its state to the previous one before
editing (changed or view)
save() Changes its state to changed with a new value
getValue() Gets the current value
setValue(newValue) Sets the current value and name
409
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.11.8.1. Description
The <rich:inputNumberSlider> component is a slider component. A handler's position
corresponds to a definite value on the slider track. In order to change the value you can slide a
handler or set the necessary value into the input field. You can dispose it horizontally or vertically
on the page.
410
Chapter 6. The RichFaces Components
• Possibility to display 2 controls that increase/decrease the value by the defined step width, when
they will be clicked.
• Attribute "orientation" that can have the values "vertical" and "horizontal" to define in which
direction the slider should be movable.
Here is the simplest variant of a slider definition with "minValue" , "maxValue" and "step" (by
default is "1") attributes, which define the beginning and the end of a numerical area and a slider
property step.
Example:
<rich:inputNumberSlider></rich:inputNumberSlider>
Using "showInput" (default value is "true") and "enableManualInput" (default value is "true")
attributes, it's possible to output the input area near the slider, and make it read-only or editable.
Example:
411
Chapter 6. The RichFaces Components
It's also possible to switch off displaying of "boundary values" and a toolTip showing on a
handle drawing. This could be performed with the help of the component defined attributes:
"showBoundaryValues" which is responsible for "boundary values" displaying (default value is
"true") and "showToolTip" which is responsible for tooltTip displaying (default value is "true").
Moreover, to add e.g. some JavaScript effects, events defined on it are used.
• "onchange"
• "onmouseover"
• "onclick"
• "onfocus"
• "onmouseout"
• etc.
The "label" attribute is a generic attribute. The "label" attribute provides an association
between the component and the message that the component (indirectly) produced. This attribute
defines the parameters of a localized error and informational messages that occur as a result of
conversion, validation, or other application actions during the request processing lifecycle. With the
help of this attribute you can replace the last parameter substitution token shown in the messages.
For example, {1} for "DoubleRangeValidator.MAXIMUM" , {2} for "ShortConverter.SHORT".
The "showArrows" boolean attribute when set to "true" enables additional controls for increasing
and decreasing slider value. The controls (arrows by default) are placed in the beginning and in
the end of a slider track:
Clicking an arrow changes the driven value on the amount defined with "step" attribute. Keepeng
an arrow control pressed changes the value continuous. Time that value takes to change from
one step to another is definded with "delay" attribute.
412
Chapter 6. The RichFaces Components
413
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.11.9.1. Description
A single line input field that lets selecting a number using controls near a text field. It's possible
to change a value using "Up/Down" keyboard keys. The keyboard input in a field is possible if it
isn't locked by the "enableManualInput" attribute. When arrow controls are pressed, the cursor
can be moved in any way without losing a dragged state.
414
Chapter 6. The RichFaces Components
Here is the simplest variant of spinner definition with "minValue" , "maxValue" and "step" (on
default is "1") attributes, which define the beginning and the end of numerical area and a spinner
step.
Example:
...
<rich:inputNumberSpinner minValue="1" maxValue="100"/>
...
It generates on a page:
• "cycled" if the attribute is "true" after the current value reaches the border value it's be reversed
to another border value after next increasing/decreasing. In other case possibilities of next
increasing/decreasing are locked
415
Chapter 6. The RichFaces Components
Moreover, to add e.g. some JavaScript effects, events defined on it are used
• "onchange"
• "onmouseover"
• "onclick"
• "onfocus"
• "onmouseout"
• etc.
The "label" attribute is a generic attribute. The "label" attribute provides an association between
a component, and the message that the component (indirectly) produced. This attribute defines
the parameters of localized error and informational messages that occur as a result of conversion,
validation, or other application actions during the request processing lifecycle. With the help of
this attribute you can replace the last parameter substitution token shown in the messages. For
example, {1} for "DoubleRangeValidator.MAXIMUM" , {2} for "ShortConverter.SHORT" .
416
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.11.10.1. Description
The component adds on-keypress suggestions capabilities to any input text component like
<h:inputText> .
417
Chapter 6. The RichFaces Components
• "for" contains an ID of an input component for which the suggestion support is provided
• "var" defines a collection name that provides an access for the current row while iterating
through
...
<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>
...
...
public class SBbean {
418
Chapter 6. The RichFaces Components
public SBbean() {
URL rulesUrl = getClass().getResource("capitals-rules.xml");
Digester digester = DigesterLoader.createDigester(rulesUrl);
digester.push(this);
try {
digester.parse(getClass().getResourceAsStream("capitals.xml"));
} catch (IOException e) {
throw new FacesException(e);
} catch (SAXException e) {
throw new FacesException(e);
}
capitalsNames.clear();
for (Capital cap : capitals) {
capitalsNames.add(cap.getName());
}
capitalsOptions.clear();
for (Capital cap : capitals) {
capitalsOptions.add(new SelectItem(cap.getName(), cap.getState()));
}
}
419
Chapter 6. The RichFaces Components
In the example above when suggestion item (city) is selected it is set as a value of <h:inputText
id="city"/> .
Here is a result:
The <rich:suggestionbox> component could get any collection and outputs it in a popup in
several columns. The "fetchValue" attribute points to the data that is inserted into the input field
if a particular row is selected or clicked from the suggested list. Therefore when some string is
chosen input receives the proper value.
...
<h:inputText id="city" value="#{capitalsBean.capital}" />
<rich:suggestionbox for="city" var="result"
fetchValue="#{result.state}"
suggestionAction="#{capitalsBean.autocomplete}">
<h:column>
<h:outputText value="#{result.name}" />
</h:column>
<h:column>
<h:outputText value="#{result.state}" />
</h:column>
</rich:suggestionbox>
...
In the example above if you choose any string input will receive the corresponding value from the
second column containing #{result.state} .
420
Chapter 6. The RichFaces Components
Here is a result:
There is also one more important attribute named "tokens" that specifies separators after which
a set of some characters sequence is defined as a new prefix beginning from this separator and
not from the string beginning.
Example:
...
<h:inputText id="city" value="#{capitalsBean.capital}" />
<rich:suggestionbox for="city" var="result"
suggestionAction="#{capitalsBean.autocomplete}"
tokens=",">
<h:column>
<h:outputText value="#{result.name}" />
</h:column>
</rich:suggestionbox>
...
This example shows that when a city is chosen and a comma and first letter character are input,
Ajax request is called again, but it submits a value starting from the last token:
421
Chapter 6. The RichFaces Components
For a multiple definition use either " ,.;[] " syntax as a value for "tokens" attribute or link a
parameter to some bean property that transmits separators collection.
...
<h:inputText id="city" value="#{capitalsBean.capital}" />
<rich:suggestionbox for="city" var="result"
suggestionAction="#{capitalsBean.autocomplete}"
onobjectchange="processObjects(suggestion)"
usingSuggestObjects="true">
<h:column>
<h:outputText value="#{result.name}" />
</h:column>
</rich:suggestionbox>
<h:panelGroup>
<div id="state"></div>
</h:panelGroup>
...
When the item is selected you can get it as an object on the client side and use
getSelectedItems() method to access any object properties:
<script
422
Chapter 6. The RichFaces Components
type="text/javascript">
function processObjects(suggestionBox) {
var items = suggestionBox.getSelectedItems();
var state;
if (items && items.length > 0) {
for ( var i = 0; i < items.length; i++) {
state = items[i].state;
}
document.getElementById('state').innerHTML = "State: "+state;
}else{
document.getElementById('state').innerHTML = '';
}
}
</script>
Here is a result:
In addition to attributes common for Ajax action components and limiting requests quantity and
frequency, the <rich:suggestionbox> has one more its own attribute limiting requests: the
"minChars" attribute. This attribute defines characters quantity inputted into a field after which
Ajax requests are called to perform suggestion.
There is possibility to define what is shown if the autocomplete returns empty list. Attribute
"nothingLabel" or facet with the same name could be used for this purpose.
Example:
...
<rich:suggestionbox for="city" var="result"
suggestionAction="#{capitalsBean.autocomplete}"
nothingLabel="No cities found">
<h:column>
<h:outputText value="#{result.name}" />
</h:column>
</rich:suggestionbox>
...
423
Chapter 6. The RichFaces Components
Here is a result:
You can also use facets for the further <rich:suggestionbox> customization:
...
<h:inputText id="city" value="#{capitalsBean.capital}" />
<rich:suggestionbox for="city" var="result"
suggestionAction="#{capitalsBean.autocomplete}">
<f:facet name="nothingLabel">
<h:outputText value="No cities found" />
</f:facet>
<f:facet name="header">
<h:outputText value="Select your city" />
</f:facet>
<h:column>
<h:outputText value="#{result.name}" />
</h:column>
</rich:suggestionbox>
...
Here is a result:
424
Chapter 6. The RichFaces Components
Information about the "process" attribute usage you can findin the "Decide what to process"
guide section.
Name Value
component-type org.richfaces.SuggestionBox
component-class org.richfaces.component.html.HtmlSuggestionBox
component-family org.richfaces.SuggestionBox
renderer-type org.richfaces.SuggestionBoxRenderer
tag-class org.richfaces.taglib.SuggestionBoxTag
425
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
426
Chapter 6. The RichFaces Components
RichFaces cookbook at JBoss Portal includes some articles that cover different aspects of working
with <rich:suggestionbox> :
6.12.1.1. Description
The <rich:listShuttle> component is used for moving chosen items from one list into another
with their optional reordering there.
• Keyboard support
427
Chapter 6. The RichFaces Components
• two item lists (source and target). List consists of items. Each item has three different
representations: common, selected, active
• move controls set is a set of controls, which performs moving items between lists
Note:
Now the listener can not be called from the column facet. This is a temporary
limitation. The additional information can be found in RichFaces Jira [http://
jira.jboss.org/jira/browse/RF-5327].
The "sourceValue" attribute defines a List or Array of items to be shown in the source list.
The "targetValue" attribute defines a List or Array of items to be shown in the target list.
The "var" attribute could be shared between both Lists or Arrays to define lists on the page.
The "sourceRequired" and "targetRequired" attributes define the case when source and target
values are being validated. If the value of both attributes is "true" there should be at least one item
in source and target lists. Otherwise validation fails.
Example:
...
<h:form id="myForm">
<rich:messages>
<f:facet name="errorMarker">
<h:graphicImage value="/images/ajax/error.gif" />
</f:facet>
</rich:messages>
428
Chapter 6. The RichFaces Components
</h:form>
...
In the example above the source list is empty. If you submit the form validation fails and error
message appears on a page.
The "converter" attribute is used to convert component data to a particular component's value.
For example, when you select items in a list, a converter is used to format a set of objects to a
strings to be displayed.
Note
The "sourceSelection" attribute stores the collection of items selected by you in the source list.
The "targetSelection" attribute stores the collection of items selected by you in the target list.
Captions could be added to a list only after it was defined as a "sourceCaption" and
"targetCaption" named facets inside the component or defined with the "sourceCaptionLabel"
and "targetCaptionLabel" attribute.
...
<rich:listShuttle var="item" sourceValue="#{bean.source}" targetValue="#{bean.target}" sourceSelection="#{bean
targetSelection="#{bean.targetSelection}" converter="listShuttleconverter">
<f:facet name="sourceCaption">
<h:outputText value="Cars Store #1" />
</f:facet>
429
Chapter 6. The RichFaces Components
<f:facet name="targetCaption">
<h:outputText value="Cars Store #2" />
</f:facet>
<rich:column>
<h:outputText value="#{items.name}" />
</rich:column>
</rich:listShuttle>
...
The <rich:listShuttle> component provides the possibility to use ordering controls set, which
performs reordering in the target item list. Every control has possibility to be disabled.
Example:
...
<rich:listShuttle var="item" sourceValue="#{bean.source}" targetValue="#{bean.target}" converter="listShuttlecon
...
<f:facet name="topControl">
<h:outputText value="Move to top" />
</f:facet>
<f:facet name="upControl">
<h:outputText value="Move up" />
</f:facet>
<f:facet name="downControl">
<h:outputText value="Move down" />
</f:facet>
<f:facet name="bottomControl">
<h:outputText value="Move to bottom" />
</f:facet>
</rich:listShuttle>
...
The <rich:listShuttle> component also provides 4 predefined controls in move controls set for
moving items between source and target lists. Every control has possibility to be disabled.
430
Chapter 6. The RichFaces Components
...
<rich:listShuttle var="item" sourceValue="#{bean.source}" targetValue="#{bean.target}" converter="listShuttlecon
copyControlLabel="Copy" removeControlLabel="Remove"
copyAllControlLabel="Copy all" removeAllControlLabel="Remove all">
<h:column>
<f:facet name="header">
<h:outputText value="Cars" />
</f:facet>
<h:outputText value="#{item.name}" />
</h:column>
</rich:listShuttle>
...
Controls rendering is based on the "controlsType" attribute. Possible types are button and none.
Note
You could also pack org.richfaces.renderkit.listShuttle resource bundle with your JARs
defining the same properties.
431
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.ListShuttle
component-class org.richfaces.component.html.HtmlListShuttle
component-family org.richfaces.ListShuttle
renderer-type org.richfaces.ListShuttleRenderer
tag-class org.richfaces.taglib.ListShuttleTag
Function Description
enable() Enables ordering control (to be implemented)
disable() Disables ordering control (to be implemented)
isEnabled() Checks if current control is enabled (to be
implemented)
up() Moves up selected item in the list
down() Moves down selected item in the list
top() Moves top selected item in the list
bottom() Moves bottom selected item in the list
copy() Copies selected item from the source list to the
target list
432
Chapter 6. The RichFaces Components
Function Description
remove() Removes selected item from the target list to
the source list
copyAll() Copies all items from the source list to the
target list
removeAll() Removes all items from the target list to the
source list
getSelection() Returns currently selected item (to be
implemented)
getItems() Returns the collection of all items (to be
implemented)
Facet Description
copyAllControl Redefines the label content for the
"copyAll" control. Related attribute is
"copyAllControlLabel"
removeAllControl Redefines the label content for the
"removeAll" control. Related attribute is
"removeAllControlLabel"
copyControl Redefines the label content for the "copy"
control. Related attribute is "copyControlLabel"
removeControl Redefines the label content for the
"remove" control. Related attribute is
"removeControlLabel"
copyAllControlDisabled Redefines the disabled label content for the
"copyAll" control
removeAllControlDisabled Redefines the disabled label content for the
"removeAll" control
caption Redefines the caption control
sourceCaption Defines source list caption representation text.
Related attribute is "sourceCaptionLabel"
targetCaption Defines source list target representation text.
Related attribute is "targetCaptionLabel"
433
Chapter 6. The RichFaces Components
434
Chapter 6. The RichFaces Components
Table 6.216. Classes names that define a cells representations in a target list
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
435
Chapter 6. The RichFaces Components
6.12.2.1. Description
The <rich:orderingList> is a component for ordering items in a list. This component provides
possibilities to reorder a list and sort it on the client side.
• Keyboard support
• Item list element that displays a list of items. It has three different representations for a single
element: common, selected, active. Combination of these states is possible.
The "value" and "var" attributes are used to access the values of a list.
Controls rendering is based on the "controlsType" attribute. Possible types are button or none.
Note
Currently the button controls type is based on <div> element.
436
Chapter 6. The RichFaces Components
The "selection" attribute stores the collection of items selected by you. In the example below
after submitting the form the current collection is placed in the object's property and then
<rich:dataTable> with selected items is shown.
Example:
...
<h:form>
The <rich:orderingList> component allows to use "caption" facet. A caption could be also
defined with "captionLabel" attribute.
Example:
...
<rich:orderingList value="#{bean.simpleItems}" var="item" controlsType="button" selection="#{bean.selection}">
<f:facet name="caption">
<h:outputText value="Caption Facet" />
</f:facet>
<rich:column>
<f:facet name="header">
<h:outputText value="Cars" />
</f:facet>
437
Chapter 6. The RichFaces Components
The <rich:orderingList> component provides the possibility to use ordering controls set, which
performs reordering. Every control has possibility to be disabled.
Example:
...
<rich:orderingList value="#{bean.simpleItems}" var="item" controlsType="button" selection="#{bean.selection}">
<f:facet name="topControl">
<h:outputText value="Move to top" />
</f:facet>
<f:facet name="upControl">
<h:outputText value="Move up" />
</f:facet>
<f:facet name="downControl">
<h:outputText value="Move down" />
</f:facet>
<f:facet name="bottomControl">
<h:outputText value="Move to bottom" />
</f:facet>
<rich:orderingList>
...
438
Chapter 6. The RichFaces Components
The <rich:orderingList> component has a possibility to hide any of the controls by pairs using
following attributes:
• "orderControlsVisible" attribute has two values: "true" or "false". If false Up and Down controls
are not displayed.
• "fastOrderControlsVisible" attribute has two values: "true" or "false". If false Top and Bottom
controls are not displayed.
You could also pack org.richfaces.renderkit.orderingList resource bundle with your JARs
defining the same properties.
439
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.OrderingList
component-class org.richfaces.component.html.HtmlOrderingList
component-family org.richfaces.OrderingList
renderer-type org.richfaces.OrderingListRenderer
Function Description
hide() Hides ordering control (to be implemented)
show() Shows ordering control (to be implemented)
isShown() Checks if current control is shown (to be
implemented)
enable() Enables ordering control (to be implemented)
disable() Disables ordering control (to be implemented)
isEnabled() Checks if current control is enabled (to be
implemented)
Up() Moves up selected item in the list
Down() Moves down selected item in the list
Top() Moves top selected item in the list
Bottom() Moves bottom selected item in the list
getSelection() Returns currently selected item
getItems() Returns the collection of all items
Facet Description
caption Redefines the caption content. Related
attribute is "captionLabel"
440
Chapter 6. The RichFaces Components
Facet Description
topControl Redefines the label for the "Top" control.
Related attribute is "topControlLabel"
bottomControl Redefines the label for the "Bottom" control.
Related attribute is "bottomControlLabel"
upControl Redefines the label for the "Up" control.
Related attribute is "upControlLabel"
downControl Redefines the label for the "Down" control.
Related attribute is "downControlLabel"
topControlDisabled Redefines the disabled label for the "Top"
control
bottomControlDisabled Redefines the disabled label for the "Bottom"
control
upControlDisabled Redefines the disabled label for the "Up"
control
downControlDisabled Redefines the disabled label for the "Down"
control
441
Chapter 6. The RichFaces Components
442
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.12.3.1. Description
The <rich:pickList> component is used for moving selected item(s) from one list into another.
• Keyboard support
• 2 item lists. Every item has three different representations: common, selected, active.
Combination of these states is possible.
• Move controls set is a set of controls, which performs moving items between lists.
443
Chapter 6. The RichFaces Components
The <f:selectItem /> or <f:selectItems /> facets are used to define the values of a source list.
Example:
...
<rich:pickList value="#{pickBean.listValues}">
<f:selectItem itemValue="Bentley" itemLabel="Bentley"/>
<f:selectItem itemValue="Audi" itemLabel="Audi"/>
<f:selectItems value="#{pickBean.sourceList}"/>
</rich:pickList>
...
The "switchByClick" attribute provides an option to copy and remove items between lists by one
click. Default value of this attribute is "false", so you need a double click to copy, remove items
from one list to another.
Example:
...
<rich:pickList copyAllControlLabel = "#{pickBean.copyAllLabel}" copyControlLabel = "#{pickBean.copyLabel}"
removeControlLabel = "#{pickBean.removeLabel}" removeAllControlLabel ="#{pickBean.removeAllL
<f:selectItem itemValue="Bentley" itemLabel="Bentley"/>
<f:selectItem itemValue="Audi" itemLabel="Audi"/>
<f:selectItems value="#{pickBean.sourceList}"/>
</rich:pickList>
...
If you don't want to display labels on the buttons you need to set "showButtonsLabel" to "false".
Alternative to the given attributes are the following facets: "copyAllControl" , "removeAllControl"
, "copyControl" , "removeControl" , "copyAllControlDisabled" , "removeAllControlDisabled" ,
"copyControlDisabled" , "removeControlDisabled" , "caption" .
444
Chapter 6. The RichFaces Components
...
<rich:pickList value="#{pickBean.listValues}">
<f:facet name="copyAllControl">
<h:commandButton value="#{pickBean.copyAllLabel}" />
</f:facet>
<f:facet name="copyControl">
<h:commandButton value="#{pickBean.copyLabel}" />
</f:facet>
<f:facet name="removeControl">
<h:commandButton value="#{pickBean.removeLabel}" />
</f:facet>
<f:facet name="removeAllControl">
<h:commandButton value="#{pickBean.removeAllLabel}" />
</f:facet>
<f:selectItem itemValue="Bentley" itemLabel="Bentley"/>
<f:selectItem itemValue="Audi" itemLabel="Audi"/>
<f:selectItems value="#{pickBean.sourceList}"/>
</rich:pickList>
...
With the help of "moveControlsVerticalAlign" attribute you can align move controls vertically.
The possible value for "moveControlsVerticalAlign" are "top", "bottom" and "center" (default
value).
The <rich:pickList> component provides resizing of lists by using such attributes as:
Example:
...
<rich:pickList listsHeight="#{pickBean.listsHeight}" sourceListWidth="#{pickBean.sourceListWidth}" targetListWid
<f:selectItem itemValue="Bentley" itemLabel="Bentley"/>
<f:selectItem itemValue="Audi" itemLabel="Audi"/>
<f:selectItems value="#{pickBean.sourceList}"/>
</rich:pickList>
445
Chapter 6. The RichFaces Components
...
Name Value
component-type org.richfaces.PickList
component-class org.richfaces.component.html.HtmlPickList
component-family org.richfaces.PickList
renderer-type org.richfaces.PickListRenderer
tag-class org.richfaces.taglib.PickListTag
Facet Description
copyAllControl Redefines the "copyAll" label with the control
set. Related attribute is "copyAllControlLabel"
removeAllControl Redefines the "removeAll" label with
the control set. Related attribute is
"removeAllControlLabel"
copyControl Redefines the "copy" label with the control set.
Related attribute is "copyControlLabel"
446
Chapter 6. The RichFaces Components
Facet Description
removeControl Redefines the "remove" label with the control
set. Related attribute is "removeControlLabel"
copyAllControlDisabled Redefines the disabled "copyAll" label with the
control set.
removeAllControlDisabled Redefines the disabled "removeAll" label with
the control set.
copyControlDisabled Redefines the disabled "copy" label with the
control set.
removeControlDisabled Redefines the disabled "remove" label with the
control set.
caption Defines the "caption" label with the control set.
Table 6.234. Classes names that define a source and target items
representation
447
Chapter 6. The RichFaces Components
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
448
Chapter 6. The RichFaces Components
6.13.1.1. Description
The <rich:page> component is used to create basic (X)HTML markup and define document
parameters like DOCTYPE, title etc. The component also allows to build top level layout: header,
bottom, center and left or right layout areas.
The <rich:page> component together with the <rich:layout> component provides a full-fledged
mechanism for markup creation.
First of all, to declare the document type of the page you should use the "markupType" attribute
which has the following values:
• "html"
• "html-transitional"
• "xhtml"
• "xhtml-transitional"
• "html-frameset"
449
Chapter 6. The RichFaces Components
• "html-3.2"
The "contentType" allows to specify the type of the content and encoding for the page.
The title of the page can be set with the "pageTitle" attribute. To place some other page
parameters (like meta information, links to CSS style sheets etc.) in the <head> element of an
HTML page use "pageHeader" facet.
Example:
...
<rich:page pageTitle="The title of the page" markupType="xhtml">
<f:facet name="pageHeader">
<meta content="The rich:page component" name="keywords" />
<link rel="shortcut icon" href="/images/favicon.ico" />
<link href="/css/style.css" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="/js/menu.js"></script>
</f:facet>
<!-- page content -->
</rich:page>
...
Note:
Note, the <rich:page> component encodes the full page structure. Therefore,
be sure you don't use the doctype declaration, root html element, head and body
elements on the same page where you've put this component.
The implementation of the <rich:page> component provides four facets that you can use to
arrange the layout of the page: "header", "subheader", "sidebar" and "footer". Their behavior is
quite self-explanatory.
The position of the panel rendered by the "sidebar" facet can be set with the "sidebarPosition"
attribute that can take either "right" or "left" as values, you can also specify the width for this facet
with the "sidebarWidth" attribute.
Example:
...
<rich:page sidebarPosition="left" sidebarWidth="300">
<f:facet name="header">
<!-- header content -->
450
Chapter 6. The RichFaces Components
</f:facet>
<f:facet name="sidebar">
<!-- side panel content -->
</f:facet>
<!-- body content -->
<f:facet name="footer">
<!-- footer content -->
</f:facet>
</rich:page>
...
The <rich:page> component also provides attributes to define CSS classes for each nested
facet as well as a body part of the page created with the component.
Several templates are available for the <rich:page> component. A template can be activated
with the "theme" attribute.
The theme defines the way the <rich:page> is rendered. Default renderer (default theme) of the
<rich:page> has no mappings to skin parameters and just provides CSS classes for the page
part. However, the simple theme, which is an extension of the default theme, has mappings to
skin parameters and adds the RichFaces skinning for the page elements.
Name Value
component-type org.richfaces.Page
component-class org.richfaces.component.html.HtmlPage
component-family org.richfaces.Page
renderer-type org.richfaces.PageRenderer
tag-class org.richfaces.taglib.PageTag
451
Chapter 6. The RichFaces Components
6.13.2.1. Description
The <rich:layout> component is designed to build layouts basing on Yahoo UI Grids CSS
• Cross-borwser compatibility
452
Chapter 6. The RichFaces Components
The <rich:layout> allows to build a grid that can be used to make the layout on a page. The
<rich:layout> is used in conjunction with the <rich:layoutPanel> that is used as a child element
and carries the main burden of building the grid.
Hence, you need to use the <rich:layout> as a container and <rich:layoutPanel> to create
areas inside the container.
This is how you can make a layout with 5 areas:
Example:
...
<rich:layout>
<rich:layoutPanel position="top">
<!--top-->
</rich:layoutPanel>
<rich:layoutPanel position="left">
<!--left-->
</rich:layoutPanel>
<rich:layoutPanel position="center">
<!--center-->
</rich:layoutPanel>
<rich:layoutPanel position="right">
<!--right-->
</rich:layoutPanel>
<rich:layoutPanel position="bottom">
<!--bottom-->
</rich:layoutPanel>
</rich:layout>
...
To get more details about <rich:layoutPanel> please read the chapter about layoutPanel in
the guide.
Name Value
component-type org.richfaces.Layout
component-class org.richfaces.component.html.HtmlLayout
453
Chapter 6. The RichFaces Components
Name Value
component-family org.richfaces.Layout
renderer-type org.richfaces.LayoutRenderer
tag-class org.richfaces.taglib.layoutTag
6.13.3.1. Description
The <rich:layouPanel> is an auxiliary component used to create layout areas within the
<rich:layout> container.
• Cross-browser compatibility
The <rich:layoutPanel> component is used to split the area inside the <rich:layout> into up
to 5 parts: top, left, center, right, bottom.
The "position" attribute defines the position of the <rich:layoutPanel> in the area created with
<rich:layout> .
...
<rich:layout>
<rich:layoutPanel position="top">
<!--top-->
</rich:layoutPanel>
<rich:layoutPanel position="left">
<!--left-->
</rich:layoutPanel>
<rich:layoutPanel position="center">
<!--center-->
454
Chapter 6. The RichFaces Components
</rich:layoutPanel>
<rich:layoutPanel position="right">
<!--right-->
</rich:layoutPanel>
<rich:layoutPanel position="bottom">
<!--bottom-->
</rich:layoutPanel>
</rich:layout>
...
You can specify the width of the layout area with the "width" attribute.
Name Value
component-type org.richfaces.LayoutPanel
component-class org.richfaces.component.html.HtmlLayoutPanel
component-family org.richfaces.LayoutPanel
renderer-type org.richfaces.LayoutPanelRenderer
tag-class org.richfaces.taglib.LayoutPanelTag
6.14.1.1. Description
455
Chapter 6. The RichFaces Components
...
<rich:componentControl
attachTo="doExpandCalendarID"
event="onclick"
operation="Expand"
for="ccCalendarID"
/
>
...
In other words it means "clicking on the component with ID doExpandCalendarID expands the
component with ID ccCalendarID". It can be said, that <rich:componentControl> makes
interact two components with the help of JavaScript API function.
The ID of the component the event that invokes JavaScript API function is applied, is defined
with "attachTo" attribute (see the exapmle above). If "attachTo" attribute is not specified, the
<rich:componentControl> is supposed to be attached to it's parent.
Example:
456
Chapter 6. The RichFaces Components
...
<rich:componentControl
name="func"
event="onRowClick"
for="menu"
operation="show"
params="#{car.model}"/
>
...
The alternative way for parameters transferring uses <f:param> attribute. As the code above,
the following code will represent the same functionality:
...
<rich:componentControl event="onRowClick" for="menu" operation="show">
<f:param value="#{car.model}" name="model"/>
</rich:componentControl>
...
With the help of the "attachTiming" attribute you can define the page loading phase when
<rich:componentControl> is attached to source component. Possible values are:
In order to use <rich:componentControl> with another component you should place the id of
this component into "for" attribute field. All operations with defined component you can find in
the JavaScript API section of defined component.
<h:form>
<rich:toolTip id="toolTip" mode="ajax" value="and then just touch me." direction="top-right" />
</h:form>
<h:commandButton id="ButtonID" value="Push me">
457
Chapter 6. The RichFaces Components
<rich:componentControlattachTo="ButtonID"event="onmouseover"operation="show"for="toolTip"/
>
</h:commandButton>
This is a result:
Name Value
component-type org.richfaces.ComponentControl
component-class org.richfaces.component.html.HtmlComponentControl
component-family org.richfaces.ComponentControl
renderer-type org.richfaces.ComponentControlRenderer
tag-class org.richfaces.taglib.ComponentControlTag
Information on JSF <f:param> component You can find at <f:param> TLD reference [http://
java.sun.com/javaee/javaserverfaces/1.1_01/docs/tlddocs/f/param.html] in Java Server Faces
technology section at Sun portal.
458
Chapter 6. The RichFaces Components
6.14.2.1. Description
The <rich:effect> utilizes a set of effects provided by the Scriptaculous JavaScript library. It allows
to attach effects to JSF components and HTML tags.
• attached to a JSF component or HTML tag and triggered by a particular event. Wiring effect
with JSF components might occur on the server or client. Wiring with html tag is possible only
on the client side.
• invoking from the JavaScript code by an effect name. During the rendering, <rich:effect>
generates the JavaScript function with defined name. When the function is called, the effect
is applied
<!-- attached to a window onload event and applied to a particular page element -->
<rich:effect
for="window"
event="onload"
type="Appear"
params="targetId:'contentDiv',duration:0.8,from:0.3,to:1.0"
/
>
459
Chapter 6. The RichFaces Components
The "name" attribute defines a name of the JavaScript function that will be generated on a
page after the component is rendered. This function will activate the needed effect. The function
accesses one parameter. It is a set of effect options in JSON format.
The "type" attribute defines the type of an effect that will be applied. Possible values are Fade,
Blind, Opacity.
The "for" attribute defines the ID of the component or HTML tag, the effect is attached to.
RichFaces converts value of "for" attribute to a component client ID if such component is found.
In case if such component is not found the value is left because of possible wirings with some
DOM element id on the client side. By default, the target of the effect is the same element that
effect is pointed to. #arget element can be redefined with the "targetId" attribute; new parameters
should be passed with the "params" attribute.
The "params" attribute allows to define a set of options (duration, delay, from, to) possible for
a particurar effect. Additionally to the options used by the effect itself, there are two option that
might override the <rich:effect>attribute:
• "targetId" allows to re-define the target of effect. The option is override the value of "for" attribute.
• "type" defines the effect type. The option is override the value of "type" attribute.
Besides all you can load the Scriptaculous library to the page and use it directly without
<rich:effect>:
But if you use the <rich:effect> there is no need to include this library because it's already there.
460
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.Effect
component-class org.richfaces.component.html.HtmlEffect
component-family org.richfaces.Effect
renderer-type org.richfaces.EffectRenderer
tag-class org.richfaces.taglib.EffectTag
Useful articels:
Find more information about the compinent at RichFaces Users Forum [http://jboss.com/
index.html?module=bb&op=viewtopic&t=119044].
6.14.3.1. Description
461
Chapter 6. The RichFaces Components
To use Google Map in your application, generate a key on Google Map official resource [http://
google.com/apis/maps] . One key could be used for one directory on the server.
Here are the main settings of initial rendering performed with a component map that are accessible
with the following attributes:
• "lat" specifies an initial latitude coordinate in degrees, as a number between -90 and +90
• "lng" specifies an initial longitude coordinate in degrees, as a number between -180 and +180
462
Chapter 6. The RichFaces Components
For example, the city of Paris is shown after rendering with the following initial settings: lat =
"48.44" , lng = "2.24" and zoom = "5" .
It's also possible to set accessible controls on the map with the help of the attributes:
• "showGMapTypeControl" determines whether the controls for a map type definition are
switched on
• "showGLargeMapControl" determines whether the control for map scale rendering is rendered
463
Chapter 6. The RichFaces Components
To set the controls as well as to perform other activities (Zoom In/Out etc.) is possible with your
JavaScript, i.e. declare a name of a map object in the "gmapVar" attribute and then call the object
directly with Google Maps API.
For instance, if you have gmapVar = "map" declared for your component, to zoom in a map you
should call map.zoomIn() on an event. See also an example of <rich:gmap> usage on the
RichFaces Live Demo [http://livedemo.exadel.com/richfaces-demo/richfaces/gmap.jsf?c=gmap].
Tip:
You do not need to use reRender to perform uptades for the <rich:gmap>
component. Use the "gmapVar" attribute and Google Maps native API [http://
code.google.com/intl/ru/apis/maps/documentation/reference.html] instead as it's
described above.
Moreover, to add e.g. some JavaScript effects, events defined on it are used.
• "onmouseover"
• "onclick"
• "onmouseout"
464
Chapter 6. The RichFaces Components
• etc.
Note
Google Map does not support XHTML format of the page. Thus, if you use Facelets
and JSF 1.2, do not forget to put the following tags somewhere on the page:
...
<f:view contentType="text/html">...</f:view>
...
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
6.14.4.1. Description
The component presents the Microsoft Virtual Earth map in the JSF applications.
465
Chapter 6. The RichFaces Components
Here are the main settings of initial rendering performed with a component map that are accessible
with the following attributes:
• "lat" specifies an initial latitude coordinate in degrees, as a number between -90 and +90
• "lng" specifies an initial longitude coordinate in degrees, as a number between -180 and +180
For example, the city of Paris is shown after rendering with the following initial settings: lat =
"48.833" , lng = "2.40" and zoom = "11" .
466
Chapter 6. The RichFaces Components
<rich:virtualEarth
style="width:800px;"
id="vm"
lat="48.833"
lng="2.40"
dashboardSize="Normal"
zoom="11"
mapStyle="Hybrid"
var="map"
/
>
To set all these parameters and perform some activity (Zoom In/Out etc.) is possible with your
JavaScript, i.e. declare a name of an object on a map in the "var" attribute and then call the
object directly with API Microsoft Virtual Earth map .
For example, to approximate a map for var = "map" declared inside the component, call
map.ZoomIn() on an event.
Moreover, to add e.g. some JavaScript effects, events defined on it are used.
• onmouseover
• onclick
• onmouseout
• etc.
Note
Virtual Earth does not support XHTML format of the page. Thus, if you use Facelets
and JSF 1.2, do not forget to put the following tags somewhere on the page:
<f:view contentType="text/html">...</f:view>
467
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.VirtualEarth
component-class org.richfaces.component.html.HtmlVirtualEarth
component-family org.richfaces.VirtualEarth
renderer-type org.richfaces.VirtualEarthRenderer
tag-class org.richfaces.taglib.VirtualEarthTag
Useful articles:
6.14.5.1. Description
The <rich:hotKey> component allows to register hot keys for the page or particular elements and
to define client-side processing functions for these keys.
468
Chapter 6. The RichFaces Components
• place it anywhere on the page. In this case the <rich:hotKey> component is attached to the
whole page (html[0] element). This is default scenario.
• attach it with "selector" attribute to all the elements defined using this selector. This attribute
uses defined by w3c consortium [http://www.w3.org] syntax for CSS rule selector with some
jQuery extensions.
The "key" attribute defines the hot key itself which is processed by the component.
After the hot key has been registered and defined you could set the "handler" attribute which
determines a JavaScript function to be called every time when corresponding keys are pressed.
In the example above the "selector" attribute is used. So the keys work only if <rich:listShuttle>
component is focused.
469
Chapter 6. The RichFaces Components
You could press Right or Left keys in order to move some selected items between lists. You could
press Home or End buttons in order to move all items between lists.
With the help of the "timing" attribute you could manage <rich:hotKey> registration timing.
There are three possible values of this attribute:
• onregistercall — the component is rendered only after JavaScript API for the key registration
is used.
The "type" attribute defines the type of keyboard event. Possible values are: onkeyup, onkeypress
and onkeydown.
The "checkParent" attribute defines the hotkey handling of events generated by child components
nested into the parent component to which the <rich:hotKey> is attached.
The <rich:hotKey> component also provides a number of JavaScript API functions. There is
an example below.
<h:form id="myForm">
<rich:hotKey id="myKey" key="ctrl+g" handler="alert('Ctrl+G is pressed')" />
<button onclick="${rich:component('myKey')}.enable(); return false;">Turn Ctrl+G On</button>
<button onclick="${rich:component('myKey')}.disable(); return false;">Turn Ctrl+G Off</button>
</h:form>
In the example above the Ctrl+G is registered as a global hotkey, so if you press this key
combination the alert window with the "Ctrl+G is pressed" text appears. With the help of
enable(), disable() JavaScript API fucntions you could enable or disable registered hotkey.
Name Value
component-type org.richfaces.HotKey
component-class org.richfaces.component.html.HtmlHotKey
component-family org.richfaces.HotKey
470
Chapter 6. The RichFaces Components
Name Value
renderer-type org.richfaces.HotKeyRenderer
Function Description
add(selector, key, handler) Adds the hotkey(from key param) for elements
targeted by selector. it assigns a handler
function to the key
remove() Removes hotkey registration
enable() Enables registered hotkey
disable() Disables registered hotkey
6.14.6.1. Description
The <rich:insert> component is used for highlighting, source code inserting and, optionally,
format the file from the application context into the page.
The are two basic attributes. The "src" attribute defines the path to the file with source code. The
"highlight" attribute defines the type of a syntax highlighting.
471
Chapter 6. The RichFaces Components
The "errorContent" attribute defines the alternative content that will be shown in case the
<rich:insert> cannot read the resource defined with "src" attribute. If "errorContent" attribute is
not defined, the component shown the actual error message in the place where the content is
expected.
Name Value
component-type org.richfaces.ui.Insert
component-class org.richfaces.ui.component.html.HtmlInsert
component-family org.richfaces.ui.Insert
renderer-type org.richfaces.ui.InsertRenderer
tag-class org.richfaces.ui.taglib.InsertTag
472
Chapter 6. The RichFaces Components
6.14.7.1. Description
The component is used for rendering a single message for a specific component.
• Consists of two parts to be defined optionally: marker (pictogram) and label (text message)
The <rich:message> appears on page after form is submitted. Even for "passed" state. The
"passedLabel" attribute is used for definition of the label when validation is passed. Boolean
attribute "showSummary" defines possibility to display summary portion of displayed messages.
473
Chapter 6. The RichFaces Components
</rich:message>
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
474
Chapter 6. The RichFaces Components
6.14.8.1. Description
The <rich:messages> component is similar to <rich:message> component but used for
rendering all messages for the components.
• Consists of three parts to be defined optionally: marker (pictogram), label (text message) and
header
475
Chapter 6. The RichFaces Components
</f:facet>
</rich:messages>
The <rich:messages> component keeps all messages for all components even after only one
Ajax-validated component was updated.
Name Value
component-type org.richfaces.component.RichMessages
component-class org.richfaces.component.html.HtmlRichMessages
component-family org.richfaces.component.RichMessages
renderer-type org.richfaces.RichMessagesRenderer
tag-class org.richfaces.taglib.RichMessagesTag
Facet Description
errorMarker Defines pictogram for message with error
severity class
fatalMarker Defines pictogram for message with fatal
severity class
infoMarker Defines pictogram for message with info
severity class
passedMarker Defines pictogram if there is no fatal, error,
warn or info message
warnMarker Defines pictogram for message with warn
severity class
You can find all necessary information about style classes redefinition in Definition of Custom
Style Classes section.
476
Chapter 6. The RichFaces Components
6.14.9.1. Description
The mode is chosen with "timing" attribute that has the following options:
• onJScall — applying a query by invoked JavaScript function defined with the "name" attribute.
Definition of the "name" attribute is mandatory when the value of "timing" attribute is "onJScall".
If the "name" attribute is defined when "timing" value equals to "immediate" or "onload", the query
is applied according to this value, but you still have an opportunity to invoke it by a function name.
The "selector" attribute defines an object or a list of objects. The query is defined with the "query"
attribute.
<style>
.odd {background-color: #FFC;}
477
Chapter 6. The RichFaces Components
</style>
The "selector" attribute uses defined by w3c consortium syntax for CSS rule selector [http://
www.w3.org/TR/REC-CSS2/selector.html] with some jQuery extensions
Selector Comment
p[a] In a document all "p" tags with "a" tag inside
are selected
ul/li All "li" elements of unordered "ul" lists are
selected
p.foo[a] All "p" tags with "foo" class and inserted "a" tag
are selected
input[@name=bar] All "input" tags with "name" attribute which
value is "bar" are selected
input[@type=radio][@checked] All "input" tags with attribute "type"="radio" and
attribute value = "chekced" are selected
p,span,td All tag elements "p" or"span" or "td" are
selected
p#secret "p" paragraph element with "id" identification =
"secret" is selected
p span "span" tag is a (direct or non-direct) child of "p"
tag. If it's necessary, use "p > span" or "p/span"
is selected
p[@foo^=bar] "p" tag containing "foo" attribute with textual
value beginning with "bar" word is selected
p[@foo$=bar] "p" tag containing "foo" attribute with textual
value ending with "bar" word is selected
p[@foo*=bar] "p" tag with "foo" attribute containing substring
"bar" in any place is selected
p//span "span" tag that is a (direct or non-direct) child
of "p" tag is selected
478
Chapter 6. The RichFaces Components
Selector Comment
p/../span "span" tag that is a grandchild of "p" tag is
selected
In addition, RichFaces allows using either a component id or client id if you apply the query to a
JSF component. When you define a selector, RichFaces examines its content and tries to replace
the defined in the selector id with a component id if it's found.
<h:form id="form">
<h:panelGrid id="menu">
<h:graphicImage value="pic1.jpg" />
<h:graphicImage value="pic2.jpg" />
</h:panelGrid>
</h:form>
The actual id of the <h:panelGrid> table in the browser DOM is "form:menu". However, you
still can reference to images inside this table using the following selector:
...
<rich:jQuery selector="#menu img" query="..." />
...
You can define the exact id in the selector if you want. The following code reference to the same
set of a DOM object:
...
<rich:jQuery selector="#form\\:menu img" query="..." />
...
In case when the "name" attribute is defined, <rich:jQuery> generates a JavaScript function
that might be used from any place of JavaScript code on a page.
There is an example of how to enlarge the picture smoothly on a mouse over event and return
back to the normal size on mouse out:
...
479
Chapter 6. The RichFaces Components
The JavaScript could use two parameters. The first parameter is a replacement for the selector
attribute. Thus, you can share the same query, applying it to the different DOM objects. You can
use a literal value or a direct reference for an existing DOM object. The second parameter can
be used to path the specific value inside the query. The JSON syntax is used for the second
parameter. The "param." namespace is used for referencing data inside the parameter value.
<rich:jQuery> adds styles and behavior to the DOM object dynamically. This means if you replace
something on a page during an Ajax response, the applied artifacts is overwritten. But you are
allowed to apply them again after the Ajax response is complete.
Usually, it could be done with reRendering the <rich:jQuery> components in the same Ajax
interaction with the components these queries are applied to. Note, that queries with "timing"
attribute set to "onload" are not invoked even if the query is reRendered, because a DOM
document is not fully reloaded during the Ajax interaction. If you need to re-applies query with
"onload" value of "timing" attribute, define the "name" attribute and invoke the query by name
in the "oncomplete" attribute of the Ajax component.
RichFaces includes jQuery JavaScript framework. You can use the futures of jQuery directly
without defining the <rich:jQuery> component on a page if it is convenient for you. To start using
the jQuery feature on the page, include the library into a page with the following code:
...
<a4j:loadScript src="resource://jquery.js"/>
...
Refer to the jQuery documentation [http://docs.jquery.com/] for the right syntax. Remember to use
jQuery() function instead of $(), as soon as jQuery works without conflicts with prototype.js.
480
Chapter 6. The RichFaces Components
Name Value
component-type org.richfaces.JQuery
component-class org.richfaces.component.html.HtmlJQuery
component-family org.richfaces.JQuery
renderer-type org.richfaces.JQueryRenderer
tag-class org.richfaces.taglib.JQueryTag
More information about jQuery framework you can find injQuery official documentation [http://
jquery.com/].
See also:
481
Chapter 7. IDE Support
IDE Support
RichFaces support is implemented in JBoss Developer Studio 1.0.0 GA [http://www.redhat.com/
developers/rhds/index.html] and in Jboss Tools [http://jboss.org/tools]. JBoss Developer Studio
is a fully packaged IDE that provides full support for Java Server Faces, RichFaces, Facelets,
Struts and other Web technologies. In addition to this, it seamlessly combines visual and source-
oriented development approaches. One of the special support feature for RichFaces is that it is
available as project "capabilitiy" which can be added to any existing JSF project by adding libraries
and modifying configuration files as required."
483
Chapter 8. Links to information resources
Resources Links
JBoss RichFaces JBoss RichFaces [http://labs.jboss.com/portal/
jbossrichfaces/]
JBoss Forum JBoss Forums [http://jboss.com/index.html?
module=bb&op=main&c=27]
RichFaces Wiki RichFaces Wiki [http://labs.jboss.com/wiki/
RichFaces]
RichFaces Blog RichFaces Blog [http://jroller.com/a4j/]
485