All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.thymeleaf.spring4.dialect.SpringStandardDialect Maven / Gradle / Ivy

There is a newer version: 3.0.15.RELEASE
Show newest version
/*
 * =============================================================================
 *
 *   Copyright (c) 2011-2018, The THYMELEAF team (http://www.thymeleaf.org)
 *
 *   Licensed under the Apache License, Version 2.0 (the "License");
 *   you may not use this file except in compliance with the License.
 *   You may obtain a copy of the License at
 *
 *       http://www.apache.org/licenses/LICENSE-2.0
 *
 *   Unless required by applicable law or agreed to in writing, software
 *   distributed under the License is distributed on an "AS IS" BASIS,
 *   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *   See the License for the specific language governing permissions and
 *   limitations under the License.
 *
 * =============================================================================
 */
package org.thymeleaf.spring4.dialect;

import java.util.LinkedHashSet;
import java.util.Map;
import java.util.Set;

import org.thymeleaf.expression.IExpressionObjectFactory;
import org.thymeleaf.processor.IProcessor;
import org.thymeleaf.spring4.expression.SPELVariableExpressionEvaluator;
import org.thymeleaf.spring4.expression.SpringStandardConversionService;
import org.thymeleaf.spring4.expression.SpringStandardExpressionObjectFactory;
import org.thymeleaf.spring4.expression.SpringStandardExpressions;
import org.thymeleaf.spring4.processor.SpringActionTagProcessor;
import org.thymeleaf.spring4.processor.SpringErrorClassTagProcessor;
import org.thymeleaf.spring4.processor.SpringErrorsTagProcessor;
import org.thymeleaf.spring4.processor.SpringHrefTagProcessor;
import org.thymeleaf.spring4.processor.SpringInputCheckboxFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringInputFileFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringInputGeneralFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringInputPasswordFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringInputRadioFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringMethodTagProcessor;
import org.thymeleaf.spring4.processor.SpringObjectTagProcessor;
import org.thymeleaf.spring4.processor.SpringOptionFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringOptionInSelectFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringSelectFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringSrcTagProcessor;
import org.thymeleaf.spring4.processor.SpringTextareaFieldTagProcessor;
import org.thymeleaf.spring4.processor.SpringTranslationDocTypeProcessor;
import org.thymeleaf.spring4.processor.SpringUErrorsTagProcessor;
import org.thymeleaf.spring4.processor.SpringValueTagProcessor;
import org.thymeleaf.standard.StandardDialect;
import org.thymeleaf.standard.expression.IStandardConversionService;
import org.thymeleaf.standard.expression.IStandardVariableExpressionEvaluator;
import org.thymeleaf.standard.processor.StandardActionTagProcessor;
import org.thymeleaf.standard.processor.StandardHrefTagProcessor;
import org.thymeleaf.standard.processor.StandardMethodTagProcessor;
import org.thymeleaf.standard.processor.StandardObjectTagProcessor;
import org.thymeleaf.standard.processor.StandardSrcTagProcessor;
import org.thymeleaf.standard.processor.StandardValueTagProcessor;
import org.thymeleaf.templatemode.TemplateMode;

