diff --git a/source/java/org/alfresco/repo/jscript/RhinoScriptProcessor.java b/source/java/org/alfresco/repo/jscript/RhinoScriptProcessor.java index 2192c003b1..76e1097dc1 100644 --- a/source/java/org/alfresco/repo/jscript/RhinoScriptProcessor.java +++ b/source/java/org/alfresco/repo/jscript/RhinoScriptProcessor.java @@ -536,8 +536,9 @@ public class RhinoScriptProcessor extends BaseProcessor implements ScriptProcess /** * Converts the passed model into a Rhino model * - * @param model the model - * @return Map the converted model + * @param model the model + * + * @return Map the converted model */ private Map convertToRhinoModel(Map model) { diff --git a/source/java/org/alfresco/repo/jscript/ValueConverter.java b/source/java/org/alfresco/repo/jscript/ValueConverter.java index 2ccb8d28fd..f5d695c978 100644 --- a/source/java/org/alfresco/repo/jscript/ValueConverter.java +++ b/source/java/org/alfresco/repo/jscript/ValueConverter.java @@ -99,13 +99,14 @@ public class ValueConverter { // recursively convert each value in the collection Collection collection = (Collection)value; - Serializable[] array = new Serializable[collection.size()]; + Object[] array = new Object[collection.size()]; int index = 0; for (Serializable obj : collection) { array[index++] = convertValueForScript(services, scope, qname, obj); } - value = array; + // convert array to a native JavaScript Array + value = (Serializable)Context.getCurrentContext().newArray(scope, array); } // simple numbers and strings are wrapped automatically by Rhino diff --git a/source/java/org/alfresco/repo/template/FreeMarkerProcessor.java b/source/java/org/alfresco/repo/template/FreeMarkerProcessor.java index 586cab5e4b..2d0a113ecc 100644 --- a/source/java/org/alfresco/repo/template/FreeMarkerProcessor.java +++ b/source/java/org/alfresco/repo/template/FreeMarkerProcessor.java @@ -269,6 +269,13 @@ public class FreeMarkerProcessor extends BaseProcessor implements TemplateProces } } + /** + * Converts the passed model into a FreeMarker model + * + * @param model the model + * + * @return Object the converted model + */ private Object convertToFreeMarkerModel(Object model) { // If we dont have a map in our hand we just return the passes model diff --git a/source/java/org/alfresco/repo/template/PropertyConverter.java b/source/java/org/alfresco/repo/template/PropertyConverter.java new file mode 100644 index 0000000000..564c458a27 --- /dev/null +++ b/source/java/org/alfresco/repo/template/PropertyConverter.java @@ -0,0 +1,68 @@ +/* + * Copyright (C) 2005-2007 Alfresco Software Limited. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + + * As a special exception to the terms and conditions of version 2.0 of + * the GPL, you may redistribute this Program in connection with Free/Libre + * and Open Source Software ("FLOSS") applications as described in Alfresco's + * FLOSS exception. You should have recieved a copy of the text describing + * the FLOSS exception, and it is also available here: + * http://www.alfresco.com/legal/licensing + */ +package org.alfresco.repo.template; + +import java.io.Serializable; +import java.util.List; + +import org.alfresco.service.ServiceRegistry; +import org.alfresco.service.cmr.repository.NodeRef; +import org.alfresco.service.cmr.repository.TemplateImageResolver; +import org.alfresco.service.namespace.QName; + +/** + * Simple class to recursively convert property values to bean objects accessable by Templates. + * + * @author Kevin Roast + */ +public class PropertyConverter +{ + public Serializable convertProperty( + Serializable value, QName name, ServiceRegistry services, TemplateImageResolver resolver) + { + // perform conversions from Java objects to template compatable instances + if (value == null) + { + return null; + } + else if (value instanceof NodeRef) + { + // NodeRef object properties are converted to new TemplateNode objects + // so they can be used as objects within a template + value = new TemplateNode(((NodeRef)value), services, resolver); + } + else if (value instanceof List) + { + // recursively convert each value in the collection + List list = (List)value; + for (int i=0; i buildDefaultModel( NodeRef person, NodeRef companyHome, diff --git a/source/java/org/alfresco/service/cmr/repository/TemplateService.java b/source/java/org/alfresco/service/cmr/repository/TemplateService.java index 03669659bf..94fcea357d 100644 --- a/source/java/org/alfresco/service/cmr/repository/TemplateService.java +++ b/source/java/org/alfresco/service/cmr/repository/TemplateService.java @@ -169,7 +169,7 @@ public interface TemplateService * @param imageResolver the image resolver (optional) * @return */ - @Auditable(parameters = {"person", "compantHome", "userHome", "template", "imageResolver"}) + @Auditable(parameters = {"person", "companyHome", "userHome", "template", "imageResolver"}) public Map buildDefaultModel( NodeRef person, NodeRef companyHome,