You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@struts.apache.org by "Lukasz Lenart (JIRA)" <ji...@apache.org> on 2013/01/21 22:54:13 UTC

[jira] [Resolved] (WW-3922) Make javatemplates work with other plugins

     [ https://issues.apache.org/jira/browse/WW-3922?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Lukasz Lenart resolved WW-3922.
-------------------------------

    Resolution: Fixed
      Assignee: Lukasz Lenart

Patch applied, thanks for reporting!
                
> Make javatemplates work with other plugins
> ------------------------------------------
>
>                 Key: WW-3922
>                 URL: https://issues.apache.org/jira/browse/WW-3922
>             Project: Struts 2
>          Issue Type: Improvement
>          Components: Plugin - Java Templates
>    Affects Versions: 2.3.4.1
>            Reporter: Greg Huber
>            Assignee: Lukasz Lenart
>             Fix For: 2.3.9
>
>         Attachments: patch.txt, patch.txt
>
>
> Hello,
> Using the plugin stops the struts2-jquery plugin working.  Can the JavaTemplateEngine be modified to call the default template engine (ftl) if it cannot find a plugin java template.
> Here are the changes needed to the JavaTemplateEngine.java to get it to work.
> Cheers Greg
> {code:java}
> package org.apache.struts2.views.java;
> import org.apache.struts2.StrutsException;
> import org.apache.struts2.components.template.BaseTemplateEngine;
> import org.apache.struts2.components.template.Template;
> import org.apache.struts2.components.template.TemplateEngine;
> import org.apache.struts2.components.template.TemplateEngineManager;
> import org.apache.struts2.components.template.TemplateRenderingContext;
> import org.apache.struts2.views.java.simple.SimpleTheme;
> import java.util.HashMap;
> import java.util.StringTokenizer;
> import com.opensymphony.xwork2.util.logging.LoggerFactory;
> import com.opensymphony.xwork2.util.logging.Logger;
> import com.opensymphony.xwork2.util.ClassLoaderUtil;
> import com.opensymphony.xwork2.config.ConfigurationException;
> import com.opensymphony.xwork2.inject.Inject;
> /**
>  * Template engine that renders tags using java implementations
>  */
> public class JavaTemplateEngine extends BaseTemplateEngine {
> 	private static final Logger LOG = LoggerFactory
> 			.getLogger(JavaTemplateEngine.class);
> 	// The struts template engine manager
> 	protected TemplateEngineManager templateEngineManager;
> 	// The struts default template type. If struts ever changes this will need
> 	// updating.
> 	private String defaultTemplateType = "ftl";
> 	@Inject
> 	public void setTemplateEngineManager(TemplateEngineManager mgr) {
> 		this.templateEngineManager = mgr;
> 	}
> 	private Themes themes = new Themes() {
> 		{
> 			add(new SimpleTheme());
> 		}
> 	};
> 	@Override
> 	protected String getSuffix() {
> 		return "java";
> 	}
> 	public void renderTemplate(TemplateRenderingContext templateContext)
> 			throws Exception {
> 		Template t = templateContext.getTemplate();
> 		Theme theme = themes.get(t.getTheme());
> 		if (theme == null) {
> 			// Theme not supported, so do what struts would have done if we were
> 			// not here.
> 			if (LOG.isDebugEnabled()) {
> 				LOG.debug("Theme not found " + t.getTheme()
> 						+ "trying default templete engine using template type "
> 						+ defaultTemplateType);
> 			}
> 			final TemplateEngine engine = templateEngineManager
> 					.getTemplateEngine(templateContext.getTemplate(),
> 							defaultTemplateType);
> 			if (engine == null) {
> 				// May be the default template has changed?
> 				throw new ConfigurationException(
> 						"Unable to find a TemplateEngine for template type '"
> 								+ defaultTemplateType
> 								+ "' whilst trying to render template "
> 								+ templateContext.getTemplate());
> 			} else {
> 				try {
> 					// Retry render
> 					engine.renderTemplate(templateContext);
> 				} catch (Exception e) {
> 					// Give up and throw a new StrutsException(e);
> 					throw new StrutsException("Cannot render tag ["
> 							+ t.getName() + "] because theme [" + t.getTheme()
> 							+ "] was not found.");
> 				}
> 			}
> 		} else {
> 			// Render our template
> 			theme.renderTag(t.getName(), templateContext);
> 		}
> 	}
> 	private class Themes {
> 		private HashMap<String, Theme> themes = new HashMap<String, Theme>();
> 		public void add(Theme theme) {
> 			themes.put(theme.getName(), theme);
> 		}
> 		public Theme get(String name) {
> 			return themes.get(name);
> 		}
> 	}
> 	/**
> 	 * Allows for providing custom theme classes (implementations of the
> 	 * org.apache.struts2.views.java.Theme) interface for custom rendering of
> 	 * tags using the javatemplates engine
> 	 * 
> 	 * @param themeClasses
> 	 *            a comma delimited list of custom theme class names
> 	 */
> 	@Inject(value = "struts.javatemplates.customThemes", required = false)
> 	public void setThemeClasses(String themeClasses) {
> 		StringTokenizer customThemes = new StringTokenizer(themeClasses, ",");
> 		while (customThemes.hasMoreTokens()) {
> 			String themeClass = customThemes.nextToken().trim();
> 			try {
> 				if (LOG.isInfoEnabled()) {
> 					LOG.info("Registering custom theme '" + themeClass
> 							+ "' to javatemplates engine");
> 				}
> 				// FIXME: This means Themes must have no-arg constructor -
> 				// should use object factory here
> 				// ObjectFactory.getObjectFactory().buildBean(ClassLoaderUtil.loadClass(themeClass,
> 				// getClass()), null);
> 				themes.add((Theme) ClassLoaderUtil.loadClass(themeClass,
> 						getClass()).newInstance());
> 			} catch (ClassCastException cce) {
> 				LOG.error("Invalid java them class '"
> 						+ themeClass
> 						+ "'. Class does not implement 'org.apache.struts2.views.java.Theme' interface");
> 			} catch (ClassNotFoundException cnf) {
> 				LOG.error("Invalid java theme class '" + themeClass
> 						+ "'. Class not found");
> 			} catch (Exception e) {
> 				LOG.error("Could not find messages file " + themeClass
> 						+ ".properties. Skipping");
> 			}
> 		}
> 	}
> 	/**
> 	 * Allows for providing an alternative default struts theme. Will default to
> 	 * "ftl" otherwise.
> 	 * 
> 	 * @param defaultTemplateTheme
> 	 *            the struts default theme
> 	 */
> 	@Inject(value = "struts.javatemplates.defaultTemplateType", required = false)
> 	public void setDefaultTemplateType(String type) {
> 		// Make sure we don't set ourself as default for race condition
> 		if (type != null && !type.equalsIgnoreCase(getSuffix())) {
> 			this.defaultTemplateType = type.toLowerCase();
> 		} else {
> 			LOG.error("Invalid struts.javatemplates.defaultTemplateType value.  Cannot be "
> 					+ getSuffix());
> 		}
> 	}
> }
> {code}

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira