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

com.holonplatform.vaadin.components.PropertyValueComponentSource Maven / Gradle / Ivy

There is a newer version: 5.4.0
Show newest version
/*
 * Copyright 2000-2017 Holon TDCN.
 * 
 * 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;

import java.util.Optional;
import java.util.stream.Stream;

import com.holonplatform.core.property.Property;

/**
 * Represent a source of {@link ValueComponent}s bound to a {@link Property} set, i.e. a container of
 * {@link ValueComponent} and {@link Property} bindings.
 *
 * @since 5.0.0
 */
public interface PropertyValueComponentSource extends ComponentSource, PropertySetBound {

	/**
	 * Gets all the {@link ValueComponent}s that have been bound to a property.
	 * @return An {@link Iterable} on all property bound {@link ValueComponent}s
	 */
	@SuppressWarnings("rawtypes")
	Iterable getValueComponents();

	/**
	 * Get the {@link ValueComponent} bound to given property, if any.
	 * @param  Component type
	 * @param property Property for which to get the associated {@link ValueComponent} (not null)
	 * @return Optional {@link ValueComponent} bound to given property
	 */
	 Optional> getValueComponent(Property property);

	/**
	 * Get the {@link ValueComponent} bound to given property, throwing and exception is the component is
	 * not available.
	 * @param  Component type
	 * @param property Property for which to get the associated {@link ValueComponent} (not null)
	 * @return The {@link ValueComponent} bound to given property
	 * @throws IllegalArgumentException If a value component is not available for given property
	 */
	default  ValueComponent requireValueComponent(Property property) {
		return getValueComponent(property).orElseThrow(
				() -> new IllegalArgumentException("No component available for property [" + property + "]"));
	}

	/**
	 * Return a {@link Stream} of the available {@link Property} and {@link ValueComponent}s bindings.
	 * @return Property-ValueComponent {@link PropertyBinding} stream
	 */
	Stream>> streamOfValueComponents();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy