public class CheckboxGroup<T> extends GeneratedVaadinCheckboxGroup<CheckboxGroup<T>,Set<T>> implements HasItemsAndComponents<T>, HasSize, HasValidation, MultiSelect<CheckboxGroup<T>,T>, HasDataProvider<T>
vaadin-checkbox-group
element.
CheckBoxGroup is a multiselection component where items are displayed as check boxes.
GeneratedVaadinCheckboxGroup.InvalidChangeEvent<R extends GeneratedVaadinCheckboxGroup<R,?>>
AbstractField.ComponentValueChangeEvent<C extends Component,V>
HasItemsAndComponents.ItemComponent<T>
HasValue.ValueChangeEvent<V>, HasValue.ValueChangeListener<E extends HasValue.ValueChangeEvent<?>>
Constructor and Description |
---|
CheckboxGroup() |
Modifier and Type | Method and Description |
---|---|
Registration |
addSelectionListener(MultiSelectionListener<CheckboxGroup<T>,T> listener)
Adds a selection listener that will be called when the selection is
changed either by the user or programmatically.
|
DataProvider<T,?> |
getDataProvider()
Gets the data provider.
|
String |
getErrorMessage()
Gets the current error message from the checkbox group.
|
SerializablePredicate<T> |
getItemEnabledProvider()
Returns the item enabled predicate.
|
ItemLabelGenerator<T> |
getItemLabelGenerator()
Gets the item label generator that is used to produce the strings shown
in the checkbox group for each item.
|
String |
getLabel()
Gets the label of the checkbox group.
|
Set<T> |
getSelectedItems()
Returns an immutable set of the currently selected items.
|
protected boolean |
hasValidValue()
Checks whether the element property has a value that can be converted to
the model type.
|
boolean |
isInvalid()
Returns
true if component input is invalid, false
otherwise. |
boolean |
isReadOnly()
Returns whether this
HasValue is in read-only mode or not. |
boolean |
isRequired()
Determines whether the checkbox group is marked as input required.
|
void |
onEnabledStateChanged(boolean enabled)
Handle component enable state when the enabled state changes.
|
void |
setDataProvider(DataProvider<T,?> dataProvider)
Sets the data provider for this listing.
|
void |
setErrorMessage(String errorMessage)
Description copied from corresponding location in WebComponent:
|
void |
setInvalid(boolean invalid)
Description copied from corresponding location in WebComponent:
|
void |
setItemEnabledProvider(SerializablePredicate<T> itemEnabledProvider)
Sets the item enabled predicate for this checkbox group.
|
void |
setItemLabelGenerator(ItemLabelGenerator<T> itemLabelGenerator)
Sets the item label generator that is used to produce the strings shown
in the checkbox group for each item.
|
void |
setLabel(String label)
Description copied from corresponding location in WebComponent:
|
void |
setReadOnly(boolean readOnly)
Sets the read-only mode of this
HasValue to given mode. |
void |
setRequired(boolean required)
Description copied from corresponding location in WebComponent:
|
void |
setValue(Set<T> value)
Sets the value of this component.
|
void |
updateSelection(Set<T> addedItems,
Set<T> removedItems)
Updates the selection by adding and removing the given items from it.
|
protected boolean |
valueEquals(Set<T> value1,
Set<T> value2)
Compares to value instances to each other to determine whether they are
equal.
|
addInvalidChangeListener, addThemeVariants, getErrorMessageString, getLabelString, isDisabledBoolean, isInvalidBoolean, isRequiredBoolean, removeThemeVariants, setDisabled, validate
getSynchronizationRegistration, setPresentationValue, setSynchronizedEvent
addValueChangeListener, getEmptyValue, getValue, isEmpty, setModelValue
addListener, fireEvent, from, get, getChildren, getElement, getEventBus, getId, getLocale, getParent, getTranslation, getTranslation, getUI, hasListener, isTemplateMapped, isVisible, onAttach, onDetach, set, setElement, setId, setVisible
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
addComponents, getItemPosition, prependComponents
add, add, addComponentAsFirst, addComponentAtIndex, remove, removeAll
getHeight, getMaxHeight, getMaxWidth, getMinHeight, getMinWidth, getWidth, setHeight, setHeightFull, setMaxHeight, setMaxWidth, setMinHeight, setMinWidth, setSizeFull, setSizeUndefined, setWidth, setWidthFull
deselect, deselect, deselectAll, getEmptyValue, getValue, isSelected, select, select
isRequiredIndicatorVisible, setRequiredIndicatorVisible
addValueChangeListener, clear, getOptionalValue, isEmpty
isEnabled, setEnabled
setItems
addClassName, addClassNames, getClassName, getClassNames, getStyle, hasClassName, removeClassName, removeClassNames, setClassName, setClassName
addThemeName, addThemeNames, getThemeName, getThemeNames, hasThemeName, removeThemeName, removeThemeNames, setThemeName, setThemeName
addAttachListener
addDetachListener
public void setDataProvider(DataProvider<T,?> dataProvider)
HasDataProvider
setDataProvider
in interface HasDataProvider<T>
dataProvider
- the data provider, not nullpublic void updateSelection(Set<T> addedItems, Set<T> removedItems)
MultiSelect
If all the added items were already selected and the removed items were not selected, this is a NO-OP.
Duplicate items (in both add and remove sets) are ignored.
updateSelection
in interface MultiSelect<CheckboxGroup<T>,T>
addedItems
- the items to add, not null
removedItems
- the items to remove, not null
public void setValue(Set<T> value)
The component doesn't accept null
values. The value of a checkbox
group without any selected items is an empty set. You can use the
HasValue.clear()
method to set the empty value.
setValue
in interface HasValue<AbstractField.ComponentValueChangeEvent<CheckboxGroup<T>,Set<T>>,Set<T>>
setValue
in interface MultiSelect<CheckboxGroup<T>,T>
setValue
in class AbstractField<CheckboxGroup<T>,Set<T>>
value
- the new value to set, not null
NullPointerException
- if value is null
public Set<T> getSelectedItems()
MultiSelect
SelectionModel
methods while iterating over the set.
Implementation note: the iteration order of the items in the returned set should be well-defined and documented by the implementing class.
getSelectedItems
in interface MultiSelect<CheckboxGroup<T>,T>
null
public Registration addSelectionListener(MultiSelectionListener<CheckboxGroup<T>,T> listener)
MultiSelect
addSelectionListener
in interface MultiSelect<CheckboxGroup<T>,T>
listener
- the value change listener, not null
public DataProvider<T,?> getDataProvider()
null
public void onEnabledStateChanged(boolean enabled)
Component
By default this sets or removes the 'disabled' attribute from the element. This can be overridden to have custom handling.
onEnabledStateChanged
in class Component
enabled
- the new enabled state of the componentpublic void setReadOnly(boolean readOnly)
HasValue
HasValue
to given mode. The user
can't change the value when in read-only mode.
A HasValue
with a visual component in read-only mode typically
looks visually different to signal to the user that the value cannot be
edited.
setReadOnly
in interface HasValue<AbstractField.ComponentValueChangeEvent<CheckboxGroup<T>,Set<T>>,Set<T>>
setReadOnly
in interface HasValueAndElement<AbstractField.ComponentValueChangeEvent<CheckboxGroup<T>,Set<T>>,Set<T>>
readOnly
- a boolean value specifying whether the component is put
read-only mode or notpublic boolean isReadOnly()
HasValue
HasValue
is in read-only mode or not.isReadOnly
in interface HasValue<AbstractField.ComponentValueChangeEvent<CheckboxGroup<T>,Set<T>>,Set<T>>
isReadOnly
in interface HasValueAndElement<AbstractField.ComponentValueChangeEvent<CheckboxGroup<T>,Set<T>>,Set<T>>
false
if the user can modify the value, true
if
not.public SerializablePredicate<T> getItemEnabledProvider()
setItemEnabledProvider(com.vaadin.flow.function.SerializablePredicate<T>)
public void setItemEnabledProvider(SerializablePredicate<T> itemEnabledProvider)
true
) or disabled (false
). Disabled items are displayed
as grayed out and the user cannot select them. The default predicate
always returns true (all the items are enabled).itemEnabledProvider
- the item enable predicate, not null
public void setItemLabelGenerator(ItemLabelGenerator<T> itemLabelGenerator)
String.valueOf(Object)
is used.itemLabelGenerator
- the item label provider to use, not nullpublic ItemLabelGenerator<T> getItemLabelGenerator()
public void setLabel(String label)
GeneratedVaadinCheckboxGroup
Description copied from corresponding location in WebComponent:
String used for the label element.
setLabel
in class GeneratedVaadinCheckboxGroup<CheckboxGroup<T>,Set<T>>
label
- the String value to setpublic String getLabel()
label
property of the checkbox grouppublic void setErrorMessage(String errorMessage)
GeneratedVaadinCheckboxGroup
Description copied from corresponding location in WebComponent:
Error to show when the input value is invalid.
setErrorMessage
in interface HasValidation
setErrorMessage
in class GeneratedVaadinCheckboxGroup<CheckboxGroup<T>,Set<T>>
errorMessage
- the String value to setpublic String getErrorMessage()
getErrorMessage
in interface HasValidation
public void setRequired(boolean required)
GeneratedVaadinCheckboxGroup
Description copied from corresponding location in WebComponent:
Specifies that the user must fill in a value.
setRequired
in class GeneratedVaadinCheckboxGroup<CheckboxGroup<T>,Set<T>>
required
- the boolean value to setpublic boolean isRequired()
This property is not synchronized automatically from the client side, so the returned value may not be the same as in client side.
true
if the input is required, false
otherwisepublic boolean isInvalid()
HasValidation
true
if component input is invalid, false
otherwise.isInvalid
in interface HasValidation
public void setInvalid(boolean invalid)
GeneratedVaadinCheckboxGroup
Description copied from corresponding location in WebComponent:
This property is set to true when the control value is invalid.
setInvalid
in interface HasValidation
setInvalid
in class GeneratedVaadinCheckboxGroup<CheckboxGroup<T>,Set<T>>
invalid
- the boolean value to setprotected boolean valueEquals(Set<T> value1, Set<T> value2)
AbstractField
AbstractField.setValue(Object)
or
AbstractField.setModelValue(Object, boolean)
is called. Subclasses can
override this method to define an alternative comparison method instead
of Object.equals(Object)
.valueEquals
in class AbstractField<CheckboxGroup<T>,Set<T>>
value1
- the first instancevalue2
- the second instancetrue
if the instances are equal; otherwise
false
protected boolean hasValidValue()
AbstractSinglePropertyField
false
. The default implementation always
return true
.hasValidValue
in class AbstractSinglePropertyField<CheckboxGroup<T>,Set<T>>
true
if the element property value can be converted
to the model type; otherwise false
Copyright © 2020. All rights reserved.