/**
 * 

* SpringStandard Dialect. This is the class containing the implementation of Thymeleaf Standard Dialect, including all * {@code th:*} processors, expression objects, etc. for Spring-enabled environments. *

*

* Note this dialect uses SpringEL as an expression language and adds some Spring-specific * features on top of {@link StandardDialect}, like {@code th:field} or Spring-related expression objects. *

*

* The usual and recommended way of using this dialect is by instancing {@link org.thymeleaf.spring4.SpringTemplateEngine} * instead of {@link org.thymeleaf.TemplateEngine}. The former will automatically add this dialect and perform * some specific configuration like e.g. Spring-integrated message resolution. *

*

* Note a class with this name existed since 1.0, but it was completely reimplemented * in Thymeleaf 3.0 *

* * @author Daniel Fernández * * @since 3.0.0 * */ public class SpringStandardDialect extends StandardDialect { public static final String NAME = "SpringStandard"; public static final String PREFIX = "th"; public static final int PROCESSOR_PRECEDENCE = 1000; public static final boolean DEFAULT_ENABLE_SPRING_EL_COMPILER = false; public static final boolean DEFAULT_RENDER_HIDDEN_MARKERS_BEFORE_CHECKBOXES = false; private boolean enableSpringELCompiler = DEFAULT_ENABLE_SPRING_EL_COMPILER; private boolean renderHiddenMarkersBeforeCheckboxes = DEFAULT_RENDER_HIDDEN_MARKERS_BEFORE_CHECKBOXES; // These variables will be initialized lazily following the model applied in the extended StandardDialect. private IExpressionObjectFactory expressionObjectFactory = null; private IStandardConversionService conversionService = null; public SpringStandardDialect() { super(NAME, PREFIX, PROCESSOR_PRECEDENCE); } /** *

* Returns whether the SpringEL compiler should be enabled in SpringEL expressions or not. *

*

* Expression compilation can significantly improve the performance of Spring EL expressions, but * might not be adequate for every environment. Read * the * official Spring documentation for more detail. *

*

* Also note that although Spring includes a SpEL compiler since Spring 4.1, most expressions * in Thymeleaf templates will only be able to properly benefit from this compilation step when at least * Spring Framework version 4.2.4 is used. *

*

* This flag is set to {@code false} by default. *

* * @return {@code true} if SpEL expressions should be compiled if possible, {@code false} if not. */ public boolean getEnableSpringELCompiler() { return enableSpringELCompiler; } /** *

* Sets whether the SpringEL compiler should be enabled in SpringEL expressions or not. *

*

* Expression compilation can significantly improve the performance of Spring EL expressions, but * might not be adequate for every environment. Read * the * official Spring documentation for more detail. *

*

* Also note that although Spring includes a SpEL compiler since Spring 4.1, most expressions * in Thymeleaf templates will only be able to properly benefit from this compilation step when at least * Spring Framework version 4.2.4 is used. *

*

* This flag is set to {@code false} by default. *

* * @param enableSpringELCompiler {@code true} if SpEL expressions should be compiled if possible, {@code false} if not. */ public void setEnableSpringELCompiler(final boolean enableSpringELCompiler) { this.enableSpringELCompiler = enableSpringELCompiler; } /** *

* Returns whether the {@code } marker tags rendered to signal the presence * of checkboxes in forms when unchecked should be rendered before the checkbox tag itself, * or after (default). *

*

* A number of CSS frameworks and style guides assume that the {@code

*

* Note this hidden field is introduced in order to signal the existence of the field in the form being sent, * even if the checkbox is unchecked (no URL parameter is added for unchecked check boxes). *

*

* This flag is set to {@code false} by default. *

* * @return {@code true} if hidden markers should be rendered before the checkboxes, {@code false} if not. * * @since 3.0.10 */ public boolean getRenderHiddenMarkersBeforeCheckboxes() { return this.renderHiddenMarkersBeforeCheckboxes; } /** *

* Sets whether the {@code } marker tags rendered to signal the presence * of checkboxes in forms when unchecked should be rendered before the checkbox tag itself, * or after (default). *

*

* A number of CSS frameworks and style guides assume that the {@code

*

* Note this hidden field is introduced in order to signal the existence of the field in the form being sent, * even if the checkbox is unchecked (no URL parameter is added for unchecked check boxes). *

*

* This flag is set to {@code false} by default. *

* * @param renderHiddenMarkersBeforeCheckboxes {@code true} if hidden markers should be rendered * before the checkboxes, {@code false} if not. * * @since 3.0.10 */ public void setRenderHiddenMarkersBeforeCheckboxes(final boolean renderHiddenMarkersBeforeCheckboxes) { this.renderHiddenMarkersBeforeCheckboxes = renderHiddenMarkersBeforeCheckboxes; } @Override public IStandardVariableExpressionEvaluator getVariableExpressionEvaluator() { return SPELVariableExpressionEvaluator.INSTANCE; } @Override public IStandardConversionService getConversionService() { if (this.conversionService == null) { this.conversionService = new SpringStandardConversionService(); } return this.conversionService; } @Override public IExpressionObjectFactory getExpressionObjectFactory() { if (this.expressionObjectFactory == null) { this.expressionObjectFactory = new SpringStandardExpressionObjectFactory(); } return this.expressionObjectFactory; } @Override public Set getProcessors(final String dialectPrefix) { return createSpringStandardProcessorsSet(dialectPrefix, this.renderHiddenMarkersBeforeCheckboxes); } @Override public Map getExecutionAttributes() { final Map executionAttributes = super.getExecutionAttributes(); executionAttributes.put( SpringStandardExpressions.ENABLE_SPRING_EL_COMPILER_ATTRIBUTE_NAME, Boolean.valueOf(getEnableSpringELCompiler())); return executionAttributes; } /** *

* Create a the set of SpringStandard processors, all of them freshly instanced. *

* * @param dialectPrefix the prefix established for the Standard Dialect, needed for initialization * @return the set of SpringStandard processors. */ public static Set createSpringStandardProcessorsSet(final String dialectPrefix) { return createSpringStandardProcessorsSet(dialectPrefix, DEFAULT_RENDER_HIDDEN_MARKERS_BEFORE_CHECKBOXES); } /** *

* Create a the set of SpringStandard processors, all of them freshly instanced. *

* * @param dialectPrefix the prefix established for the Standard Dialect, needed for initialization * @param renderHiddenMarkersBeforeCheckboxes {@code true} if hidden markers should be rendered * before the checkboxes, {@code false} if not. * * @return the set of SpringStandard processors. * * @since 3.0.10 */ public static Set createSpringStandardProcessorsSet( final String dialectPrefix, final boolean renderHiddenMarkersBeforeCheckboxes) { /* * It is important that we create new instances here because, if there are * several dialects in the TemplateEngine that extend StandardDialect, they should * not be returning the exact same instances for their processors in order * to allow specific instances to be directly linked with their owner dialect. */ final Set standardProcessors = StandardDialect.createStandardProcessorsSet(dialectPrefix); final Set processors = new LinkedHashSet(40); /* * REMOVE STANDARD PROCESSORS THAT WE WILL REPLACE */ for (final IProcessor standardProcessor : standardProcessors) { // There are several processors we need to remove from the Standard Dialect set if (!(standardProcessor instanceof StandardObjectTagProcessor) && !(standardProcessor instanceof StandardActionTagProcessor) && !(standardProcessor instanceof StandardHrefTagProcessor) && !(standardProcessor instanceof StandardMethodTagProcessor) && !(standardProcessor instanceof StandardSrcTagProcessor) && !(standardProcessor instanceof StandardValueTagProcessor)) { processors.add(standardProcessor); } else if (standardProcessor.getTemplateMode() != TemplateMode.HTML) { // We only want to remove from the StandardDialect the HTML versions of the attribute processors processors.add(standardProcessor); } } /* * ATTRIBUTE TAG PROCESSORS */ processors.add(new SpringActionTagProcessor(dialectPrefix)); processors.add(new SpringHrefTagProcessor(dialectPrefix)); processors.add(new SpringMethodTagProcessor(dialectPrefix)); processors.add(new SpringSrcTagProcessor(dialectPrefix)); processors.add(new SpringValueTagProcessor(dialectPrefix)); processors.add(new SpringObjectTagProcessor(dialectPrefix)); processors.add(new SpringErrorsTagProcessor(dialectPrefix)); processors.add(new SpringUErrorsTagProcessor(dialectPrefix)); processors.add(new SpringInputGeneralFieldTagProcessor(dialectPrefix)); processors.add(new SpringInputPasswordFieldTagProcessor(dialectPrefix)); processors.add(new SpringInputCheckboxFieldTagProcessor(dialectPrefix, renderHiddenMarkersBeforeCheckboxes)); processors.add(new SpringInputRadioFieldTagProcessor(dialectPrefix)); processors.add(new SpringInputFileFieldTagProcessor(dialectPrefix)); processors.add(new SpringSelectFieldTagProcessor(dialectPrefix)); processors.add(new SpringOptionInSelectFieldTagProcessor(dialectPrefix)); processors.add(new SpringOptionFieldTagProcessor(dialectPrefix)); processors.add(new SpringTextareaFieldTagProcessor(dialectPrefix)); processors.add(new SpringErrorClassTagProcessor(dialectPrefix)); /* * DOCTYPE PROCESSORS */ processors.add(new SpringTranslationDocTypeProcessor()); return processors; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy