com.holonplatform.vaadin.internal.converters.StringToNumberConverter Maven / Gradle / Ivy
/*
* Copyright 2016-2017 Axioma srl.
*
* 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 com.holonplatform.vaadin.internal.converters;
import java.text.NumberFormat;
import java.util.Locale;
import com.holonplatform.core.Context;
import com.holonplatform.core.i18n.LocalizationContext;
import com.holonplatform.core.internal.utils.ConversionUtils;
import com.holonplatform.core.internal.utils.TypeUtils;
import com.vaadin.data.Converter;
import com.vaadin.data.Result;
import com.vaadin.data.ValueContext;
/**
* A {@link Converter}s that convert from {@link Number} types to {@link String} and back.
*
* The String value is trimmed before conversion. Null or empty String values will be converted into null
* Number values.
*
*
* The {@link NumberFormat} to use for conversion is retrieved from {@link LocalizationContext}, if available as
* {@link Context} resource. If a {@link LocalizationContext} is not available, default Number formats for current
* Locale are used.
*
*
* @param Number type
*
* @since 5.0.0
*/
public class StringToNumberConverter implements Converter {
private static final long serialVersionUID = 2952012087662607453L;
/**
* Number type
*/
private final Class extends T> numberType;
/**
* The number format to use
*/
private NumberFormat numberFormat;
/**
* Constructor
* @param numberType Number type
*/
public StringToNumberConverter(Class extends T> numberType) {
super();
this.numberType = numberType;
}
/**
* Sets a fixed NumberFormat to use for value conversions
* @param numberFormat the NumberFormat to set
*/
public void setNumberFormat(NumberFormat numberFormat) {
this.numberFormat = numberFormat;
}
/**
* Gets the NumberFormat to use to convert values
* @param locale Locale to use
* @return the numberFormat If a NumberFormat was specified using {@link #setNumberFormat(NumberFormat)}, this one
* is returned. Otherwise, a NumberFormat is obtained using given Locale
*/
public NumberFormat getNumberFormat(Locale locale) {
Locale lcl = (locale != null) ? locale
: LocalizationContext.getCurrent().filter(l -> l.isLocalized()).flatMap(l -> l.getLocale())
.orElse(Locale.getDefault());
return (numberFormat != null) ? numberFormat
: TypeUtils.isDecimalNumber(numberType) ? NumberFormat.getNumberInstance(lcl)
: NumberFormat.getIntegerInstance(lcl);
}
/*
* (non-Javadoc)
* @see com.vaadin.data.Converter#convertToModel(java.lang.Object, com.vaadin.data.ValueContext)
*/
@Override
public Result convertToModel(String value, ValueContext context) {
if (value != null && !value.trim().equals("")) {
try {
return Result.ok(ConversionUtils.convertNumberToTargetClass(
getNumberFormat(context.getLocale().orElse(null)).parse(value.trim()), numberType));
} catch (@SuppressWarnings("unused") Exception e) {
return Result.error("Could not convert '" + value + "' to " + numberType.getName());
}
}
return Result.ok(null);
}
/*
* (non-Javadoc)
* @see com.vaadin.data.Converter#convertToPresentation(java.lang.Object, com.vaadin.data.ValueContext)
*/
@Override
public String convertToPresentation(T value, ValueContext context) {
if (value != null) {
return getNumberFormat(context.getLocale().orElse(null)).format(value);
}
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy