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

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

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.Date;

import com.holonplatform.core.internal.utils.ObjectUtils;
import com.holonplatform.core.property.Property;
import com.holonplatform.core.property.PropertyBox;
import com.holonplatform.core.property.PropertySet;
import com.holonplatform.vaadin.components.ComposableComponent.Composer;
import com.holonplatform.vaadin.components.Dialog.DialogBuilder;
import com.holonplatform.vaadin.components.Dialog.QuestionDialogBuilder;
import com.holonplatform.vaadin.components.PropertyInputForm.PropertyInputFormBuilder;
import com.holonplatform.vaadin.components.PropertyInputGroup.PropertyInputGroupBuilder;
import com.holonplatform.vaadin.components.PropertyViewForm.PropertyViewFormBuilder;
import com.holonplatform.vaadin.components.PropertyViewGroup.PropertyViewGroupBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectInputBuilder.RenderingMode;
import com.holonplatform.vaadin.components.builders.BaseSelectModeMultiPropertySelectInputBuilder.OptionsModeMultiPropertySelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeMultiPropertySelectInputBuilder.SelectModeMultiPropertySelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeMultiSelectInputBuilder.OptionsModeMultiSelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeMultiSelectInputBuilder.SelectModeMultiSelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeSinglePropertySelectInputBuilder.NativeModeSinglePropertySelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeSinglePropertySelectInputBuilder.OptionsModeSinglePropertySelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeSinglePropertySelectInputBuilder.SelectModeSinglePropertySelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeSingleSelectInputBuilder.NativeModeSingleSelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeSingleSelectInputBuilder.OptionsModeSingleSelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BaseSelectModeSingleSelectInputBuilder.SelectModeSingleSelectInputBuilder;
import com.holonplatform.vaadin.components.builders.BooleanInputBuilder;
import com.holonplatform.vaadin.components.builders.ButtonBuilder;
import com.holonplatform.vaadin.components.builders.ButtonConfigurator;
import com.holonplatform.vaadin.components.builders.ButtonConfigurator.BaseButtonConfigurator;
import com.holonplatform.vaadin.components.builders.ClickableLayoutConfigurator;
import com.holonplatform.vaadin.components.builders.ClickableLayoutConfigurator.BaseClickableLayoutConfigurator;
import com.holonplatform.vaadin.components.builders.ComponentConfigurator;
import com.holonplatform.vaadin.components.builders.ComponentConfigurator.BaseComponentConfigurator;
import com.holonplatform.vaadin.components.builders.CssLayoutBuilder;
import com.holonplatform.vaadin.components.builders.DateInputBuilder;
import com.holonplatform.vaadin.components.builders.DateInputBuilder.Resolution;
import com.holonplatform.vaadin.components.builders.FormLayoutBuilder;
import com.holonplatform.vaadin.components.builders.GridLayoutBuilder;
import com.holonplatform.vaadin.components.builders.HorizontalLayoutBuilder;
import com.holonplatform.vaadin.components.builders.InputConfigurator;
import com.holonplatform.vaadin.components.builders.InputConfigurator.BaseFieldConfigurator;
import com.holonplatform.vaadin.components.builders.ItemListingBuilder.GridItemListingBuilder;
import com.holonplatform.vaadin.components.builders.LabelBuilder;
import com.holonplatform.vaadin.components.builders.LayoutConfigurator;
import com.holonplatform.vaadin.components.builders.LayoutConfigurator.BaseLayoutConfigurator;
import com.holonplatform.vaadin.components.builders.MultiPropertySelectInputBuilder.GenericMultiPropertySelectInputBuilder;
import com.holonplatform.vaadin.components.builders.MultiSelectInputBuilder.GenericMultiSelectInputBuilder;
import com.holonplatform.vaadin.components.builders.NumberInputBuilder;
import com.holonplatform.vaadin.components.builders.OrderedLayoutConfigurator;
import com.holonplatform.vaadin.components.builders.OrderedLayoutConfigurator.BaseOrderedLayoutConfigurator;
import com.holonplatform.vaadin.components.builders.PanelBuilder;
import com.holonplatform.vaadin.components.builders.PropertyListingBuilder.GridPropertyListingBuilder;
import com.holonplatform.vaadin.components.builders.SecretInputBuilder;
import com.holonplatform.vaadin.components.builders.SinglePropertySelectInputBuilder.GenericSinglePropertySelectInputBuilder;
import com.holonplatform.vaadin.components.builders.SingleSelectInputBuilder.GenericSingleSelectInputBuilder;
import com.holonplatform.vaadin.components.builders.StringInputBuilder;
import com.holonplatform.vaadin.components.builders.TabsBuilder;
import com.holonplatform.vaadin.components.builders.TemporalInputBuilder.TemporalWithTimeFieldBuilder;
import com.holonplatform.vaadin.components.builders.TemporalInputBuilder.TemporalWithoutTimeFieldBuilder;
import com.holonplatform.vaadin.components.builders.VerticalLayoutBuilder;
import com.holonplatform.vaadin.components.builders.ViewComponentBuilder;
import com.holonplatform.vaadin.internal.components.BooleanField;
import com.holonplatform.vaadin.internal.components.DateField;
import com.holonplatform.vaadin.internal.components.DateTimeField;
import com.holonplatform.vaadin.internal.components.DefaultPropertyViewGroup;
import com.holonplatform.vaadin.internal.components.Filler;
import com.holonplatform.vaadin.internal.components.LocalDateField;
import com.holonplatform.vaadin.internal.components.LocalDateTimeField;
import com.holonplatform.vaadin.internal.components.NumberField;
import com.holonplatform.vaadin.internal.components.SecretField;
import com.holonplatform.vaadin.internal.components.StringArea;
import com.holonplatform.vaadin.internal.components.StringField;
import com.holonplatform.vaadin.internal.components.builders.AccordionBuilder;
import com.holonplatform.vaadin.internal.components.builders.DefaultButtonBuilder;
import com.holonplatform.vaadin.internal.components.builders.DefaultButtonConfigurator;
import com.holonplatform.vaadin.internal.components.builders.DefaultClickableLayoutConfigurator;
import com.holonplatform.vaadin.internal.components.builders.DefaultComponentConfigurator;
import com.holonplatform.vaadin.internal.components.builders.DefaultCssLayoutBuilder;
import com.holonplatform.vaadin.internal.components.builders.DefaultFieldConfigurator;
import com.holonplatform.vaadin.internal.components.builders.DefaultFormLayoutBuilder;
import com.holonplatform.vaadin.internal.components.builders.DefaultGridLayoutBuilder;
import com.holonplatform.vaadin.internal.components.builders.DefaultHorizontalLayoutBuilder;
import com.holonplatform.vaadin.internal.components.builders.DefaultLabelBuilder;
import com.holonplatform.vaadin.internal.components.builders.DefaultLayoutConfigurator;
import com.holonplatform.vaadin.internal.components.builders.DefaultOrderedLayoutConfigurator;
import com.holonplatform.vaadin.internal.components.builders.DefaultPanelBuilder;
import com.holonplatform.vaadin.internal.components.builders.DefaultVerticalLayoutBuilder;
import com.holonplatform.vaadin.internal.components.builders.TabSheetBuilder;
import com.vaadin.ui.AbsoluteLayout;
import com.vaadin.ui.AbstractComponent;
import com.vaadin.ui.AbstractField;
import com.vaadin.ui.Accordion;
import com.vaadin.ui.Button;
import com.vaadin.ui.Component;
import com.vaadin.ui.CssLayout;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.GridLayout;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TabSheet;
import com.vaadin.ui.VerticalLayout;

