All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.tapestry5.corelib.components.ProgressiveDisplay Maven / Gradle / Ivy

Go to download

Central module for Tapestry, containing interfaces to the Java Servlet API and all core services and components.

There is a newer version: 5.8.6
Show newest version
// Copyright 2009, 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.corelib.components;

import java.io.IOException;

import org.apache.tapestry5.BindingConstants;
import org.apache.tapestry5.Block;
import org.apache.tapestry5.ComponentResources;
import org.apache.tapestry5.EventConstants;
import org.apache.tapestry5.EventContext;
import org.apache.tapestry5.Link;
import org.apache.tapestry5.MarkupWriter;
import org.apache.tapestry5.TrackableComponentEventCallback;
import org.apache.tapestry5.ajax.MultiZoneUpdate;
import org.apache.tapestry5.annotations.Environmental;
import org.apache.tapestry5.annotations.Events;
import org.apache.tapestry5.annotations.IncludeJavaScriptLibrary;
import org.apache.tapestry5.annotations.Parameter;
import org.apache.tapestry5.annotations.SupportsInformalParameters;
import org.apache.tapestry5.dom.Element;
import org.apache.tapestry5.ioc.annotations.Inject;
import org.apache.tapestry5.ioc.internal.util.InternalUtils;
import org.apache.tapestry5.json.JSONObject;
import org.apache.tapestry5.services.javascript.JavaScriptSupport;

/**
 * A component used to implement the progressive
 * enhancement web design strategy; the component renders itself with a
 * simplified initial content (i.e., "loading
 * ...") and an Ajax request then supplies the component's true body. This
 * results in much faster page loads. You can
 * even nest these!
 * 

* The component simply does not render its body on initial render. On the subsequent action event request, it fires a * {@link org.apache.tapestry5.EventConstants#PROGRESSIVE_DISPLAY} event to inform the container about the (optional) * event context. The event handler method may return a renderable object; if not then the component's body is rendered * as the partial markup response. * * @since 5.1.0.1 */ @SupportsInformalParameters @IncludeJavaScriptLibrary("ProgressiveDisplay.js") @Events(EventConstants.PROGRESSIVE_DISPLAY) @SuppressWarnings("all") public class ProgressiveDisplay { /** * The initial content to display until the real content arrives. Defaults * to "Loading ..." and an Ajax activity * icon. */ @Parameter(defaultPrefix = BindingConstants.LITERAL, value = "block:defaultInitial") private Block initial; /** * If provided, this is the event context, which will be provided via the * {@link org.apache.tapestry5.EventConstants#PROGRESSIVE_DISPLAY event}. */ @Parameter private Object[] context; @Inject private ComponentResources resources; @Environmental private JavaScriptSupport jsSupport; @Environmental private TrackableComponentEventCallback eventCallback; /** * Name of a function on the client-side Tapestry.ElementEffect object that * is invoked after the elements's body * content has been updated. If not specified, then the basic "highlight" * method is used, which performs a classic * "yellow fade" to indicate to the user that and update has taken place. */ @Parameter(defaultPrefix = BindingConstants.LITERAL) private String update; Block beginRender(MarkupWriter writer) { String clientId = jsSupport.allocateClientId(resources); String elementName = resources.getElementName("div"); Element e = writer.element(elementName, "id", clientId); resources.renderInformalParameters(writer); e.addClassName("t-zone"); Link link = resources.createEventLink(EventConstants.ACTION, context); JSONObject spec = new JSONObject(); if (InternalUtils.isNonBlank(update)) spec.put("update", update.toLowerCase()); spec.put("element", clientId); spec.put("url", link.toURI()); jsSupport.addInitializerCall("progressiveDisplay", spec); return initial; } Object onAction(EventContext context) throws IOException { resources.triggerContextEvent(EventConstants.PROGRESSIVE_DISPLAY, context, eventCallback); if (eventCallback.isAborted()) return null; return getBody(); } boolean beforeRenderBody() { return false; } void afterRender(MarkupWriter writer) { writer.end(); } /** * Returns the body of the ProgressiveDisplay, which is sometimes (in the * context of a {@linkplain MultiZoneUpdate multi-zone update}) * the content to be included. * * @since 5.2.0 * @return body of component */ public Block getBody() { return resources.getBody(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy