Package org.apache.tapestry.components

Source Code of org.apache.tapestry.components.RenderBlock

// Copyright 2004, 2005 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.tapestry.components;

import org.apache.tapestry.AbstractComponent;
import org.apache.tapestry.IComponent;
import org.apache.tapestry.IMarkupWriter;
import org.apache.tapestry.IRequestCycle;

/**
* Renders the text and components wrapped by a {@link Block}component. [ <a
* href="../../../../../ComponentReference/RenderBlock.html">Component Reference </a>]
* <p>
* It is possible for an RenderBlock to obtain a Block from a page <em>other than</em> the render
* page. This works, even when the Block contains links, forms and form components. The action and
* direct services will create URLs that properly address this situation.
* <p>
* However, because the rendering page can't know ahead of time about these foriegn Blocks,
* {@link org.apache.tapestry.event.PageRenderListener}methods (for components and objects of the
* foriegn page) via RenderBlock will <em>not</em> be executed. This specifically affects the
* methods of the {@link org.apache.tapestry.event.PageRenderListener}interface.
* <p>
* Before rendering its {@link Block}, RenderBlock will set itself as the Block's inserter, and
* will reset the inserter after the {@link Block}is rendered. This gives the components contained
* in the {@link Block}access to its inserted environment via the RenderBlock. In particular this
* allows the contained components to access the informal parameters of the RenderBlock which
* effectively allows parameters to be passed to the components contained in a Block.
*
* @author Howard Lewis Ship
*/

public abstract class RenderBlock extends AbstractComponent
{
    /**
     * If block is not null, then the block's inserter is set (to this),
     * {@link org.apache.tapestry.IComponent#renderBody(IMarkupWriter, IRequestCycle)}is invoked on
     * it, and the Block's inserter is set back to its previous state.
     */

    protected void renderComponent(IMarkupWriter writer, IRequestCycle cycle)
    {
        Block block = getBlock();

        if (block == null)
            return;

        IComponent previousInserter = block.getInserter();

        try
        {
            block.setInserter(this);
            block.renderBody(writer, cycle);
        }
        finally
        {
            block.setInserter(previousInserter);
        }
    }

    public abstract Block getBlock();

}
TOP

Related Classes of org.apache.tapestry.components.RenderBlock

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.