[OmniFaces utilities] The
addFlashFatal()
method adds a flash scoped FATAL faces message to the given clientId, with the given message body which is formatted with the given parameters. Use this when you need to display the message after a redirect.Method:
See also: Faces#getContext() | Faces#getFlash()
Usage:
The
information stored in flash scope "survives" one redirect. Let's
suppose that the below code is in page A.xhtml:
<h:form>
<h:commandButton value="Click
Me!" action="#{myBean.myAction()}"/>
</h:form>
The myAction() method
perform some tasks, including generating a global FATAL parameterized messages
and redirecting to page, B.xhtml:
import
org.omnifaces.util.Messages;
...
// FATAL
message
private
static final String USER_FATAL = "The database at {0} does not respond on
port {1} !";
...
// for a
certain component, replace null with clientId
public
String myAction() {
// add a FATAL
message as a global message in flash scope
Object[]
params = new Object[]{"89.38.122.5", "5432"};
Messages.addFlashFatal(null,
USER_FATAL, "89.38.122.5", "5432");
// or
Messages.addFlashFatal(null,
USER_FATAL, params);
return
"B?faces-redirect=true";
}
Now, in
page B.xhtml, you will
see this message:
// FATAL
message
The database
at 89.38.122.5 does not respond on port 5432 !
Note Don't
forget to use in page where the messages are displayed the <h:messages>, for
global messages, <h:message>, for component messages, or any other
approach capable to display the messages.
Note By
default, this example uses the OmniFaces default message resolver, but you can use your own message resolver as in Working with OmniFaces Message Resolvers.
Niciun comentariu :
Trimiteți un comentariu