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

com.vaadin.data.converter.StringToLongConverter 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 Long} and back. Uses
 * the given locale and a {@link NumberFormat} instance for formatting and
 * parsing.
 * 

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

* * @author Vaadin Ltd * @since 8.0 */ public class StringToLongConverter 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 StringToLongConverter(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 StringToLongConverter(Long 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 StringToLongConverter(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 StringToLongConverter(Long emptyValue, ErrorMessageProvider errorMessageProvider) { super(emptyValue, errorMessageProvider); } /** * Returns the format used by * {@link #convertToPresentation(Object, ValueContext)} and * {@link #convertToModel(String, ValueContext)}. * * @param locale * The locale to use * @return A NumberFormat instance */ @Override protected NumberFormat getFormat(Locale locale) { if (locale == null) { locale = Locale.getDefault(); } return NumberFormat.getIntegerInstance(locale); } @Override public Result convertToModel(String value, ValueContext context) { Result n = convertToNumber(value, context); return n.map(number -> { if (number == null) { return null; } return number.longValue(); }); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy