/* ===============================================================================
*
* Part of the InfoGlue Content Management Platform (www.infoglue.org)
*
* ===============================================================================
*
* Copyright (C)
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License version 2, as published by the
* Free Software Foundation. See the file LICENSE.html for more information.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY, including the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with
* this program; if not, write to the Free Software Foundation, Inc. / 59 Temple
* Place, Suite 330 / Boston, MA 02111-1307 / USA.
*
* ===============================================================================
*/
package org.infoglue.deliver.taglib.content;
import java.util.List;
import javax.servlet.jsp.JspException;
import org.infoglue.deliver.taglib.component.ComponentLogicTag;
/**
* This is a tag which lets you get the categories assigned to a content on a specific category key.
*
* <%@ taglib uri="infoglue" prefix="infoglue" %>
*
* <content:assignedCategory propertyName="Article" categoryKey="Area"/>
*
* @author Mattias Bogeblad
*
*/
public class AssignedCategoriesTag extends ComponentLogicTag
{
private static final long serialVersionUID = 3257850991142318897L;
private Integer contentId;
private String propertyName;
private String categoryKey;
private Integer languageId;
private boolean useInheritance = true;
private boolean useRepositoryInheritance = true;
private boolean useAttributeLanguageFallback = false;
private boolean useStructureInheritance = true;
public AssignedCategoriesTag()
{
super();
}
/**
* Initializes the parameters to make it accessible for the children tags (if any).
*
* @return indication of whether to evaluate the body or not.
* @throws JspException if an error occurred while processing this tag.
*/
public int doStartTag() throws JspException
{
return EVAL_BODY_INCLUDE;
}
public int doEndTag() throws JspException
{
if(this.languageId == null)
this.languageId = getController().getLanguageId();
List result = null;
if(contentId != null)
{
result = getController().getAssignedCategories(contentId, categoryKey, languageId, useAttributeLanguageFallback);
}
else if(propertyName != null)
{
result = getComponentLogic().getAssignedCategories(propertyName, categoryKey, languageId, useInheritance, useAttributeLanguageFallback, useRepositoryInheritance, useStructureInheritance);
}
else
{
throw new JspException("You must specify either contentId or propertyName");
}
produceResult(result);
contentId = null;
propertyName = null;
categoryKey = null;;
useInheritance = true;
useAttributeLanguageFallback = true;
languageId = null;
return EVAL_PAGE;
}
public void setPropertyName(String propertyName) throws JspException
{
this.propertyName = evaluateString("contentAttribute", "propertyName", propertyName);
}
public void setCategoryKey(String categoryKey) throws JspException
{
this.categoryKey = evaluateString("contentAttribute", "categoryKey", categoryKey);
}
public void setUseInheritance(boolean useInheritance)
{
this.useInheritance = useInheritance;
}
public void setUseRepositoryInheritance(boolean useRepositoryInheritance)
{
this.useRepositoryInheritance = useRepositoryInheritance;
}
public void setUseStructureInheritance(boolean useStructureInheritance)
{
this.useStructureInheritance = useStructureInheritance;
}
public void setContentId(final String contentId) throws JspException
{
this.contentId = evaluateInteger("contentAttribute", "contentId", contentId);
}
public void setLanguageId(final String languageId) throws JspException
{
this.languageId = evaluateInteger("contentAttribute", "languageId", languageId);
}
public void setUseAttributeLanguageFallback(boolean useAttributeLanguageFallback)
{
this.useAttributeLanguageFallback = useAttributeLanguageFallback;
}
}