diff options
author | Erik Lumme <erik@vaadin.com> | 2017-09-15 11:51:29 +0300 |
---|---|---|
committer | Erik Lumme <erik@vaadin.com> | 2017-09-15 11:51:29 +0300 |
commit | 40236881ce54819f1f17a69bf00d776e3a731ac2 (patch) | |
tree | 9b6c04624775c949b2626999bd65a82f0dc14192 /documentation | |
parent | b8c76ef85137d39d05236765dced3ad59844a68e (diff) | |
download | vaadin-framework-40236881ce54819f1f17a69bf00d776e3a731ac2.tar.gz vaadin-framework-40236881ce54819f1f17a69bf00d776e3a731ac2.zip |
Migrate AutoGeneratingAFormBasedOnABeanVaadin6StyleForm
Diffstat (limited to 'documentation')
-rw-r--r-- | documentation/articles/AutoGeneratingAFormBasedOnABeanVaadin6StyleForm.asciidoc | 45 | ||||
-rw-r--r-- | documentation/articles/contents.asciidoc | 1 |
2 files changed, 46 insertions, 0 deletions
diff --git a/documentation/articles/AutoGeneratingAFormBasedOnABeanVaadin6StyleForm.asciidoc b/documentation/articles/AutoGeneratingAFormBasedOnABeanVaadin6StyleForm.asciidoc new file mode 100644 index 0000000000..8c4851bfe7 --- /dev/null +++ b/documentation/articles/AutoGeneratingAFormBasedOnABeanVaadin6StyleForm.asciidoc @@ -0,0 +1,45 @@ +[[auto-generating-a-form-based-on-a-bean-vaadin-6-style-form]] +Auto-generating a form based on a bean - Vaadin 6 style Form +------------------------------------------------------------ + +In Vaadin 6 it is easy to get a completely auto generated form based on +a bean instance by creating a `BeanItem` and passing that to a Form. Using +`FieldGroup` this requires a few extra lines as `FieldGroup` never adds +fields automatically to any layout but instead gives that control to the +developer. + +Given a bean such as this `Person`: + +[source,java] +.... +public class Person { + private String firstName,lastName; + private int age; + // + setters and getters +} +.... + +You can auto create a form using FieldGroup as follows: + +[source,java] +.... +public class AutoGeneratedFormUI extends UI { + @Override + public void init(VaadinRequest request) { + VerticalLayout layout = new VerticalLayout(); + setContent(layout); + + FieldGroup fieldGroup = new BeanFieldGroup<Person>(Person.class); + + // We need an item data source before we create the fields to be able to + // find the properties, otherwise we have to specify them by hand + fieldGroup.setItemDataSource(new BeanItem<Person>(new Person("John", "Doe", 34))); + + // Loop through the properties, build fields for them and add the fields + // to this UI + for (Object propertyId : fieldGroup.getUnboundPropertyIds()) { + layout.addComponent(fieldGroup.buildAndBind(propertyId)); + } + } +} +.... diff --git a/documentation/articles/contents.asciidoc b/documentation/articles/contents.asciidoc index 830c8eeb9f..2f3ce98a50 100644 --- a/documentation/articles/contents.asciidoc +++ b/documentation/articles/contents.asciidoc @@ -21,3 +21,4 @@ - link:AddingJPAToTheAddressBookDemo.asciidoc[Adding JPA to the address book demo] - link:SimplifiedRPCusingJavaScript.asciidoc[Simplified RPC using JavaScript] - link:JMeterTesting.asciidoc[JMeter testing] +- link:AutoGeneratingAFormBasedOnABeanVaadin6StyleForm.asciidoc[Auto-generating a form based on a bean - Vaadin 6 style Form] |