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

com.holonplatform.vaadin.internal.converters.StringToNumberConverter Maven / Gradle / Ivy

There is a newer version: 5.4.0
Show newest version
/*
 * 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 numberType; /** * The number format to use */ private NumberFormat numberFormat; /** * Constructor * @param numberType Number type */ public StringToNumberConverter(Class 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