/**
 * Main provider of UI components builders and configurators.
 * 

* Provides static methods to obtain builder for common UI components type, allowing fluent and implementation-agnostic * components creation and configuration. *

* * @since 5.0.0 */ public interface Components { /** * CSS style name to render a Component as scrollable */ public static final String SCROLLABLE_STYLENAME = "v-scrollable"; // Configurators /** * Get a {@link ComponentConfigurator} to configure given component. * @param component Component to configure (not null) * @return BaseComponentConfigurator */ static BaseComponentConfigurator configure(AbstractComponent component) { return new DefaultComponentConfigurator(component); } /** * Get a {@link ButtonConfigurator} to configure given button. * @param button Button to configure (not null) * @return BaseButtonConfigurator */ static BaseButtonConfigurator configure(Button button) { return new DefaultButtonConfigurator(button); } /** * Get a {@link InputConfigurator} to configure given field. * @param Field type * @param field Field to configure (not null) * @return BaseFieldConfigurator */ static BaseFieldConfigurator configure(AbstractField field) { return new DefaultFieldConfigurator<>(field); } /** * Get a {@link OrderedLayoutConfigurator} to configure given layout. * @param layout Layout to configure * @return Layout configurator */ static BaseOrderedLayoutConfigurator configure(VerticalLayout layout) { return new DefaultOrderedLayoutConfigurator<>(layout); } /** * Get a {@link OrderedLayoutConfigurator} to configure given layout. * @param layout Layout to configure * @return Layout configurator */ static BaseOrderedLayoutConfigurator configure(HorizontalLayout layout) { return new DefaultOrderedLayoutConfigurator<>(layout); } /** * Get a {@link OrderedLayoutConfigurator} to configure given layout. * @param layout Layout to configure * @return Layout configurator */ static BaseOrderedLayoutConfigurator configure(FormLayout layout) { return new DefaultOrderedLayoutConfigurator<>(layout); } /** * Get a {@link LayoutConfigurator} to configure given layout. * @param layout Layout to configure * @return Layout configurator */ static BaseLayoutConfigurator configure(GridLayout layout) { return new DefaultLayoutConfigurator<>(layout); } /** * Get a {@link ClickableLayoutConfigurator} to configure given layout. * @param layout Layout to configure * @return Layout configurator */ static BaseClickableLayoutConfigurator configure(CssLayout layout) { return new DefaultClickableLayoutConfigurator<>(layout); } /** * Get a {@link ClickableLayoutConfigurator} to configure given layout. * @param layout Layout to configure * @return Layout configurator */ static BaseClickableLayoutConfigurator configure(AbsoluteLayout layout) { return new DefaultClickableLayoutConfigurator<>(layout); } // Builders /** * Build a filler component, i.e. a {@link Label} with undefined size and the HTML entity   as * content, which can be used with full expand ratio as a space filler in layouts. * @return Filler */ static Component filler() { return new Filler(); } /** * Gets a builder to create {@link Label}s. *

* The Label is of undefined size by default. *

* @return Label builder */ static LabelBuilder label() { return new DefaultLabelBuilder(); } /** * Gets a builder to create {@link Button}s. * @return Button builder */ static ButtonBuilder button() { return button(false); } /** * Gets a builder to create {@link Button}s * @param nativeMode true to create a "native" button, i.e. implemented using the native button of web * browsers, using the HTML <button> element. * @return Button builder */ static ButtonBuilder button(boolean nativeMode) { return new DefaultButtonBuilder(nativeMode); } /** * Gets a builder to create {@link CssLayout}s. * @return CssLayout builder */ static CssLayoutBuilder cssLayout() { return new DefaultCssLayoutBuilder(); } /** * Gets a builder to create {@link FormLayout}s. * @return FormLayout builder */ static FormLayoutBuilder formLayout() { return new DefaultFormLayoutBuilder(); } /** * Gets a builder to create {@link FormLayout}s. * @return FormLayout builder */ static GridLayoutBuilder gridLayout() { return gridLayout(1, 1); } /** * Gets a builder to create {@link GridLayout}s. * @param columns Initial number of columns * @param rows Initial number of rows * @return GridLayout builder */ static GridLayoutBuilder gridLayout(int columns, int rows) { return new DefaultGridLayoutBuilder(columns, rows); } /** * Gets a builder to create {@link HorizontalLayout}s. * @return HorizontalLayout builder */ static HorizontalLayoutBuilder hl() { return new DefaultHorizontalLayoutBuilder(); } /** * Gets a builder to create {@link VerticalLayout}s. * @return VerticalLayout builder */ static VerticalLayoutBuilder vl() { return new DefaultVerticalLayoutBuilder(); } /** * Gets a builder to create {@link Panel}s. * @return Panel builder */ static PanelBuilder panel() { return new DefaultPanelBuilder(); } /** * Gets a builder to create a {@link TabSheet}. * @return TabSheet builder */ static TabsBuilder tabSheet() { return new TabSheetBuilder(); } /** * Gets a builder to create an {@link Accordion}. * @return Accordion builder */ static TabsBuilder accordion() { return new AccordionBuilder(); } /** * Gets a builder to create and open a {@link Dialog} window. The dialog will present by default a single * ok button. * @return DialogBuilder */ static DialogBuilder dialog() { return Dialog.builder(); } /** * Gets a builder to create and open a question {@link Dialog} window. The dialog will present by default a * yes and a no button. Use * {@link QuestionDialogBuilder#callback(com.holonplatform.vaadin.components.Dialog.QuestionCallback)} to handle the * user selected answer. * @return QuestionDialogBuilder */ static QuestionDialogBuilder questionDialog() { return Dialog.question(); } // Inputs /** * {@link Input}, {@link PropertyInputGroup} and {@link PropertyInputForm} builders provider. */ static interface input { /** * Gets a builder to create {@link String} type {@link Input}s. * @return Input builder */ static StringInputBuilder string() { return string(false); } /** * Gets a builder to create {@link String} type {@link Input}s. * @param area true to create an input component rendered as a text area, * false for a standard text input * @return Input builder */ static StringInputBuilder string(boolean area) { return area ? new StringArea.Builder() : new StringField.Builder(); } /** * Gets a builder to create {@link String} type {@link Input}s which not display user input on screen, used to * enter secret text information like passwords. * @return Input builder */ static SecretInputBuilder secretString() { return new SecretField.Builder(); } /** * Gets a builder to create {@link Number} type {@link Input}s. * @param Number type * @param numberClass Concrete number class * @return Input builder */ static NumberInputBuilder number(Class numberClass) { return new NumberField.Builder<>(numberClass); } /** * Gets a builder to create {@link Boolean} type {@link Input}s. * @return Input builder */ static BooleanInputBuilder boolean_() { return new BooleanField.Builder(); } /** * Gets a builder to create {@link Date} type {@link Input}s. * @param resolution field Resolution * @param inline true to render the input component using an inline calendar * @return Input builder */ static DateInputBuilder date(Resolution resolution, boolean inline) { ObjectUtils.argumentNotNull(resolution, "Resolution must be not null"); return resolution.isTime() ? new DateTimeField.Builder(resolution, inline) : new DateField.Builder(resolution, inline); } /** * Gets a builder to create {@link Date} type {@link Input}s. * @param resolution field Resolution * @return Input builder */ static DateInputBuilder date(Resolution resolution) { return date(resolution, false); } /** * Gets a builder to create {@link Date} type {@link Input}s. * @param inline true to render the input component using an inline calendar * @return Input builder */ static DateInputBuilder date(boolean inline) { return date(Resolution.DAY, inline); } /** * Gets a builder to create {@link Date} type {@link Input}s. * @return Input builder */ static DateInputBuilder date() { return date(Resolution.DAY, false); } /** * Gets a builder to create {@link LocalDate} type {@link Input}s. * @param inline true to render the input component using an inline calendar * @return Input builder */ static TemporalWithoutTimeFieldBuilder localDate(boolean inline) { return new LocalDateField.Builder(inline); } /** * Gets a builder to create {@link LocalDate} type {@link Input}s. * @return Input builder */ static TemporalWithoutTimeFieldBuilder localDate() { return localDate(false); } /** * Gets a builder to create {@link LocalDateTime} type {@link Input}s. * @param inline true to render the input component using an inline calendar * @return Input builder */ static TemporalWithTimeFieldBuilder localDateTime(boolean inline) { return new LocalDateTimeField.Builder(inline); } /** * Gets a builder to create {@link LocalDateTime} type {@link Input}s. * @return Input builder */ static TemporalWithTimeFieldBuilder localDateTime() { return localDateTime(false); } /** * Gets a builder to create a single selection {@link Input}. * @param Selection value type * @param type Selection value type * @param renderingMode Rendering mode * @return Input builder */ static GenericSingleSelectInputBuilder singleSelect(Class type, RenderingMode renderingMode) { return SingleSelect.builder(type, renderingMode); } /** * Gets a builder to create a single selection {@link Input} using {@link RenderingMode#SELECT}. * @param Selection value type * @param type Selection value type * @return Input builder */ static SelectModeSingleSelectInputBuilder singleSelect(Class type) { return SingleSelect.select(type); } /** * Gets a builder to create a single selection {@link Input} using {@link RenderingMode#NATIVE_SELECT}. * @param Selection value type * @param type Selection value type * @return Input builder */ static NativeModeSingleSelectInputBuilder singleNativeSelect(Class type) { return SingleSelect.nativeSelect(type); } /** * Gets a builder to create a single selection {@link Input} using {@link RenderingMode#OPTIONS}. * @param Selection value type * @param type Selection value type * @return Input builder */ static OptionsModeSingleSelectInputBuilder singleOptionSelect(Class type) { return SingleSelect.options(type); } /** * Gets a builder to create a {@link SingleSelect} with a {@link PropertyBox} items data source with * {@link Property} as item properties. * @param Selection value type * @param selectProperty Property to select (not null) * @param renderingMode Rendering mode * @return {@link SingleSelect} builder */ static GenericSinglePropertySelectInputBuilder singleSelect(Property selectProperty, RenderingMode renderingMode) { return SingleSelect.property(selectProperty, renderingMode); } /** * Gets a builder to create a {@link SingleSelect} with a {@link PropertyBox} items data source with * {@link Property} as item properties using {@link RenderingMode#SELECT}. * @param Selection value type * @param selectProperty Property to select (not null) * @return {@link SingleSelect} builder */ static SelectModeSinglePropertySelectInputBuilder singleSelect(Property selectProperty) { return SingleSelect.select(selectProperty); } /** * Gets a builder to create a {@link SingleSelect} with a {@link PropertyBox} items data source with * {@link Property} as item properties using {@link RenderingMode#NATIVE_SELECT}. * @param Selection value type * @param selectProperty Property to select (not null) * @return {@link SingleSelect} builder */ static NativeModeSinglePropertySelectInputBuilder singleNativeSelect(Property selectProperty) { return SingleSelect.nativeSelect(selectProperty); } /** * Gets a builder to create a {@link SingleSelect} with a {@link PropertyBox} items data source with * {@link Property} as item properties using {@link RenderingMode#OPTIONS}. * @param Selection value type * @param selectProperty Property to select (not null) * @return {@link SingleSelect} builder */ static OptionsModeSinglePropertySelectInputBuilder singleOptionSelect(Property selectProperty) { return SingleSelect.options(selectProperty); } /** * Gets a builder to create a multiple selection {@link Input}. * @param Selection value type * @param type Selection value type * @param renderingMode Rendering mode * @return Input builder */ static GenericMultiSelectInputBuilder multiSelect(Class type, RenderingMode renderingMode) { return MultiSelect.builder(type, renderingMode); } /** * Gets a builder to create a multiple selection {@link Input} using default {@link RenderingMode#OPTIONS}. * @param Selection value type * @param type Selection value type * @return Input builder */ static OptionsModeMultiSelectInputBuilder multiSelect(Class type) { return MultiSelect.options(type); } /** * Gets a builder to create a multiple selection {@link Input} using {@link RenderingMode#SELECT}. * @param Selection value type * @param type Selection value type * @return Input builder */ static SelectModeMultiSelectInputBuilder multiSelectList(Class type) { return MultiSelect.list(type); } /** * Gets a builder to create a {@link MultiSelect} with a {@link PropertyBox} items data source with * {@link Property} as item properties. * @param Selection value type * @param selectProperty Property to select (not null) * @param renderingMode Rendering mode * @return {@link MultiSelect} builder */ static GenericMultiPropertySelectInputBuilder multiSelect(Property selectProperty, RenderingMode renderingMode) { return MultiSelect.property(selectProperty, renderingMode); } /** * Gets a builder to create a {@link MultiSelect} with a {@link PropertyBox} items data source with * {@link Property} as item properties using default {@link RenderingMode#OPTIONS}. * @param Selection value type * @param selectProperty Property to select (not null) * @return {@link MultiSelect} builder */ static OptionsModeMultiPropertySelectInputBuilder multiSelect(Property selectProperty) { return MultiSelect.options(selectProperty); } /** * Gets a builder to create a {@link MultiSelect} with a {@link PropertyBox} items data source with * {@link Property} as item properties using default {@link RenderingMode#SELECT}. * @param Selection value type * @param selectProperty Property to select (not null) * @return {@link MultiSelect} builder */ static SelectModeMultiPropertySelectInputBuilder multiSelectList(Property selectProperty) { return MultiSelect.list(selectProperty); } /** * Gets a builder to create a single selection {@link Input} with given {@link Enum} class as data source, using * all enum constants as selection items. * @param Enum value type * @param type Enum value type * @param renderingMode Rendering mode * @return Input builder */ static > GenericSingleSelectInputBuilder enumSingle(Class type, RenderingMode renderingMode) { return singleSelect(type, renderingMode).items(type.getEnumConstants()); } /** * Gets a builder to create a single selection {@link Input} with given {@link Enum} class as data source, using * all enum constants as selection items and default {@link RenderingMode#SELECT} rendering mode. * @param Enum value type * @param type Enum value type * @return Input builder */ static > SelectModeSingleSelectInputBuilder enumSingle(Class type) { return singleSelect(type).items(type.getEnumConstants()); } /** * Gets a builder to create a multiple selection {@link Input} with given {@link Enum} class as data source, * using all enum constants as selection items. * @param Enum value type * @param type Enum value type * @param renderingMode Rendering mode * @return Input builder */ static > GenericMultiSelectInputBuilder enumMulti(Class type, RenderingMode renderingMode) { return multiSelect(type, renderingMode).items(type.getEnumConstants()); } /** * Gets a builder to create a multiple selection {@link Input} with given {@link Enum} class as data source, * using all enum constants as selection items and default {@link RenderingMode#OPTIONS} rendering mode. * @param Enum value type * @param type Enum value type * @return Input builder */ static > OptionsModeMultiSelectInputBuilder enumMulti(Class type) { return multiSelect(type).items(type.getEnumConstants()); } /** * Gets a builder to create a {@link PropertyInputGroup}. * @return {@link PropertyInputGroup} builder */ static PropertyInputGroupBuilder propertyGroup() { return PropertyInputGroup.builder(); } /** * Gets a builder to create a {@link PropertyInputForm}. * @param Content type * @param content Form content, where fields will be composed by the form {@link Composer} (not null) * @return {@link PropertyInputForm} builder */ static PropertyInputFormBuilder form(C content) { return PropertyInputForm.builder(content); } /** * Gets a builder to create a {@link PropertyInputForm} using a {@link FormLayout} as layout component and a * default {@link PropertyInputForm#componentContainerComposer()} to compose the fields on layout. * @return {@link PropertyInputForm} builder */ static PropertyInputFormBuilder form() { return PropertyInputForm.builder(formLayout().fullWidth().spacing().build()) .composer(ComposableComponent.componentContainerComposer()); } /** * Gets a builder to create a {@link PropertyInputForm} using a {@link VerticalLayout} as layout component and a * default {@link PropertyInputForm#componentContainerComposer()} to compose the fields on layout. * @return {@link PropertyInputForm} builder */ static PropertyInputFormBuilder formVertical() { return PropertyInputForm.builder(vl().fullWidth().build()) .composer(ComposableComponent.componentContainerComposer()); } /** * Gets a builder to create a {@link PropertyInputForm} using a {@link HorizontalLayout} as layout component and * a default {@link PropertyInputForm#componentContainerComposer()} to compose the fields on layout. * @return {@link PropertyInputForm} builder */ static PropertyInputFormBuilder formHorizontal() { return PropertyInputForm.builder(hl().build()).composer(ComposableComponent.componentContainerComposer()); } /** * Gets a builder to create a {@link PropertyInputForm} using a {@link VerticalLayout} as layout component and a * default {@link PropertyInputForm#componentContainerComposer()} to compose the fields on layout. * @return {@link PropertyInputForm} builder */ static PropertyInputFormBuilder formGrid() { return PropertyInputForm.builder(gridLayout().fullWidth().build()) .composer(ComposableComponent.componentContainerComposer()); } } // View components /** * {@link ViewComponent} and {@link PropertyViewGroup} builders provider. */ static interface view { /** * Gets a builder to create a {@link ViewComponent} instance. * @param Value type * @param valueType the value type handled by the {@link ViewComponent} * @return {@link ViewComponent} builder */ static ViewComponentBuilder component(Class valueType) { return ViewComponent.builder(valueType); } /** * Get a builder to create and setup a {@link PropertyViewGroup}. * @return {@link PropertyViewGroup} builder */ static PropertyViewGroupBuilder propertyGroup() { return new DefaultPropertyViewGroup.DefaultBuilder(); } /** * Gets a builder to create a {@link PropertyViewForm}. * @param Content type * @param content Form content, where view components will be composed by the form {@link Composer} (not null) * @return {@link PropertyViewForm} builder */ static PropertyViewFormBuilder form(C content) { return PropertyViewForm.builder(content); } /** * Gets a builder to create a {@link PropertyViewForm} using a {@link FormLayout} as layout component and a * default {@link PropertyViewForm#componentContainerComposer()} to compose the view components on layout. * @return {@link PropertyViewForm} builder */ static PropertyViewFormBuilder form() { return PropertyViewForm.builder(formLayout().build()) .composer(ComposableComponent.componentContainerComposer()); } /** * Gets a builder to create a {@link PropertyViewForm} using a {@link VerticalLayout} as layout component and a * default {@link PropertyViewForm#componentContainerComposer()} to compose the view components on layout. * @return {@link PropertyViewForm} builder */ static PropertyViewFormBuilder formVertical() { return PropertyViewForm.builder(vl().build()).composer(ComposableComponent.componentContainerComposer()); } /** * Gets a builder to create a {@link PropertyViewForm} using a {@link HorizontalLayout} as layout component and * a default {@link PropertyViewForm#componentContainerComposer()} to compose the view components on layout. * @return {@link PropertyViewForm} builder */ static PropertyViewFormBuilder formHorizontal() { return PropertyViewForm.builder(hl().build()).composer(ComposableComponent.componentContainerComposer()); } /** * Gets a builder to create a {@link PropertyViewForm} using a {@link VerticalLayout} as layout component and a * default {@link PropertyViewForm#componentContainerComposer()} to compose the view components on layout. * @return {@link PropertyViewForm} builder */ static PropertyViewFormBuilder formGrid() { return PropertyViewForm.builder(gridLayout().build()) .composer(ComposableComponent.componentContainerComposer()); } } // Item listings /** * {@link ItemListing} builders provider. */ static interface listing { /** * Builder to create an {@link ItemListing} instance using a {@link Grid} as backing component. * @param Item data type * @param itemType Item bean type * @return Grid {@link ItemListing} builder */ static GridItemListingBuilder items(Class itemType) { return BeanListing.builder(itemType); } /** * Builder to create an {@link PropertyListing} instance using a {@link Grid} as backing component. * @param

Actual property type * @param properties The property set to use for the listing * @return Grid {@link PropertyListing} builder */ @SafeVarargs static

> GridPropertyListingBuilder properties(P... properties) { return properties(PropertySet.of(properties)); } /** * Builder to create an {@link PropertyListing} instance using a {@link Grid} as backing component. * @param

Actual property type * @param properties The property set to use for the listing * @return Grid {@link PropertyListing} builder */ static

> GridPropertyListingBuilder properties(Iterable

properties) { return PropertyListing.builder(properties); } /** * Builder to create an {@link PropertyListing} instance using a {@link Grid} as backing component. * @param

Actual property type * @param properties The property set to use for the listing (not null) * @param additionalProperties Additional properties to declare * @return Grid {@link PropertyListing} builder */ @SafeVarargs @SuppressWarnings("rawtypes") static

GridPropertyListingBuilder properties(PropertySet properties, P... additionalProperties) { ObjectUtils.argumentNotNull(properties, "Properties must be not null"); if (additionalProperties != null && additionalProperties.length > 0) { PropertySet.Builder builder = PropertySet.builder().add(properties); for (P property : additionalProperties) { builder.add(property); } return PropertyListing.builder(builder.build()); } return PropertyListing.builder(properties); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy