X-Git-Url: https://juplo.de/gitweb/?p=juplo-dialect;a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fthymeleaf%2FActiveElementProcessor.java;fp=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fthymeleaf%2FActiveElementProcessor.java;h=0000000000000000000000000000000000000000;hp=46725e199803bb520dd7813ab18e817203901274;hb=815df4f032e0cfdef9857f711420c772f9e2c0d5;hpb=8f5433b0625ba08b380ba757ee6b090945f8cf2c diff --git a/src/main/java/de/juplo/thymeleaf/ActiveElementProcessor.java b/src/main/java/de/juplo/thymeleaf/ActiveElementProcessor.java deleted file mode 100644 index 46725e1..0000000 --- a/src/main/java/de/juplo/thymeleaf/ActiveElementProcessor.java +++ /dev/null @@ -1,98 +0,0 @@ -package de.juplo.thymeleaf; - - -import org.thymeleaf.Arguments; -import org.thymeleaf.Configuration; -import org.thymeleaf.dom.Element; -import org.thymeleaf.dom.Node; -import org.thymeleaf.processor.AbstractProcessor; -import org.thymeleaf.processor.IProcessorMatcher; -import org.thymeleaf.processor.ProcessorMatchingContext; -import org.thymeleaf.processor.ProcessorResult; -import org.thymeleaf.processor.AttributeNameProcessorMatcher; -import org.thymeleaf.standard.expression.IStandardExpression; -import org.thymeleaf.standard.expression.IStandardExpressionParser; -import org.thymeleaf.standard.expression.StandardExpressions; - - -/** - * Replaces the element by the tag <strong>, if it is - * marked as active. - * @author Kai Moritz - */ -public class ActiveElementProcessor extends AbstractProcessor -{ - private final AttributeNameProcessorMatcher matcher = - new AttributeNameProcessorMatcher("active"); - - - @Override - public IProcessorMatcher getMatcher() - { - return matcher; - } - - @Override - protected ProcessorResult doProcess( - Arguments arguments, - ProcessorMatchingContext context, - Node node - ) - { - // Because of the type of applicability being used, casts to Element here will not fail - final Element element = (Element) node; - final String[] names = this.matcher.getAttributeNames(context); - - for (final String name : names) - { - if (element.hasNormalizedAttribute(name)) - { - Configuration configuration = arguments.getConfiguration(); - IStandardExpressionParser parser = - StandardExpressions.getExpressionParser(configuration); - String value = element.getAttributeValue(name); - IStandardExpression expression = - parser.parseExpression(configuration, arguments, value); - element.removeAttribute(name); - if ((Boolean)expression.execute(configuration, arguments)) - { - // We must not clone the processors, because we remove attributes - Element strong = - element.cloneElementNodeWithNewName(element, "strong", false); - strong.removeAttribute("charset"); - strong.removeAttribute("th:charset"); - strong.removeAttribute("coords"); - strong.removeAttribute("href"); - strong.removeAttribute("th:href"); - strong.removeAttribute("hreflang"); - strong.removeAttribute("th:hreflang"); - strong.removeAttribute("media"); - strong.removeAttribute("th:media"); - strong.removeAttribute("name"); - strong.removeAttribute("th:name"); - strong.removeAttribute("rel"); - strong.removeAttribute("th:rel"); - strong.removeAttribute("ref"); - strong.removeAttribute("th:ref"); - strong.removeAttribute("shape"); - strong.removeAttribute("target"); - strong.removeAttribute("th:target"); - strong.removeAttribute("type"); - strong.removeAttribute("th:type"); - element.clearChildren(); - element.addChild(strong); - element.getParent().extractChild(element); - } - break; - } - } - return ProcessorResult.OK; - } - - @Override - public int getPrecedence() - { - // Be sure to be executed first - return 0; - } -}