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


Reply via email to