javax.faces.render.Renderer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of myfaces-api Show documentation
Show all versions of myfaces-api Show documentation
The public API classes of the Apache MyFaces CORE JSF-2.2 project
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 javax.faces.render;
import java.io.IOException;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.convert.ConverterException;
/**
* see Javadoc of JSF Specification
*
* @author Manfred Geiler (latest modification by $Author: lu4242 $)
* @version $Revision: 1151309 $ $Date: 2011-07-26 21:04:45 -0500 (Tue, 26 Jul 2011) $
*/
public abstract class Renderer
{
public void decode(FacesContext context, UIComponent component)
{
if (context == null)
throw new NullPointerException("context");
if (component == null)
throw new NullPointerException("component");
}
/**
* @throws IOException if an input/output error occurs while rendering
*/
public void encodeBegin(FacesContext context, UIComponent component) throws IOException
{
if (context == null)
throw new NullPointerException("context");
if (component == null)
throw new NullPointerException("component");
}
/**
* Render all children if there are any.
*
* Note: this will only be called if getRendersChildren() returns true. A component which has a renderer with
* getRendersChildren() set to true will typically contain the rendering logic for its children in this method.
*
* @param context
* @param component
* @throws IOException
*/
public void encodeChildren(FacesContext context, UIComponent component) throws IOException
{
if (context == null)
throw new NullPointerException("context");
if (component == null)
throw new NullPointerException("component");
if (component.getChildCount() > 0)
{
for (int i = 0, childCount = component.getChildCount(); i < childCount; i++)
{
UIComponent child = component.getChildren().get(i);
if (!child.isRendered())
{
continue;
}
child.encodeAll(context);
}
}
}
/**
* @throws IOException if an input/output error occurs while rendering
*/
public void encodeEnd(FacesContext context, UIComponent component) throws IOException
{
if (context == null)
throw new NullPointerException("context");
if (component == null)
throw new NullPointerException("component");
}
public String convertClientId(FacesContext context, String clientId)
{
if (context == null)
throw new NullPointerException("context");
if (clientId == null)
throw new NullPointerException("clientId");
return clientId;
}
/**
* Switch for deciding who renders the children.
*
* @return true - if the component takes care of rendering its children. In this case, encodeChildren() ought
* to be called by the rendering controller (e.g., the rendering controller could be the method encodeAll()
* in UIComponent). In the method encodeChildren(), the component should therefore provide all children
* encode logic.
false - if the component does not take care of rendering its children. In this
* case, encodeChildren() should not be called by the rendering controller. Instead, the children-list
* should be retrieved and the children should directly be rendered by the rendering controller one by one.
*/
public boolean getRendersChildren()
{
return false;
}
public Object getConvertedValue(FacesContext context, UIComponent component, Object submittedValue)
throws ConverterException
{
if (context == null)
throw new NullPointerException("context");
if (component == null)
throw new NullPointerException("component");
return submittedValue;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy