Author: hlship
Date: Fri Jun 25 00:05:48 2010
New Revision: 957758
URL: http://svn.apache.org/viewvc?rev=957758&view=rev
Log:
TAP5-1190: Add new page-level events triggered when links are created for a
page, allowing the page to modify the links (adding new query parameters)
Added:
tapestry/tapestry5/trunk/tapestry-core/src/test/java/org/apache/tapestry5/internal/services/LinkDecorationListener.java
(with props)
Modified:
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/EventConstants.java
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalModule.java
Modified:
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/EventConstants.java
URL:
http://svn.apache.org/viewvc/tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/EventConstants.java?rev=957758&r1=957757&r2=957758&view=diff
==============================================================================
---
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/EventConstants.java
(original)
+++
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/EventConstants.java
Fri Jun 25 00:05:48 2010
@@ -15,6 +15,8 @@
package org.apache.tapestry5;
import org.apache.tapestry5.corelib.components.BeanEditForm;
+import org.apache.tapestry5.services.ComponentEventRequestParameters;
+import org.apache.tapestry5.services.PageRenderRequestParameters;
/**
* Constant values for common event names fired by Tapestry components.
@@ -80,7 +82,7 @@ public class EventConstants
*
* @see org.apache.tapestry5.corelib.components.Form
* @deprecated As of 5.2, this event should no longer be used; the Form
component now fires a {...@link #VALIDATE}
- * event.
+ * event. For compatibility, validateForm will be supported,
but may be removed in a future release.
*/
public static final String VALIDATE_FORM = "validateForm";
@@ -178,14 +180,34 @@ public class EventConstants
*
* @SINCE 5.1.0.4
*/
- public static final String PROVIDE_COMPLETIONS = "providecompletions";
+ public static final String PROVIDE_COMPLETIONS = "provideCompletions";
/**
* Event triggered by {...@link
org.apache.tapestry5.corelib.components.Select} component to inform
* its
* container that Select's value has changed.
*
- * @since 5.2.0.0
+ * @since 5.2.0
+ */
+ public static final String VALUE_CHANGED = "valueChanged";
+
+ /**
+ * Event triggered during page render link generation. The first context
parameter is the {...@link Link} object, the
+ * second is the {...@link PageRenderRequestParameters} from which the Link
+ * was created. The event is triggered on the actively rendering page.
+ *
+ * @since 5.2.0
*/
- public static final String VALUE_CHANGED = "valuechanged";
+ public static final String DECORATE_PAGE_RENDER_LINK =
"decoratePageRenderLink";
+
+ /**
+ * Event triggered during component event link generation. The first
context parameter is the {...@link Link} object,
+ * the second is the {...@link ComponentEventRequestParameters} from which
the Link
+ * was created. The event is triggered on the actively rendering page, not
necessarily the page
+ * containing the component.
+ *
+ * @since 5.2.0
+ */
+ public static final String DECORATE_COMPONENT_EVENT_LINK =
"decoreateComponentEventLink";
+
}
Modified:
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalModule.java
URL:
http://svn.apache.org/viewvc/tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalModule.java?rev=957758&r1=957757&r2=957758&view=diff
==============================================================================
---
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalModule.java
(original)
+++
tapestry/tapestry5/trunk/tapestry-core/src/main/java/org/apache/tapestry5/internal/services/InternalModule.java
Fri Jun 25 00:05:48 2010
@@ -23,6 +23,7 @@ import org.apache.tapestry5.internal.ser
import
org.apache.tapestry5.internal.structure.ComponentPageElementResourcesSource;
import
org.apache.tapestry5.internal.structure.ComponentPageElementResourcesSourceImpl;
import org.apache.tapestry5.ioc.ObjectLocator;
+import org.apache.tapestry5.ioc.OrderedConfiguration;
import org.apache.tapestry5.ioc.ScopeConstants;
import org.apache.tapestry5.ioc.ServiceBinder;
import org.apache.tapestry5.ioc.annotations.Autobuild;
@@ -36,16 +37,7 @@ import org.apache.tapestry5.ioc.services
import org.apache.tapestry5.ioc.services.ClasspathURLConverter;
import org.apache.tapestry5.ioc.services.PerthreadManager;
import org.apache.tapestry5.ioc.services.PropertyShadowBuilder;
-import org.apache.tapestry5.services.ComponentClasses;
-import org.apache.tapestry5.services.ComponentLayer;
-import org.apache.tapestry5.services.ComponentMessages;
-import org.apache.tapestry5.services.ComponentTemplates;
-import org.apache.tapestry5.services.Core;
-import org.apache.tapestry5.services.InvalidationEventHub;
-import org.apache.tapestry5.services.LocalizationSetter;
-import org.apache.tapestry5.services.RequestGlobals;
-import org.apache.tapestry5.services.ResponseCompressionAnalyzer;
-import org.apache.tapestry5.services.UpdateListenerHub;
+import org.apache.tapestry5.services.*;
import org.apache.tapestry5.services.templates.ComponentTemplateLocator;
import org.slf4j.Logger;
@@ -275,4 +267,18 @@ public class InternalModule
return service;
}
+
+ /**
+ * Contributes:
+ * <dl>
+ * <dt>LinkDecoration (instance of {...@link LinkDecorationListener})</dt>
+ * <dd>Triggers events for notifications about links</dd>
+ * <dl>
+ *
+ * @since 5.2.0
+ */
+ public static void
contributeLinkSource(OrderedConfiguration<LinkCreationListener2> configuration)
+ {
+ configuration.addInstance("LinkDecoration",
LinkDecorationListener.class);
+ }
}
Added:
tapestry/tapestry5/trunk/tapestry-core/src/test/java/org/apache/tapestry5/internal/services/LinkDecorationListener.java
URL:
http://svn.apache.org/viewvc/tapestry/tapestry5/trunk/tapestry-core/src/test/java/org/apache/tapestry5/internal/services/LinkDecorationListener.java?rev=957758&view=auto
==============================================================================
---
tapestry/tapestry5/trunk/tapestry-core/src/test/java/org/apache/tapestry5/internal/services/LinkDecorationListener.java
(added)
+++
tapestry/tapestry5/trunk/tapestry-core/src/test/java/org/apache/tapestry5/internal/services/LinkDecorationListener.java
Fri Jun 25 00:05:48 2010
@@ -0,0 +1,73 @@
+// Copyright 2010 The Apache Software Foundation
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package org.apache.tapestry5.internal.services;
+
+import org.apache.tapestry5.EventConstants;
+import org.apache.tapestry5.Link;
+import org.apache.tapestry5.model.ComponentModel;
+import org.apache.tapestry5.runtime.Component;
+import org.apache.tapestry5.services.ComponentClassResolver;
+import org.apache.tapestry5.services.ComponentEventRequestParameters;
+import org.apache.tapestry5.services.ComponentSource;
+import org.apache.tapestry5.services.LinkCreationListener2;
+import org.apache.tapestry5.services.PageRenderRequestParameters;
+
+/**
+ * A default {...@link LinkCreationListener2} that triggers the {...@link
EventConstants#DECORATE_COMPONENT_EVENT_LINK} and
+ * {...@link EventConstants#DECORATE_PAGE_RENDER_LINK} events as links are
generated.
+ *
+ * @since 5.2.0
+ */
+public class LinkDecorationListener implements LinkCreationListener2
+{
+ private final ComponentClassResolver resolver;
+
+ private final ComponentSource componentSource;
+
+ private final ComponentModelSource modelSource;
+
+ public LinkDecorationListener(ComponentClassResolver resolver,
ComponentSource componentSource,
+ ComponentModelSource modelSource)
+ {
+ this.resolver = resolver;
+ this.componentSource = componentSource;
+ this.modelSource = modelSource;
+ }
+
+ public void createdComponentEventLink(Link link,
ComponentEventRequestParameters parameters)
+ {
+ trigger(parameters.getActivePageName(),
EventConstants.DECORATE_COMPONENT_EVENT_LINK, link, parameters);
+ }
+
+ public void createdPageRenderLink(Link link, PageRenderRequestParameters
parameters)
+ {
+ trigger(parameters.getLogicalPageName(),
EventConstants.DECORATE_PAGE_RENDER_LINK, link, parameters);
+ }
+
+ private void trigger(String pageName, String eventType, Link link, Object
parameters)
+ {
+ String pageClassName = resolver.resolvePageNameToClassName(pageName);
+
+ ComponentModel model = modelSource.getModel(pageClassName);
+
+ if (model.handlesEvent(eventType))
+ {
+ Component page = componentSource.getPage(pageName);
+
+ page.getComponentResources().triggerEvent(eventType, new Object[]
+ { link, parameters }, null);
+ }
+ }
+}
Propchange:
tapestry/tapestry5/trunk/tapestry-core/src/test/java/org/apache/tapestry5/internal/services/LinkDecorationListener.java
------------------------------------------------------------------------------
svn:eol-style = native