com.holonplatform.vaadin.components.builders.CalendarInputBuilder 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.components.builders;
import java.util.Calendar;
import java.util.TimeZone;
import com.holonplatform.core.Context;
import com.holonplatform.core.i18n.Localizable;
import com.holonplatform.core.i18n.LocalizationContext;
import com.holonplatform.vaadin.components.Input;
/**
* An builder to create {@link Input}s rendered as a calendar (inline or in a popup activated by a button) in UI.
*
* @param Value type
* @param Concrete builder type
*
* @since 5.0.0
*/
public interface CalendarInputBuilder> extends InputBuilder, B> {
/**
* Sets date format to use for internal component date display.
* @param dateFormat the dateFormat to set
* @return this
*/
B dateFormat(String dateFormat);
/**
* Sets the default error message used if the DateField cannot parse the text input by user to a Date field.
* @param parsingErrorMessage Parse error message
* @return this
*/
B parseErrorMessage(String parsingErrorMessage);
/**
* Sets the default error message used if the DateField cannot parse the text input by user to a Date field, using a
* localizable messageCode
.
*
* For message localization, a {@link LocalizationContext} must be available and localized as {@link Context}
* resource when component is built.
*
* @param defaultParseErrorMessage Default error message if no translation is available for given
* messageCode
for current Locale.
* @param messageCode Parse error message translation message key
* @param arguments Optional translation arguments
* @return this
*/
B parseErrorMessage(String defaultParseErrorMessage, String messageCode, Object... arguments);
/**
* Sets the default error message used if the DateField cannot parse the text input by user to a Date field, using a
* {@link Localizable} message.
*
* For message localization, a {@link LocalizationContext} must be available and localized as {@link Context}
* resource when component is built.
*
* @param parseErrorMessage Localizable error message
* @return this
*/
B parseErrorMessage(Localizable parseErrorMessage);
/**
* Specifies whether or not date/time interpretation in component is to be lenient.
* @see Calendar#setLenient(boolean)
* @param lenient true if the lenient mode is to be turned on; false if it is to be turned off.
* @return this
*/
B lenient(boolean lenient);
/**
* Sets the visibility of ISO 8601 week numbers in the date selector. ISO 8601 defines that a week always starts
* with a Monday so the week numbers are only shown if this is the case.
* @param showWeekNumbers true if week numbers should be shown, false otherwise.
* @return this
*/
B showISOWeekNumbers(boolean showWeekNumbers);
/**
* Sets the time zone used by this date field. The time zone is used to convert the absolute time in a Date object
* to a logical time displayed in the selector and to convert the select time back to a Date object. If no time zone
* has been set, the current default time zone is used.
* @param timeZone the time zone to use for time calculations.
* @return this
*/
B timeZone(TimeZone timeZone);
/**
* Sets the start range for this component. If the value is set before this date/time, the component will not
* validate. If start
is set to null
, any value before end range will be accepted by the
* range.
* @param start the allowed range's start date/time (inclusive)
* @return this
*/
B rangeStart(T start);
/**
* Sets the end range for this component. If the value is set after this date/time, the component will not validate.
* If end
is set to null
, any value after start range will be accepted by the range.
* @param end the allowed range's end date (inclusive)
* @return this
*/
B rangeEnd(T end);
/**
* Sets the error message to notify if the range validation fails.
* @param dateOutOfRangeMessage Localizable message which is shown when value (the date) is set outside allowed
* range
* @return this
*/
B dateOutOfRangeMessage(String dateOutOfRangeMessage);
/**
* Sets the error message to notify if the range validation fails, using a localizable messageCode
.
*
* For caption localization, a {@link LocalizationContext} must be available and localized as {@link Context}
* resource when component is built.
*
* @param defaultDateOutOfRangeMessage Default error message if no translation is available for given
* messageCode
for current Locale.
* @param messageCode Date out of range message translation message key
* @param arguments Optional translation arguments
* @return this
*/
B dateOutOfRangeMessage(String defaultDateOutOfRangeMessage, String messageCode, Object... arguments);
/**
* Sets the error message to notify if the range validation fails, using a {@link Localizable} message.
*
* For caption localization, a {@link LocalizationContext} must be available and localized as {@link Context}
* resource when component is built.
*
* @param dateOutOfRangeMessage Localizable error message
* @return this
*/
B dateOutOfRangeMessage(Localizable dateOutOfRangeMessage);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy