Class AbstractForm<T>
- All Implemented Interfaces:
- com.vaadin.flow.component.AttachNotifier,- com.vaadin.flow.component.DetachNotifier,- com.vaadin.flow.component.HasElement,- com.vaadin.flow.component.HasStyle,- Serializable
For binding this form uses naming conventions, so for each field of your edited entity, it searches similarly named Vaadin component from your class extending AbstractForm.
By default, BeanValidationBinder is used, so validators defined in your DTO or entity class are taken into account. Note that Vaadin don't currently support class level validators so that must be handled separately. Binding is always non-buffered variant, create a clone of your DTO if you mind that it might get changed even if user don't press the save button.
- Author:
- mstahv
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic interfaceA handler called when the built-in delete button of the form is called.static interfaceA handler called when the built-in reset/cancel button of the form is called.static interfaceA handler called when the built-in save button of the form is called.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidAdjusts the reset button state.protected voidAdjust save button state.protected voidbind()By default just does simple name based binding.voidprotected abstract com.vaadin.flow.component.ComponentThis method should return the actual content of the form, including possible toolbar.protected com.vaadin.flow.component.button.Buttonprotected com.vaadin.flow.component.button.Buttonprotected com.vaadin.flow.component.button.Buttonprotected voiddelete(com.vaadin.flow.component.ClickEvent<com.vaadin.flow.component.button.Button> e) voidFocuses the first field found from the form.com.vaadin.flow.data.binder.Binder<T>com.vaadin.flow.component.button.Buttoncom.vaadin.flow.component.dialog.DialoggetPopup()com.vaadin.flow.component.button.Buttoncom.vaadin.flow.component.button.Buttoncom.vaadin.flow.component.orderedlayout.HorizontalLayoutbooleanprotected booleanisBound()booleanisValid()protected voidlazyInit()protected voidreset(com.vaadin.flow.component.ClickEvent<com.vaadin.flow.component.button.Button> e) protected voidsave(com.vaadin.flow.component.ClickEvent<com.vaadin.flow.component.button.Button> e) voidvoidsetCancelCaption(String cancelCaption) voidsetDeleteButton(com.vaadin.flow.component.button.Button deleteButton) voidsetDeleteCaption(String deleteCaption) voidsetDeleteHandler(AbstractForm.DeleteHandler<T> deleteHandler) voidSets the object to be edited by this form.voidsetEntityWithEnabledSave(T entity) by default only save button get's enabled when form has any changes
 you can use this method in case the prefilled entity is already valid and save should be possible to press without any changes
 if entity is not valid saveButton will stay disabled!protected voidsetHasChanges(boolean hasChanges) voidsetModalWindowTitle(String modalWindowTitle) voidsetResetButton(com.vaadin.flow.component.button.Button resetButton) voidsetResetHandler(AbstractForm.ResetHandler<T> resetHandler) voidsetSaveButton(com.vaadin.flow.component.button.Button button) voidsetSaveCaption(String saveCaption) voidsetSavedHandler(AbstractForm.SavedHandler<T> savedHandler) Methods inherited from class com.vaadin.flow.component.CompositegetChildren, getContent, getElement, initContentMethods inherited from class com.vaadin.flow.component.ComponentaddListener, findAncestor, fireEvent, from, get, getEventBus, getId, getListeners, getLocale, getParent, getTranslation, getTranslation, getTranslation, getTranslation, getTranslation, getTranslation, getUI, hasListener, isAttached, isTemplateMapped, isVisible, onAttach, onDetach, onEnabledStateChanged, removeFromParent, scrollIntoView, scrollIntoView, set, setElement, setId, setVisibleMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.vaadin.flow.component.AttachNotifieraddAttachListenerMethods inherited from interface com.vaadin.flow.component.DetachNotifieraddDetachListenerMethods inherited from interface com.vaadin.flow.component.HasStyleaddClassName, addClassNames, getClassName, getClassNames, getStyle, hasClassName, removeClassName, removeClassNames, setClassName, setClassName
- 
Constructor Details- 
AbstractFormConstructor for the abstract form.- Parameters:
- entityType- The class type used for data binding
 
 
- 
- 
Method Details- 
setEntitySets the object to be edited by this form. This method binds all fields from this form to given objects.If your form needs to manually configure something based on the state of the edited object, you can override this method to do that either before the object is bound to fields or to do something after the bean binding. - Parameters:
- entity- the object to be edited by this form
 
- 
setEntityWithEnabledSaveby default only save button get's enabled when form has any changes
 you can use this method in case the prefilled entity is already valid and save should be possible to press without any changes
 if entity is not valid saveButton will stay disabled!- Parameters:
- entity- the object to be edited by this form
 
- 
hasChangespublic boolean hasChanges()- Returns:
- true if bean has been changed since last setEntity call.
 
- 
setHasChangesprotected void setHasChanges(boolean hasChanges) 
- 
isValidpublic boolean isValid()
- 
setSavedHandler
- 
setResetHandler
- 
setDeleteHandler
- 
getResetHandler
- 
getSavedHandler
- 
getDeleteHandler
- 
getSaveCaption
- 
setSaveCaption
- 
getModalWindowTitle
- 
setModalWindowTitle
- 
getDeleteCaption
- 
setDeleteCaption
- 
getCancelCaption
- 
setCancelCaption
- 
getBinder
- 
setBinder
- 
lazyInitprotected void lazyInit()
- 
bindprotected void bind()By default just does simple name based binding. Override this method to customize the binding.
- 
createContentprotected abstract com.vaadin.flow.component.Component createContent()This method should return the actual content of the form, including possible toolbar. Use setEntity(T entity) to fill in the data. Am example implementation could look like this:public class PersonForm extends AbstractForm<Person> { private TextField firstName = new MTextField("First Name"); private TextField lastName = new MTextField("Last Name"); @Override protected Component createContent() { return new MVerticalLayout( new FormLayout( firstName, lastName ), getToolbar() ); } }- Returns:
- the content of the form
 
- 
adjustSaveButtonStateprotected void adjustSaveButtonState()Adjust save button state. Override if you for example want to have Save button always enabled, even if the Binder has not tracked any changes yet.
- 
getSaveButtonpublic com.vaadin.flow.component.button.Button getSaveButton()
- 
createSaveButtonprotected com.vaadin.flow.component.button.Button createSaveButton()
- 
isBoundprotected boolean isBound()
- 
createResetButtonprotected com.vaadin.flow.component.button.Button createResetButton()
- 
getResetButtonpublic com.vaadin.flow.component.button.Button getResetButton()
- 
setResetButtonpublic void setResetButton(com.vaadin.flow.component.button.Button resetButton) 
- 
createDeleteButtonprotected com.vaadin.flow.component.button.Button createDeleteButton()
- 
setDeleteButtonpublic void setDeleteButton(com.vaadin.flow.component.button.Button deleteButton) 
- 
getDeleteButtonpublic com.vaadin.flow.component.button.Button getDeleteButton()
- 
adjustResetButtonStateprotected void adjustResetButtonState()Adjusts the reset button state. Override if you for example wish to keep reset/cancel button enabled even if there is nothing to reset.
- 
setSaveButtonpublic void setSaveButton(com.vaadin.flow.component.button.Button button) 
- 
getEntity- Returns:
- the currently edited entity or null if the form is currently unbound
 
- 
saveprotected void save(com.vaadin.flow.component.ClickEvent<com.vaadin.flow.component.button.Button> e) 
- 
resetprotected void reset(com.vaadin.flow.component.ClickEvent<com.vaadin.flow.component.button.Button> e) 
- 
deleteprotected void delete(com.vaadin.flow.component.ClickEvent<com.vaadin.flow.component.button.Button> e) 
- 
getToolbarpublic com.vaadin.flow.component.orderedlayout.HorizontalLayout getToolbar()- Returns:
- A default toolbar containing save/cancel/delete buttons
 
- 
openInModalPopup
- 
focusFirstpublic void focusFirst()Focuses the first field found from the form. It often improves UX to call this method, or focus another field, when you assign a bean for editing.
- 
getPopuppublic com.vaadin.flow.component.dialog.Dialog getPopup()- Returns:
- the last Popup into which the Form was opened with #openInModalPopup method or null if the form hasn't been use in window
 
- 
closePopuppublic void closePopup()
 
-