/* * Copyright 2009-2014 PrimeTek. * * 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.primefaces.mobile.renderkit; import java.io.IOException; import javax.faces.component.UIComponent; import javax.faces.context.FacesContext; import javax.faces.context.ResponseWriter; import org.primefaces.component.accordionpanel.AccordionPanel; import org.primefaces.component.tabview.Tab; import org.primefaces.util.HTML; import org.primefaces.util.WidgetBuilder; public class AccordionPanelRenderer extends org.primefaces.component.accordionpanel.AccordionPanelRenderer { @Override protected void encodeMarkup(FacesContext context, AccordionPanel acco) throws IOException { ResponseWriter writer = context.getResponseWriter(); String clientId = acco.getClientId(context); String widgetVar = acco.resolveWidgetVar(); String style = acco.getStyle(); String styleClass = acco.getStyleClass(); styleClass = styleClass == null ? AccordionPanel.MOBILE_CONTAINER_CLASS : AccordionPanel.MOBILE_CONTAINER_CLASS + " " + styleClass; writer.startElement("div", null); writer.writeAttribute("id", clientId, null); writer.writeAttribute("class", styleClass, null); if(acco.getStyle() != null) { writer.writeAttribute("style", style, null); } writer.writeAttribute("role", "tablist", null); writer.writeAttribute(HTML.WIDGET_VAR, widgetVar, null); encodeTabs(context, acco); encodeStateHolder(context, acco); writer.endElement("div"); } @Override protected void encodeScript(FacesContext context, AccordionPanel acco) throws IOException { String clientId = acco.getClientId(context); boolean multiple = acco.isMultiple(); WidgetBuilder wb = getWidgetBuilder(context); wb.init("AccordionPanel", acco.resolveWidgetVar(), clientId); if(acco.isDynamic()) { wb.attr("dynamic", true).attr("cache", acco.isCache()); } wb.attr("multiple", multiple, false) .callback("onTabChange", "function(panel)", acco.getOnTabChange()) .callback("onTabShow", "function(panel)", acco.getOnTabShow()); encodeClientBehaviors(context, acco); wb.finish(); } @Override protected void encodeTab(FacesContext context, Tab tab, boolean active, boolean dynamic, boolean rtl) throws IOException { ResponseWriter writer = context.getResponseWriter(); String containerClass = active ? AccordionPanel.MOBILE_ACTIVE_TAB_CONTAINER_CLASS : AccordionPanel.MOBILE_INACTIVE_TAB_CONTAINER_CLASS; String headerClass = active ? AccordionPanel.MOBILE_ACTIVE_TAB_HEADER_CLASS : AccordionPanel.MOBILE_INACTIVE_TAB_HEADER_CLASS; headerClass = tab.isDisabled() ? headerClass + " ui-state-disabled" : headerClass; headerClass = tab.getTitleStyleClass() == null ? headerClass : headerClass + " " + tab.getTitleStyleClass(); String iconClass = active ? AccordionPanel.MOBILE_ACTIVE_ICON_CLASS : AccordionPanel.MOBILE_INACTIVE_ICON_CLASS; String contentClass = active ? AccordionPanel.MOBILE_ACTIVE_TAB_CONTENT_CLASS : AccordionPanel.MOBILE_INACTIVE_TAB_CONTENT_CLASS; UIComponent titleFacet = tab.getFacet("title"); //tab writer.startElement("div", null); writer.writeAttribute("id", tab.getClientId(context), null); writer.writeAttribute("class", containerClass, null); writer.writeAttribute("role", "tabpanel", null); //header container writer.startElement("h3", null); writer.writeAttribute("class", headerClass, null); writer.writeAttribute("role", "tab", null); writer.writeAttribute("aria-expanded", String.valueOf(active), null); if(tab.getTitleStyle() != null) writer.writeAttribute("style", tab.getTitleStyle(), null); if(tab.getTitletip() != null) writer.writeAttribute("title", tab.getTitletip(), null); writer.startElement("a", null); writer.writeAttribute("href", "#", null); writer.writeAttribute("class", iconClass, null); if(titleFacet == null) { writer.write(tab.getTitle()); } else { titleFacet.encodeAll(context); } writer.endElement("a"); writer.endElement("h3"); //content writer.startElement("div", null); writer.writeAttribute("class", contentClass, null); writer.writeAttribute("aria-hidden", String.valueOf(!active), null); writer.startElement("p", null); if(dynamic) { if(active) { tab.encodeAll(context); tab.setLoaded(true); } } else { tab.encodeAll(context); } writer.endElement("p"); writer.endElement("div"); writer.endElement("div"); } }