blob: b9268280d2f4f82dce874eaae28db0a21d3d7214 [file] [log] [blame]
// Copyright 2004 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;
/**
* Prevents its contents from being rendered until triggered by
* an {@link RenderBlock} component.
*
* [<a href="../../../../../ComponentReference/Block.html">Component Reference</a>]
*
* <p>Block and {@link RenderBlock} are used to build a certain class
* of complicated component that can't be assembled using the normal
* wrapping containment. Such a super component would have two or more
* sections that need to be supplied by the containing page (or component).
*
* <p>Using Blocks, the blocks can be provided as parameters to the super
* component.
*
* <p>The inserter property gives the components inside the block access to
* the component (typically an {@link RenderBlock}) that inserted the block,
* including access to its informal bindings which allows components contained
* by the Block to be passed parameters. Note - it is the responsibility of the
* inserting component to set itself as the Block's inserter.
*
* @version $Id$
* @author Howard Lewis Ship
* @since 0.2.9
*
**/
public class Block extends AbstractComponent
{
private IComponent _inserter;
/**
* Does nothing; the idea of a Block is to defer the rendering of
* the body of the block until an {@link RenderBlock} forces it
* out.
*
**/
protected void renderComponent(IMarkupWriter writer, IRequestCycle cycle)
{
// Nothing!
}
public IComponent getInserter()
{
return _inserter;
}
public void setInserter(IComponent value)
{
_inserter = value;
}
}