Files
alfresco-community-repo/source/java/org/alfresco/repo/template/Classification.java
Raluca Munteanu 8674e2bfc8 Merged 5.1.N (5.1.2) to 5.2.N (5.2.1)
125603 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2)
      125484 slanglois: MNT-16155 Update source headers - remove old Copyrights from Java and JSP dource files


git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@125781 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2016-04-26 12:48:49 +00:00

116 lines
3.4 KiB
Java

package org.alfresco.repo.template;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import org.alfresco.repo.jscript.CategoryTemplateNode;
import org.alfresco.service.ServiceRegistry;
import org.alfresco.service.cmr.repository.ChildAssociationRef;
import org.alfresco.service.cmr.repository.StoreRef;
import org.alfresco.service.cmr.search.CategoryService;
import org.alfresco.service.namespace.QName;
/**
* Support for finding classifications and their root categories.
*
* @author Andy Hind
*/
public class Classification extends BaseTemplateProcessorExtension
{
private ServiceRegistry services;
private StoreRef storeRef;
/**
* Sets the service registry
*
* @param services the service registry
*/
public void setServiceRegistry(ServiceRegistry services)
{
this.services = services;
}
/**
* @param storeUrl The store ref url to set.
*/
public void setStoreUrl(String storeUrl)
{
this.storeRef = new StoreRef(storeUrl);
}
/**
* Find all the category nodes in a given classification.
*
* @param aspect
*
* @return all the category nodes in a given classification.
*/
public List<CategoryTemplateNode> getAllCategoryNodes(String aspect)
{
return buildCategoryNodes(services.getCategoryService().getCategories(storeRef, createQName(aspect),
CategoryService.Depth.ANY));
}
/**
* Find all the category nodes in a given classification.
*
* @param aspect
*
* @return all the category nodes in a given classification.
*/
public List<CategoryTemplateNode> getAllCategoryNodes(QName aspect)
{
return buildCategoryNodes(services.getCategoryService().getCategories(storeRef, aspect,
CategoryService.Depth.ANY));
}
/**
* @return all the aspects that define a classification.
*/
public List<QName> getAllClassificationAspects()
{
Collection<QName> aspects = services.getCategoryService().getClassificationAspects();
ArrayList<QName> answer = new ArrayList<QName>(aspects.size());
answer.addAll(aspects);
return answer;
}
/**
* Get the root categories in a classification.
*
* @param aspect
*
* @return List of TemplateNode
*/
public List<CategoryTemplateNode> getRootCategories(String aspect)
{
return buildCategoryNodes(services.getCategoryService().getRootCategories(storeRef, createQName(aspect)));
}
private List<CategoryTemplateNode> buildCategoryNodes(Collection<ChildAssociationRef> cars)
{
ArrayList<CategoryTemplateNode> categoryNodes = new ArrayList<CategoryTemplateNode>(cars.size());
for (ChildAssociationRef car : cars)
{
categoryNodes.add(new CategoryTemplateNode(car.getChildRef(), this.services, getTemplateImageResolver()));
}
return categoryNodes;
}
private QName createQName(String s)
{
QName qname;
if (s.indexOf(QName.NAMESPACE_BEGIN) != -1)
{
qname = QName.createQName(s);
}
else
{
qname = QName.createQName(s, this.services.getNamespaceService());
}
return qname;
}
}