diff options
author | Erik Lumme <erik@vaadin.com> | 2017-09-15 13:29:17 +0300 |
---|---|---|
committer | Erik Lumme <erik@vaadin.com> | 2017-09-15 13:29:17 +0300 |
commit | d4a822eccba4a9f662a72ea9c3f6194592c4a7aa (patch) | |
tree | 1419fa7603794854fe2b69ddbaa88ccf801ce42c | |
parent | 39bb94aef557c31d065855384aa7beca8e400e06 (diff) | |
download | vaadin-framework-d4a822eccba4a9f662a72ea9c3f6194592c4a7aa.tar.gz vaadin-framework-d4a822eccba4a9f662a72ea9c3f6194592c4a7aa.zip |
Migrate CreatingATextFieldForIntegerOnlyInputUsingADataSource
-rw-r--r-- | documentation/articles/CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc | 63 | ||||
-rw-r--r-- | documentation/articles/contents.asciidoc | 1 |
2 files changed, 64 insertions, 0 deletions
diff --git a/documentation/articles/CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc b/documentation/articles/CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc new file mode 100644 index 0000000000..980049e9e9 --- /dev/null +++ b/documentation/articles/CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc @@ -0,0 +1,63 @@ +[[creating-a-textfield-for-integer-only-input-using-a-data-source]] +Creating a TextField for integer only input using a data source +--------------------------------------------------------------- + +A `TextField` is a component that always has a value of type `String`. When +binding a property of another type to a text field, the value is +automatically converted if the conversion between the two types is +supported. + +[source,java] +.... +public class MyBean { + private int value; + + public int getValue() { + return value; + } + + public void setValue(int integer) { + value = integer; + } +} +.... + +The property named "value" from a `BeanItem` constructed from `MyBean` will +be of type `Integer`. Binding the property to a `TextField` will +automatically make validation fail for texts that can not be converted +to an `Integer`. + +[source,java] +.... +final MyBean myBean = new MyBean(); +BeanItem<MyBean> beanItem = new BeanItem<MyBean>(myBean); + +final Property<Integer> integerProperty = (Property<Integer>) beanItem + .getItemProperty("value"); +final TextField textField = new TextField("Text field", integerProperty); + +Button submitButton = new Button("Submit value", new ClickListener() { + public void buttonClick(ClickEvent event) { + String uiValue = textField.getValue(); + Integer propertyValue = integerProperty.getValue(); + int dataModelValue = myBean.getValue(); + + Notification.show("UI value (String): " + uiValue + + "\nProperty value (Integer): " + propertyValue + + "\nData model value (int): " + dataModelValue); + } +}); + +addComponent(new Label("Text field type: " + textField.getType())); +addComponent(new Label("Text field type: " + integerProperty.getType())); +addComponent(textField); +addComponent(submitButton); +.... + +With this example, entering a number and pressing the button causes the +value of the `TextField` to be a `String`, the property value will be an +`Integer` representing the same value and the value in the bean will be +the same int. If e.g. a letter is entered to the field and the button is +pressed, the validation will fail. This causes a notice to be displayed +for the field. The field value is still updated, but the property value +and the bean value are kept at their previous values. diff --git a/documentation/articles/contents.asciidoc b/documentation/articles/contents.asciidoc index c18c8b4c97..a356c99b4b 100644 --- a/documentation/articles/contents.asciidoc +++ b/documentation/articles/contents.asciidoc @@ -30,3 +30,4 @@ - link:CreatingACustomFieldForEditingTheAddressOfAPerson.asciidoc[Creating a CustomField for editing the address of a person] - link:CreatingAMasterDetailsViewForEditingPersons.asciidoc[Creating a master details view for editing persons] - link:ShowingExtraDataForGridRows.asciidoc[Showing extra data for Grid rows] +- link:CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc[Creating a TextField for integer only input using a data source] |