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

org.thymeleaf.expression.Numbers Maven / Gradle / Ivy

/*
 * =============================================================================
 *
 *   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.expression;

import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Locale;
import java.util.Set;

import org.thymeleaf.exceptions.TemplateProcessingException;
import org.thymeleaf.util.NumberPointType;
import org.thymeleaf.util.NumberUtils;


/**
 * 

* Expression Object for performing numeric operations (esp. number formatting) inside Thymeleaf Standard Expressions. *

*

* An object of this class is usually available in variable evaluation expressions with the name * {@code #numbers}. *

* * @author Daniel Fernández * * @since 1.0 * */ public final class Numbers { private final Locale locale; public Numbers(final Locale locale) { super(); this.locale = locale; } public String formatInteger(final Number target, final Integer minIntegerDigits) { if (target == null) { return null; } try { return NumberUtils.format(target, minIntegerDigits, this.locale); } catch (final Exception e) { throw new TemplateProcessingException( "Error formatting integer with minimum integer digits = " + minIntegerDigits, e); } } public String[] arrayFormatInteger(final Object[] target, final Integer minIntegerDigits) { if (target == null) { return null; } final String[] result = new String[target.length]; for (int i = 0; i < target.length; i++) { result[i] = formatInteger((Number)target[i], minIntegerDigits); } return result; } public List listFormatInteger(final List target, final Integer minIntegerDigits) { if (target == null) { return null; } final List result = new ArrayList(target.size() + 2); for (final Number element : target) { result.add(formatInteger(element, minIntegerDigits)); } return result; } public Set setFormatInteger(final Set target, final Integer minIntegerDigits) { if (target == null) { return null; } final Set result = new LinkedHashSet(target.size() + 2); for (final Number element : target) { result.add(formatInteger(element, minIntegerDigits)); } return result; } public String formatInteger(final Number target, final Integer minIntegerDigits, final String thousandsPointType) { if (target == null) { return null; } final NumberPointType thousandsNumberPointType = NumberPointType.match(thousandsPointType); if (thousandsNumberPointType == null) { throw new TemplateProcessingException( "Unrecognized point format \"" + thousandsPointType + "\""); } try { return NumberUtils.format(target, minIntegerDigits, thousandsNumberPointType, this.locale); } catch (final Exception e) { throw new TemplateProcessingException( "Error formatting integer with minimum integer digits = " + minIntegerDigits + " and thousands point type = " + thousandsPointType, e); } } public String[] arrayFormatInteger(final Object[] target, final Integer minIntegerDigits, final String thousandsPointType) { if (target == null) { return null; } final String[] result = new String[target.length]; for (int i = 0; i < target.length; i++) { result[i] = formatInteger((Number)target[i], minIntegerDigits, thousandsPointType); } return result; } public List listFormatInteger(final List target, final Integer minIntegerDigits, final String thousandsPointType) { if (target == null) { return null; } final List result = new ArrayList(target.size() + 2); for (final Number element : target) { result.add(formatInteger(element, minIntegerDigits, thousandsPointType)); } return result; } public Set setFormatInteger(final Set target, final Integer minIntegerDigits, final String thousandsPointType) { if (target == null) { return null; } final Set result = new LinkedHashSet(target.size() + 2); for (final Number element : target) { result.add(formatInteger(element, minIntegerDigits, thousandsPointType)); } return result; } public String formatDecimal(final Number target, final Integer minIntegerDigits, final Integer decimalDigits) { if (target == null) { return null; } try { return NumberUtils.format(target, minIntegerDigits, decimalDigits, this.locale); } catch (final Exception e) { throw new TemplateProcessingException( "Error formatting decimal with minimum integer digits = " + minIntegerDigits + " and decimal digits " + decimalDigits, e); } } public String[] arrayFormatDecimal(final Object[] target, final Integer minIntegerDigits, final Integer decimalDigits) { if (target == null) { return null; } final String[] result = new String[target.length]; for (int i = 0; i < target.length; i++) { result[i] = formatDecimal((Number)target[i], minIntegerDigits, decimalDigits); } return result; } public List listFormatDecimal(final List target, final Integer minIntegerDigits, final Integer decimalDigits) { if (target == null) { return null; } final List result = new ArrayList(target.size() + 2); for (final Number element : target) { result.add(formatDecimal(element, minIntegerDigits, decimalDigits)); } return result; } public Set setFormatDecimal(final Set target, final Integer minIntegerDigits, final Integer decimalDigits) { if (target == null) { return null; } final Set result = new LinkedHashSet(target.size() + 2); for (final Number element : target) { result.add(formatDecimal(element, minIntegerDigits, decimalDigits)); } return result; } public String formatDecimal(final Number target, final Integer minIntegerDigits, final Integer decimalDigits, final String decimalPointType) { if (target == null) { return null; } final NumberPointType decimalNumberPointType = NumberPointType.match(decimalPointType); if (decimalNumberPointType == null) { throw new TemplateProcessingException( "Unrecognized point format \"" + decimalPointType + "\""); } try { return NumberUtils.format(target, minIntegerDigits, decimalDigits, decimalNumberPointType, this.locale); } catch (final Exception e) { throw new TemplateProcessingException( "Error formatting decimal with minimum integer digits = " + minIntegerDigits + ", decimal digits = " + decimalDigits + " and decimal point type = " + decimalPointType, e); } } public String[] arrayFormatDecimal(final Object[] target, final Integer minIntegerDigits, final Integer decimalDigits, final String decimalPointType) { if (target == null) { return null; } final String[] result = new String[target.length]; for (int i = 0; i < target.length; i++) { result[i] = formatDecimal((Number)target[i], minIntegerDigits, decimalDigits, decimalPointType); } return result; } public List listFormatDecimal(final List target, final Integer minIntegerDigits, final Integer decimalDigits, final String decimalPointType) { if (target == null) { return null; } final List result = new ArrayList(target.size() + 2); for (final Number element : target) { result.add(formatDecimal(element, minIntegerDigits, decimalDigits, decimalPointType)); } return result; } public Set setFormatDecimal(final Set target, final Integer minIntegerDigits, final Integer decimalDigits, final String decimalPointType) { if (target == null) { return null; } final Set result = new LinkedHashSet(target.size() + 2); for (final Number element : target) { result.add(formatDecimal(element, minIntegerDigits, decimalDigits, decimalPointType)); } return result; } public String formatDecimal(final Number target, final Integer minIntegerDigits, final String thousandsPointType, final Integer decimalDigits, final String decimalPointType) { if (target == null) { return null; } final NumberPointType decimalNumberPointType = NumberPointType.match(decimalPointType); if (decimalNumberPointType == null) { throw new TemplateProcessingException( "Unrecognized point format \"" + decimalPointType + "\""); } final NumberPointType thousandsNumberPointType = NumberPointType.match(thousandsPointType); if (thousandsNumberPointType == null) { throw new TemplateProcessingException( "Unrecognized point format \"" + thousandsPointType + "\""); } try { return NumberUtils.format(target, minIntegerDigits, thousandsNumberPointType, decimalDigits, decimalNumberPointType, this.locale); } catch (final Exception e) { throw new TemplateProcessingException( "Error formatting decimal with minimum integer digits = " + minIntegerDigits + ", thousands point type = " + thousandsPointType + ", decimal digits = " + decimalDigits + " and decimal point type = " + decimalPointType, e); } } public String[] arrayFormatDecimal(final Object[] target, final Integer minIntegerDigits, final String thousandsPointType, final Integer decimalDigits, final String decimalPointType) { if (target == null) { return null; } final String[] result = new String[target.length]; for (int i = 0; i < target.length; i++) { result[i] = formatDecimal((Number)target[i], minIntegerDigits, thousandsPointType, decimalDigits, decimalPointType); } return result; } public List listFormatDecimal(final List target, final Integer minIntegerDigits, final String thousandsPointType, final Integer decimalDigits, final String decimalPointType) { if (target == null) { return null; } final List result = new ArrayList(target.size() + 2); for (final Number element : target) { result.add(formatDecimal(element, minIntegerDigits, thousandsPointType, decimalDigits, decimalPointType)); } return result; } public Set setFormatDecimal(final Set target, final Integer minIntegerDigits, final String thousandsPointType, final Integer decimalDigits, final String decimalPointType) { if (target == null) { return null; } final Set result = new LinkedHashSet(target.size() + 2); for (final Number element : target) { result.add(formatDecimal(element, minIntegerDigits, thousandsPointType, decimalDigits, decimalPointType)); } return result; } public String formatCurrency(final Number target) { if (target == null) { return null; } try { return NumberUtils.formatCurrency(target, this.locale); } catch (final Exception e) { throw new TemplateProcessingException("Error formatting currency", e); } } public String[] arrayFormatCurrency(final Object[] target) { if (target == null) { return null; } final String[] result = new String[target.length]; for (int i = 0; i < target.length; i++) { result[i] = formatCurrency((Number) target[i]); } return result; } public List listFormatCurrency(final List target) { if (target == null) { return null; } final List result = new ArrayList(target.size() + 2); for (final Number element : target) { result.add(formatCurrency(element)); } return result; } public Set setFormatCurrency(final Set target) { if (target == null) { return null; } final Set result = new LinkedHashSet(target.size() + 2); for (final Number element : target) { result.add(formatCurrency(element)); } return result; } public String formatPercent(final Number target, final Integer minIntegerDigits, final Integer decimalDigits) { if (target == null) { return null; } try { return NumberUtils.formatPercent(target, minIntegerDigits, decimalDigits, this.locale); } catch (final Exception e) { throw new TemplateProcessingException("Error formatting percent", e); } } public String[] arrayFormatPercent(final Object[] target, final Integer minIntegerDigits, final Integer decimalDigits) { if (target == null) { return null; } final String[] result = new String[target.length]; for (int i = 0; i < target.length; i++) { result[i] = formatPercent((Number) target[i], minIntegerDigits, decimalDigits); } return result; } public List listFormatPercent(final List target, final Integer minIntegerDigits, final Integer decimalDigits) { if (target == null) { return null; } final List result = new ArrayList(target.size() + 2); for (final Number element : target) { result.add(formatPercent(element, minIntegerDigits, decimalDigits)); } return result; } public Set setFormatPercent(final Set target, final Integer minIntegerDigits, final Integer decimalDigits) { if (target == null) { return null; } final Set result = new LinkedHashSet(target.size() + 2); for (final Number element : target) { result.add(formatPercent(element, minIntegerDigits, decimalDigits)); } return result; } /** *

* Produces an array with a sequence of integer numbers. *

* * @param from value to start the sequence from * @param to value to produce the sequence to * @return the Integer[] sequence * * @since 1.1.2 */ public Integer[] sequence(final Integer from, final Integer to) { return NumberUtils.sequence(from, to); } /** *

* Produces an array with a sequence of integer numbers, using the * specified step. *

* * @param from value to start the sequence from * @param to value to produce the sequence to * @param step the step to be used * @return the Integer[] sequence * * @since 2.0.9 */ public Integer[] sequence(final Integer from, final Integer to, final Integer step) { return NumberUtils.sequence(from, to, step); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy