TMP
[juplo-dialect] / src / main / java / de / juplo / thymeleaf / ImportVariablesAttrProcessor.java
index e063a0c..bca2b4e 100644 (file)
@@ -16,8 +16,14 @@ import java.util.regex.Pattern;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.thymeleaf.context.IContext;
+import org.thymeleaf.context.ITemplateContext;
+import org.thymeleaf.engine.AttributeName;
+import org.thymeleaf.engine.EngineEventUtils;
 import org.thymeleaf.exceptions.TemplateProcessingException;
+import org.thymeleaf.model.IModel;
+import org.thymeleaf.model.IProcessableElementTag;
 import org.thymeleaf.processor.element.AbstractAttributeModelProcessor;
+import org.thymeleaf.processor.element.IElementModelStructureHandler;
 import org.thymeleaf.standard.expression.IStandardExpression;
 import org.thymeleaf.standard.expression.IStandardExpressionParser;
 import org.thymeleaf.standard.expression.StandardExpressions;
@@ -68,31 +74,28 @@ public class ImportVariablesAttrProcessor extends AbstractAttributeModelProcesso
 
 
   @Override
-  public final ProcessorResult processAttribute(
-      final Arguments arguments,
-      final Element element,
-      final String name
+  protected void doProcess(
+      final ITemplateContext context,
+      final IModel model,
+      final AttributeName attributeName,
+      final String attributeValue,
+      final IElementModelStructureHandler handler
       )
   {
-    Configuration config = arguments.getConfiguration();
-
-    Configuration configuration = arguments.getConfiguration();
-
-    String parameter = element.getAttributeValue(name);
-    try
-    {
-      IStandardExpressionParser parser =
-          StandardExpressions.getExpressionParser(configuration);
-      IStandardExpression expression =
-          parser.parseExpression(configuration, arguments, parameter);
-      parameter = (String)expression.execute(configuration, arguments);
-    }
-    catch (TemplateProcessingException e) { }
+    final IProcessableElementTag element = (IProcessableElementTag) model.get(0);
+    final String parameter =
+        EngineEventUtils.computeAttributeExpression(
+            context,
+            element,
+            attributeName,
+            attributeValue
+            )
+            .execute(context).toString();
 
     if (parameter != null && !parameter.trim().isEmpty())
     {
       LOG.info("ignoring empty parameter");
-      return ProcessorResult.OK;
+      return;
     }
 
     Iterator<Entry<String, Object>> it = null;
@@ -150,13 +153,13 @@ public class ImportVariablesAttrProcessor extends AbstractAttributeModelProcesso
                 }
               });
 
-      for (ITemplateResolver t_resolver : config.getTemplateResolvers())
+      for (ITemplateResolver t_resolver : context.getConfiguration().getTemplateResolvers())
       {
         TemplateResolution resolution = t_resolver.resolveTemplate(params);
         if (resolution == null)
           continue;
-        if (!"JSON".equals(resolution.getTemplateMode()))
-          continue;
+//        if (!"JSON".equals(resolution.getTemplateMode()))
+//          continue;
         IResourceResolver r_resolver = resolution.getResourceResolver();
         InputStream is =
             r_resolver.getResourceAsStream(params, resolution.getResourceName());
@@ -310,11 +313,4 @@ public class ImportVariablesAttrProcessor extends AbstractAttributeModelProcesso
     node.setNodeProperty(PROPERTY_NAME, variables);
     return variables;
   }
-
-
-  @Override
-  public int getPrecedence()
-  {
-    return ATTR_PRECEDENCE;
-  }
 }