From 722b8154aeb15c350a59b3d0db6de5f6060db3f9 Mon Sep 17 00:00:00 2001 From: melloware Date: Sun, 1 Dec 2024 10:57:04 -0500 Subject: [PATCH] MultiPageMessagesSupport documentation --- .../util/MultiPageMessagesSupport.java | 61 ++++++++++++++++--- 1 file changed, 53 insertions(+), 8 deletions(-) diff --git a/src/main/java/org/primefaces/showcase/util/MultiPageMessagesSupport.java b/src/main/java/org/primefaces/showcase/util/MultiPageMessagesSupport.java index 88bffaa71..94cb889dd 100644 --- a/src/main/java/org/primefaces/showcase/util/MultiPageMessagesSupport.java +++ b/src/main/java/org/primefaces/showcase/util/MultiPageMessagesSupport.java @@ -2,8 +2,11 @@ import java.io.Serial; import java.io.Serializable; -import java.util.*; - +import java.util.Iterator; +import java.util.LinkedHashSet; +import java.util.Map; +import java.util.Objects; +import java.util.Set; import jakarta.faces.application.FacesMessage; import jakarta.faces.context.FacesContext; @@ -13,21 +16,33 @@ /** * Enables messages to be rendered on different pages from which they were set. - *

+ *

* After each phase where messages may be added, this moves the messages * from the page-scoped FacesContext to the session-scoped session map. - *

+ *

+ *

* Before messages are rendered, this moves the messages from the * session-scoped session map back to the page-scoped FacesContext. - *

+ *

+ *

* Only global messages, not associated with a particular component, are * moved. Component messages cannot be rendered on pages other than the one on * which they were added. - *

+ *

+ *

* To enable multi-page messages support, add a lifecycle block to your * faces-config.xml file. That block should contain a single * phase-listener block containing the fully-qualified classname * of this file. + *

+ *

+ * Example configuration in faces-config.xml: + *

+ * <lifecycle>
+ *     <phase-listener>org.primefaces.showcase.util.MultiPageMessagesSupport</phase-listener>
+ * </lifecycle>
+ * 
+ *

* * @author Jesse Wilson jesse[AT]odel.on.ca * @author Lincoln Baxter III lincoln[AT]ocpsoft.com @@ -38,10 +53,20 @@ public class MultiPageMessagesSupport implements PhaseListener { private static final long serialVersionUID = 1250469273857785274L; private static final String TOKEN = "MULTI_PAGE_MESSAGES_SUPPORT"; + /** + * Returns the phase id indicating this listener is interested in all phases. + * @return PhaseId.ANY_PHASE + */ public PhaseId getPhaseId() { return PhaseId.ANY_PHASE; } + /** + * Before each phase, saves messages to the session. During RENDER_RESPONSE phase, + * restores messages if the response is not complete. + * + * @param event The phase event + */ public void beforePhase(final PhaseEvent event) { FacesContext facesContext = event.getFacesContext(); this.saveMessages(facesContext, facesContext.getExternalContext().getSessionMap()); @@ -58,8 +83,10 @@ public void beforePhase(final PhaseEvent event) { } } - /* - * Save messages into the session after every phase. + /** + * After each phase except RENDER_RESPONSE, saves messages to the session. + * + * @param event The phase event */ public void afterPhase(final PhaseEvent event) { if (!PhaseId.RENDER_RESPONSE.equals(event.getPhaseId())) { @@ -68,6 +95,13 @@ public void afterPhase(final PhaseEvent event) { } } + /** + * Saves FacesMessages from the FacesContext to the provided destination map. + * Messages are wrapped in FacesMessageWrapper objects and stored in a LinkedHashSet. + * + * @param facesContext The FacesContext containing messages to save + * @param destination The map where messages will be stored + */ @SuppressWarnings("unchecked") public void saveMessages(final FacesContext facesContext, final Map destination) { if (facesContext != null) { @@ -87,6 +121,13 @@ public void saveMessages(final FacesContext facesContext, final Map source) { if (facesContext != null) { @@ -114,6 +155,10 @@ public void restoreMessages(final FacesContext facesContext, final Map