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

com.vaadin.data.converter.StringToDoubleConverter Maven / Gradle / Ivy

There is a newer version: 8.27.3
Show newest version
/*
 * Copyright (C) 2000-2024 Vaadin Ltd
 *
 * This program is available under Vaadin Commercial License and Service Terms.
 *
 * See  for the full
 * license.
 */

package com.vaadin.data.converter;

import java.text.NumberFormat;
import java.util.Locale;

import com.vaadin.data.ErrorMessageProvider;
import com.vaadin.data.Result;
import com.vaadin.data.ValueContext;

/**
 * A converter that converts from {@link String} to {@link Double} and back.
 * Uses the given locale and a {@link NumberFormat} instance for formatting and
 * parsing.
 * 

* Leading and trailing white spaces are ignored when converting from a String. *

*

* Override and overwrite {@link #getFormat(Locale)} to use a different format. *

* * @author Vaadin Ltd * @since 8.0 */ public class StringToDoubleConverter extends AbstractStringToNumberConverter { /** * Creates a new converter instance with the given error message. Empty * strings are converted to null. * * @param errorMessage * the error message to use if conversion fails */ public StringToDoubleConverter(String errorMessage) { this(null, errorMessage); } /** * Creates a new converter instance with the given empty string value and * error message. * * @param emptyValue * the presentation value to return when converting an empty * string, may be null * @param errorMessage * the error message to use if conversion fails */ public StringToDoubleConverter(Double emptyValue, String errorMessage) { super(emptyValue, errorMessage); } /** * Creates a new converter instance with the given error message provider. * Empty strings are converted to null. * * @param errorMessageProvider * the error message provider to use if conversion fails * * @since 8.4 */ public StringToDoubleConverter(ErrorMessageProvider errorMessageProvider) { this(null, errorMessageProvider); } /** * Creates a new converter instance with the given empty string value and * error message provider. * * @param emptyValue * the presentation value to return when converting an empty * string, may be null * @param errorMessageProvider * the error message provider to use if conversion fails * * @since 8.4 */ public StringToDoubleConverter(Double emptyValue, ErrorMessageProvider errorMessageProvider) { super(emptyValue, errorMessageProvider); } @Override public Result convertToModel(String value, ValueContext context) { Result n = convertToNumber(value, context); return n.map(number -> { if (number == null) { return null; } return number.doubleValue(); }); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy