org.sakaiproject.jsf2.renderer.SeparatedListRenderer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jsf2-widgets Show documentation
Show all versions of jsf2-widgets Show documentation
This is the Maven project for the custom JSF 2 widgets.
The widgets and the resources projects are closely tied together.
These widgets will be deployed as a jar file containing Sakai JSF 2 widgets
(components).
Web applications can include this jar in order to use the Sakai JSF 2 widgets in a JSF tool.
/**
* Copyright (c) 2003-2021 The Apereo Foundation
*
* Licensed under the Educational Community 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://opensource.org/licenses/ecl2
*
* 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.sakaiproject.jsf2.renderer;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import javax.faces.component.UIComponent;
import javax.faces.component.UIOutput;
import javax.faces.component.UIViewRoot;
import javax.faces.context.FacesContext;
import javax.faces.context.ResponseWriter;
import javax.faces.render.Renderer;
import org.sakaiproject.jsf2.util.RendererUtil;
public class SeparatedListRenderer extends Renderer
{
/**
* This component renders its children
* @return true
*/
public boolean getRendersChildren()
{
return true;
}
/**
* This is an output type component.
* @param component
* @return true if UIOutput
*/
public boolean supportsComponentType(UIComponent component)
{
return (component instanceof UIOutput);
}
/**
* no-op
* @param context
* @param component
* @throws IOException
*/
public void encodeBegin(FacesContext context,
UIComponent component) throws IOException
{
;
}
/**
* We put all our processing in the encodeChildren method
* @param context
* @param component
* @throws IOException
*/
public void encodeChildren(FacesContext context, UIComponent component)
throws IOException
{
if (!component.isRendered())
{
return;
}
String clientId = null;
if (component.getId() != null &&
!component.getId().startsWith(UIViewRoot.UNIQUE_ID_PREFIX))
{
clientId = component.getClientId(context);
}
ResponseWriter writer = context.getResponseWriter();
if (clientId != null)
{
String styleClass = (String) RendererUtil.getAttribute(context, component, "styleClass");
writer.startElement("div", component);
writer.writeAttribute("id", clientId, "id");
writer.writeAttribute("class", styleClass, "class");
}
List children = component.getChildren();
// this is a special separator attribute, not supported by UIData
String separator = (String) RendererUtil.getAttribute(context, component, "separator");
if (separator==null) separator=" | ";
boolean first = true;
for (Iterator iter = children.iterator(); iter.hasNext();)
{
UIComponent child = (UIComponent)iter.next();
if (child.isRendered()) {
if (!first) writer.write(separator);
RendererUtil.encodeRecursive(context, child);
first = false;
}
}
if (clientId != null)
{
writer.endElement("div");
}
}
/**
* no-op
* @param context
* @param component
* @throws IOException
*/
public void encodeEnd(FacesContext context, UIComponent component)
throws IOException
{
;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy