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

com.holonplatform.vaadin.components.builders.ComponentBuilder 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 java.util.function.BiConsumer;
import java.util.function.Consumer;

import com.vaadin.ui.AbstractComponent;
import com.vaadin.ui.Component;
import com.vaadin.ui.dnd.DragSourceExtension;
import com.vaadin.ui.dnd.DropTargetExtension;

/**
 * Base builder to create {@link Component}s.
 * 
 * @param  Concrete component type
 * @param  Concrete builder type
 * 
 * @since 5.0.0
 */
public interface ComponentBuilder>
		extends ComponentConfigurator {

	/**
	 * Makes the component a drag source. The provided configurator can be used to configure the drag
	 * source using {@link DragSourceExtension}, allowing for example to set the drag effect, to set the transferred
	 * data or to register drag start/end listeners.
	 * @param configurator Consumer to configure the drag source
	 * @return this
	 * @since 5.0.6
	 */
	B dragSource(Consumer> configurator);

	/**
	 * Makes the component a drop target. The provided configurator can be used to configure the drop
	 * target behaviour using {@link DragSourceExtension}, allowing for example to control when the drop is acceptable
	 * and then react to the drop event.
	 * @param configurator BiConsumer to configure the drop target, providing also the component that will be built by
	 *        this builder
	 * @return this
	 * @since 5.0.6
	 */
	B dropTarget(BiConsumer, C> configurator);

	/**
	 * Instructs the builder to resolve any message localization (for example component caption and description) only
	 * after the component is attached to parent layout. By default, localization is performed immediately during
	 * component building.
	 * @return this
	 */
	B deferLocalization();

	/**
	 * Build and returns the component
	 * @return Component instance
	 */
	C build();

}