summaryrefslogtreecommitdiffstats
path: root/documentation/articles/CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc
diff options
context:
space:
mode:
authorHenri Sara <henri.sara@gmail.com>2017-09-19 09:50:11 +0300
committerGitHub <noreply@github.com>2017-09-19 09:50:11 +0300
commit15a76bbdcaa6cd551e85c9e1e3c681e912885e8a (patch)
tree6027d86bc9bf9afc7e0838eddabd1e4b29fc59dc /documentation/articles/CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc
parent872d489506c1b1108c4e99134f0473c4b4b987fa (diff)
parent377695d75dee8ddfaef9b994b1c85b50672f2d25 (diff)
downloadvaadin-framework-15a76bbdcaa6cd551e85c9e1e3c681e912885e8a.tar.gz
vaadin-framework-15a76bbdcaa6cd551e85c9e1e3c681e912885e8a.zip
Migrate Vaadin 7 wiki articles to documentation (#9993)
Diffstat (limited to 'documentation/articles/CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc')
-rw-r--r--documentation/articles/CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc63
1 files changed, 63 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.