summaryrefslogtreecommitdiffstats
path: root/documentation
diff options
context:
space:
mode:
Diffstat (limited to 'documentation')
-rw-r--r--documentation/datamodel/datamodel-properties.asciidoc23
1 files changed, 9 insertions, 14 deletions
diff --git a/documentation/datamodel/datamodel-properties.asciidoc b/documentation/datamodel/datamodel-properties.asciidoc
index d5d0d3e39d..ed7bb44c35 100644
--- a/documentation/datamodel/datamodel-properties.asciidoc
+++ b/documentation/datamodel/datamodel-properties.asciidoc
@@ -20,7 +20,7 @@ In the following, we set and read the property value from a
[classname]#TextField# component, which implements the [interfacename]#Property#
interface to allow accessing the field value.
-
+[source, java]
----
final TextField tf = new TextField("Name");
@@ -83,7 +83,7 @@ user interface component (views) to allow editing or viewing the data model.
A property can be bound to a component implementing the [classname]#Viewer#
interface with [methodname]#setPropertyDataSource()#.
-
+[source, java]
----
// Have a data model
ObjectProperty property =
@@ -99,7 +99,7 @@ viewer.setPropertyDataSource(property);
You can use the same method in the [classname]#Editor# interface to bind a
component that allows editing a particular property type to a property.
-
+[source, java]
----
// Have a data model
ObjectProperty property =
@@ -110,7 +110,6 @@ TextField editor = new TextField("Edit Greeting");
// Bind it to the data
editor.setPropertyDataSource(property);
-
----
As all field components implement the [classname]#Property# interface, you can
@@ -119,7 +118,7 @@ assuming that the viewer is able the view the object type of the field.
Continuing from the above example, we can bind a [classname]#Label# to the
[classname]#TextField# value:
-
+[source, java]
----
Label viewer = new Label();
viewer.setPropertyDataSource(editor);
@@ -143,7 +142,7 @@ property data source, or by calling the [methodname]#validate()# or
The [classname]#ObjectProperty# class is a simple implementation of the
[classname]#Property# interface that allows storing an arbitrary Java object.
-
+[source, java]
----
// Have a component that implements Viewer interface
final TextField tf = new TextField("Name");
@@ -159,7 +158,6 @@ ObjectProperty property =
tf.setPropertyDataSource(property);
----
-
[[datamodel.properties.converter]]
== Converting Between Property Type and Representation
@@ -179,7 +177,7 @@ application.
The [methodname]#setConverter([interfacename]#Converter#)# method sets the
converter for a field. The method is defined in [classname]#AbstractField#.
-
+[source, java]
----
// Have an integer property
final ObjectProperty<Integer> property =
@@ -233,7 +231,7 @@ the [package]#com.vaadin.data.util.converter# package.
For example, let us assume that we have a simple [classname]#Complex# type for
storing complex values.
-
+[source, java]
----
public class ComplexConverter
implements Converter<String, Complex> {
@@ -281,7 +279,7 @@ you need to implement one yourself. While you could implement the
[interfacename]#ConverterFactory# interface, it is usually easier to just extend
[classname]#DefaultConverterFactory#.
-
+[source, java]
----
class MyConverterFactory extends DefaultConverterFactory {
@Override
@@ -318,7 +316,7 @@ for the property type, as the type is often fixed in property implementations.
The following example shows a simple implementation of the [classname]#Property#
interface:
-
+[source, java]
----
class MyProperty implements Property {
Integer data = 0;
@@ -394,6 +392,3 @@ or in the read-only mode. You should normally also implement at least the
[classname]#ObjectProperty# class for an example of the implementation.
endif::web[]
-
-
-