com.sun.webui.jsf.renderkit.html.HtmlRenderer Maven / Gradle / Ivy
/*
* The contents of this file are subject to the terms
* of the Common Development and Distribution License
* (the License). You may not use this file except in
* compliance with the License.
*
* You can obtain a copy of the license at
* https://woodstock.dev.java.net/public/CDDLv1.0.html.
* See the License for the specific language governing
* permissions and limitations under the License.
*
* When distributing Covered Code, include this CDDL
* Header Notice in each file and include the License file
* at https://woodstock.dev.java.net/public/CDDLv1.0.html.
* If applicable, add the following below the CDDL Header,
* with the fields enclosed by brackets [] replaced by
* you own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
*
* Copyright 2007 Sun Microsystems, Inc. All rights reserved.
*/
/*
* $Id: HtmlRenderer.java,v 1.1.20.1 2009-12-29 04:52:45 jyeary Exp $
*/
package com.sun.webui.jsf.renderkit.html;
import com.sun.faces.annotation.Renderer;
import com.sun.webui.jsf.component.Html;
import java.io.IOException;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.context.ResponseWriter;
import com.sun.webui.jsf.util.RenderingUtilities;
/**
* Renderer for a {@link Html} component.
*/
@Renderer(@Renderer.Renders(componentFamily = "com.sun.webui.jsf.Html"))
public class HtmlRenderer extends AbstractRenderer {
// ======================================================== Static Variables
/**
* The set of String pass-through attributes to be rendered.
*/
private static final String stringAttributes[] = {"xmlns", "lang"}; //NOI18N
// -------------------------------------------------------- Renderer Methods
/**
* Render the appropriate element start, depending on whether the
* for
property is set or not.
*
* @param context FacesContext
for the current request
* @param component component to render.
* @param writer ResponseWriter
to which the element
* start should be rendered
*
* @exception IOException if an input/output error occurs
*/
@Override
protected void renderStart(FacesContext context, UIComponent component,
ResponseWriter writer) throws IOException {
// Start the appropriate element
if (!RenderingUtilities.isPortlet(context)) {
writer.startElement("html", component); //NOI18N
}
}
/**
* Render the appropriate element attributes,
*
* @param context FacesContext
for the current request
* @param component component to be rendered
* submitted value is to be stored
* @param writer ResponseWriter
to which the element
* start should be rendered
*
* @exception IOException if an input/output error occurs
*/
@Override
protected void renderAttributes(FacesContext context, UIComponent component,
ResponseWriter writer) throws IOException {
if (!RenderingUtilities.isPortlet(context)) {
addStringAttributes(context, component, writer, stringAttributes);
//these attributes needed for accessibility support
writer.writeAttribute("xmlns:wairole",
"http://www.w3.org/2005/01/wai-rdf/GUIRoleTaxonomy#", null);
writer.writeAttribute("xmlns:waistate",
"http://www.w3.org/2005/07/aaa", null);
writer.write("\n");
}
}
/**
*
Render the appropriate element end, depending on whether the
* for
property is set or not.
*
* @param context FacesContext
for the current request
* @param component component to be rendered
* @param writer ResponseWriter
to which the element
* start should be rendered
*
* @exception IOException if an input/output error occurs
*/
@Override
protected void renderEnd(FacesContext context, UIComponent component,
ResponseWriter writer) throws IOException {
if (!RenderingUtilities.isPortlet(context)) {
writer.endElement("html"); //NOI18N
writer.write("\n"); //NOI18N
}
}
// --------------------------------------------------------- Private Methods
}