summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorErik Lumme <erik@vaadin.com>2017-09-15 13:40:34 +0300
committerErik Lumme <erik@vaadin.com>2017-09-15 13:40:34 +0300
commitefd5eca05d1650ac3ca2611bb1814c53b0505ab9 (patch)
tree2545efb8e9ccfc79466975fc0c01c07fa812fd2a
parentd5ed5053222cd02d2287c2d64759ffb4247763ba (diff)
downloadvaadin-framework-efd5eca05d1650ac3ca2611bb1814c53b0505ab9.tar.gz
vaadin-framework-efd5eca05d1650ac3ca2611bb1814c53b0505ab9.zip
MIgrate ShowingDataInGrid
-rw-r--r--documentation/articles/ShowingDataInGrid.asciidoc106
-rw-r--r--documentation/articles/contents.asciidoc1
2 files changed, 107 insertions, 0 deletions
diff --git a/documentation/articles/ShowingDataInGrid.asciidoc b/documentation/articles/ShowingDataInGrid.asciidoc
new file mode 100644
index 0000000000..8f84d0ab11
--- /dev/null
+++ b/documentation/articles/ShowingDataInGrid.asciidoc
@@ -0,0 +1,106 @@
+[[showing-data-in-grid]]
+Showing data in Grid
+--------------------
+
+Grid lazy-loads data from a `Container` instance. There are different
+container implementations that e.g. fetch data from a database or use a
+list of Java objects. Assuming you already have code that initializes a
+`Container`, this is all that is needed for showing a Grid with the data
+from your container.
+
+[source,java]
+....
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.ui.Grid;
+import com.vaadin.ui.UI;
+
+public class UsingGridWithAContainer extends UI {
+ @Override
+ protected void init(VaadinRequest request) {
+ Grid grid = new Grid();
+ grid.setContainerDataSource(GridExampleHelper.createContainer());
+
+ setContent(grid);
+ }
+}
+....
+
+The container in this example contains three properties; name, count and
+amount. You can configure the columns in Grid using the property ids to
+do things like setting the column caption, removing a column or changing
+the order of the visible columns.
+
+[source,java]
+....
+protected void init(VaadinRequest request) {
+ Grid grid = new Grid();
+ grid.setContainerDataSource(GridExampleHelper.createContainer());
+
+ grid.getColumn("name").setHeaderCaption("Bean name");
+ grid.removeColumn("count");
+ grid.setColumnOrder("name", "amount");
+
+ setContent(grid);
+}
+....
+
+This is really all that is needed to get started with Grid.
+
+For reference, this is how the example container is implemented.
+
+[source,java]
+....
+public class GridExampleBean {
+ private String name;
+ private int count;
+ private double amount;
+
+ public GridExampleBean() {
+ }
+
+ public GridExampleBean(String name, int count, double amount) {
+ this.name = name;
+ this.count = count;
+ this.amount = amount;
+ }
+
+ public String getName() {
+ return name;
+ }
+
+ public int getCount() {
+ return count;
+ }
+
+ public double getAmount() {
+ return amount;
+ }
+
+ public void setName(String name) {
+ this.name = name;
+ }
+
+ public void setCount(int count) {
+ this.count = count;
+ }
+
+ public void setAmount(double amount) {
+ this.amount = amount;
+ }
+}
+....
+
+[source,java]
+....
+import com.vaadin.data.util.BeanItemContainer;
+
+public class GridExampleHelper {
+ public static BeanItemContainer<GridExampleBean> createContainer() {
+ BeanItemContainer<GridExampleBean> container = new BeanItemContainer<GridExampleBean>(GridExampleBean.class);
+ for (int i = 0; i < 1000; i++) {
+ container.addItem(new GridExampleBean("Bean " + i, i * i, i / 10d));
+ }
+ return container;
+ }
+}
+....
diff --git a/documentation/articles/contents.asciidoc b/documentation/articles/contents.asciidoc
index c03bbe214d..071eee8fea 100644
--- a/documentation/articles/contents.asciidoc
+++ b/documentation/articles/contents.asciidoc
@@ -32,3 +32,4 @@
- link:ShowingExtraDataForGridRows.asciidoc[Showing extra data for Grid rows]
- link:CreatingATextFieldForIntegerOnlyInputUsingADataSource.asciidoc[Creating a TextField for integer only input using a data source]
- link:UsingGridWithAContainer.asciidoc[Using Grid with a Container]
+- link:ShowingDataInGrid.asciidoc[Showing data in Grid]