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

com.holonplatform.vaadin.components.builders.ComponentConfigurator 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.components.builders;

import com.holonplatform.core.Context;
import com.holonplatform.core.i18n.Localizable;
import com.holonplatform.core.i18n.LocalizationContext;
import com.holonplatform.vaadin.internal.components.builders.DefaultComponentConfigurator;
import com.vaadin.event.ContextClickEvent.ContextClickListener;
import com.vaadin.event.ShortcutListener;
import com.vaadin.server.ClientConnector.AttachListener;
import com.vaadin.server.ClientConnector.DetachListener;
import com.vaadin.server.ErrorHandler;
import com.vaadin.server.Resource;
import com.vaadin.server.Sizeable.Unit;
import com.vaadin.ui.AbstractComponent;
import com.vaadin.ui.Component;

/**
 * Interface to configure a {@link Component}.
 * 
 * @param  Concrete configurator type
 * 
 * @since 5.0.0
 */
public interface ComponentConfigurator> {

	/**
	 * Sets the width of the object. Negative number implies unspecified size.
	 * @param width The width of the component
	 * @param unit The unit used for the width
	 * @return this
	 */
	B width(float width, Unit unit);

	/**
	 * Sets the width of the component using String presentation.
	 * 

* String presentation is similar to what is used in Cascading Style Sheets. Size can be length or percentage of * available size. *

*

* The empty string ("") or null will unset the width and set the units to pixels. *

* @param width Width in CSS style string representation. * @return this */ B width(String width); /** * Sets the height of the object. Negative number implies unspecified size. * @param height The height of the component * @param unit The unit used for the height * @return this */ B height(float height, Unit unit); /** * Sets the height of the component using String presentation. *

* String presentation is similar to what is used in Cascading Style Sheets. Size can be length or percentage of * available size. *

*

* The empty string ("") or null will unset the height and set the units to pixels. *

* @param height Height in CSS style string representation. * @return this */ B height(String height); /** * Set the component width to 100% * @return this */ B fullWidth(); /** * Set the component heigth to 100% * @return this */ B fullHeight(); /** * Set the component width and heigth to 100% * @return this */ B fullSize(); /** * Clears any defined width * @return this */ B widthUndefined(); /** * Clears any defined height * @return this */ B heightUndefined(); /** * Clears any size settings * @return this */ B sizeUndefined(); /** * Adds one or more style names to this component. Multiple styles can be specified as a space-separated list of * style names. The style name will be rendered as a HTML class name, which can be used in a CSS definition. *

* Each style name will occur in two versions: one as specified and one that is prefixed with the style name of the * component. *

* @param styleName The new style to be added to the component * @return this */ B styleName(String styleName); /** * Sets one or more user-defined style names of the component, replacing any previous user-defined styles. Multiple * styles can be specified as a space-separated list of style names. The style names must be valid CSS class names * and should not conflict with any built-in style names in Vaadin or GWT. *

* Each style name will occur in two versions: one as specified and one that is prefixed with the style name of the * component. *

* @param styleName The new style or styles of the component as a space-separated list * @return this */ B replaceStyleName(String styleName); /** * Changes the primary style name of the component. *

* The primary style name identifies the component when applying the CSS theme to the Component. By changing the * style name all CSS rules targeted for that style name will no longer apply, and might result in the component not * working as intended. *

* @param style The new primary style name * @return this */ B primaryStyleName(String style); /** * Disables the component. The user can not interact with disabled components, which are shown with a style that * indicates the status, usually shaded in light gray color. * @return this */ B disabled(); /** * Sets the components as not visible. * @return this */ B notVisible(); /** * Set the component as not visible. *

* Invisible components are not drawn in the user interface. The effect is not merely a cosmetic CSS change - no * information about an invisible component will be sent to the client. The effect is thus the same as removing the * component from its parent. *

* @return this */ B hidden(); /** * Sets the caption rendered as HTML. *

* When the captions are rendered in the browser as HTML, the developer is responsible for ensuring no harmful HTML * is used. *

* @return this */ B captionAsHtml(); /** * Sets the caption of the component. *

* A caption is an explanatory textual label accompanying a user interface component, usually shown above, * left of, or inside the component. *

* @param caption The new caption for the component. If the caption is null, no caption is shown * @return this */ default B caption(String caption) { return caption(Localizable.builder().message(caption).build()); } /** * Sets the caption of the component using a localizable messageCode. *

* For caption localization, a {@link LocalizationContext} must be available and localized as {@link Context} * resource when component is built. *

* @param defaultCaption Default caption if no translation is available for given messageCode for * current Locale, or no {@link LocalizationContext} is available at all * @param messageCode Caption translation message key * @param arguments Optional translation arguments * @return this */ default B caption(String defaultCaption, String messageCode, Object... arguments) { return caption(Localizable.builder().message(defaultCaption).messageCode(messageCode) .messageArguments(arguments).build()); } /** * Sets the caption of the component 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 caption Caption {@link Localizable} message * @return this */ B caption(Localizable caption); /** * Sets the component's description. *

* The description is displayed as HTML in tooltips or directly in certain components so care should be taken to * avoid creating the possibility for HTML injection and possibly XSS vulnerabilities. *

* @param description The description to set * @return this */ default B description(String description) { return description(Localizable.builder().message(description).build()); } /** * Sets the component's description using a localizable messageCode. *

* For description localization, a {@link LocalizationContext} must be available and localized as {@link Context} * resource when component is built. *

* @param defaultDescription Default description if no translation is available for given messageCode * for current Locale, or no {@link LocalizationContext} is available at all * @param messageCode Description translation message key * @param arguments Optional translation arguments * @return this */ default B description(String defaultDescription, String messageCode, Object... arguments) { return description(Localizable.builder().message(defaultDescription).messageCode(messageCode) .messageArguments(arguments).build()); } /** * Sets the component's description using a {@link Localizable} message. *

* For description localization, a {@link LocalizationContext} must be available and localized as {@link Context} * resource when component is built. *

* @param description Description {@link Localizable} message * @return this */ B description(Localizable description); /** * Sets the icon of the component. *

* An icon is an explanatory graphical label accompanying a user interface component, usually shown above, left of, * or inside the component. Icon is closely related to caption and is usually displayed horizontally before or after * it, depending on the component and the containing layout. *

* @param icon The icon of the component. If null, no icon is shown. * @return this */ B icon(Resource icon); /** * Adds an unique id for component that is used in the client-side for testing purposes. Keeping identifiers unique * is the responsibility of the programmer. * @param id An alphanumeric id * @return this */ B id(String id); /** * Sets the error handler for the component. *

* The error handler is dispatched whenever there is an error processing the data coming from the client for this * component. *

* @param errorHandler The error handler for this component * @return this */ B errorHandler(ErrorHandler errorHandler); /** * Sets the data object, that can be used for any application specific data. The component does not use or modify * this data. * @param data The Application specific data. * @return this */ B withData(Object data); /** * Enables responsiveness for this component * @return this */ B responsive(); /** * Add an {@link AttachListener} to the component, called after the component is attached to the application. * @param listener Listener to add * @return this */ B withAttachListener(AttachListener listener); /** * Add an {@link DetachListener} to the component, called before the component is detached from the application. * @param listener Listener to add * @return this */ B withDetachListener(DetachListener listener); /** * Add a {@link ShortcutListener} to this component * @param shortcut ShortcutListener to add * @return this */ B withShortcutListener(ShortcutListener shortcut); /** * Add a {@link ContextClickListener} to this component, that gets notified when a context click happens. * @param listener ContextClickListener to add * @return this */ B withContextClickListener(ContextClickListener listener); /** * Base component configurator. */ public interface BaseComponentConfigurator extends ComponentConfigurator { /** * Create a new {@link BaseComponentConfigurator} on given component. * @param component Component to configure (not null) * @return A new {@link BaseComponentConfigurator} to configure given component */ static BaseComponentConfigurator create(AbstractComponent component) { return new DefaultComponentConfigurator(component); } } }