summaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2015-06-23 23:20:59 +0300
committerVaadin Code Review <review@vaadin.com>2015-06-24 06:28:20 +0000
commitd505fc70ac3bbf13e868c227b58d82966abf2254 (patch)
tree92d452807434f1fd941c34f2384e84a3a3e32302 /server
parent3c70a219865914dfaed4e712c5642e085c905123 (diff)
downloadvaadin-framework-d505fc70ac3bbf13e868c227b58d82966abf2254.tar.gz
vaadin-framework-d505fc70ac3bbf13e868c227b58d82966abf2254.zip
Handle nested GridLayouts in declarative format correctly (#18312)
Change-Id: Id7f204c170981f4395e789333b89cd8207fe4002
Diffstat (limited to 'server')
-rw-r--r--server/src/com/vaadin/ui/GridLayout.java12
-rw-r--r--server/tests/src/com/vaadin/tests/server/component/gridlayout/GridLayoutDeclarativeTest.java33
2 files changed, 41 insertions, 4 deletions
diff --git a/server/src/com/vaadin/ui/GridLayout.java b/server/src/com/vaadin/ui/GridLayout.java
index 6ccb272704..792ad72dcc 100644
--- a/server/src/com/vaadin/ui/GridLayout.java
+++ b/server/src/com/vaadin/ui/GridLayout.java
@@ -1319,11 +1319,15 @@ public class GridLayout extends AbstractLayout implements
setMargin(readMargin(design, getMargin(), designContext));
- // Prepare a 2D map for reading column contents
- Elements rowElements = design.getElementsByTag("row");
+ List<Element> rowElements = new ArrayList<Element>();
List<Map<Integer, Component>> rows = new ArrayList<Map<Integer, Component>>();
- for (int i = 0; i < rowElements.size(); ++i) {
- rows.add(new HashMap<Integer, Component>());
+ // Prepare a 2D map for reading column contents
+ for (Element e : design.children()) {
+ if (e.tagName().equalsIgnoreCase("row")) {
+ rowElements.add(e);
+ rows.add(new HashMap<Integer, Component>());
+
+ }
}
setRows(Math.max(rows.size(), 1));
diff --git a/server/tests/src/com/vaadin/tests/server/component/gridlayout/GridLayoutDeclarativeTest.java b/server/tests/src/com/vaadin/tests/server/component/gridlayout/GridLayoutDeclarativeTest.java
index 9d3b5001da..d69fd92984 100644
--- a/server/tests/src/com/vaadin/tests/server/component/gridlayout/GridLayoutDeclarativeTest.java
+++ b/server/tests/src/com/vaadin/tests/server/component/gridlayout/GridLayoutDeclarativeTest.java
@@ -203,4 +203,37 @@ public class GridLayoutDeclarativeTest extends
}
return result;
}
+
+ @Test
+ public void testNestedGridLayouts() {
+ String design = "<!DOCTYPE html>" + //
+ "<html>" + //
+ " <body> " + //
+ " <v-grid-layout> " + //
+ " <row> " + //
+ " <column> " + //
+ " <v-grid-layout> " + //
+ " <row> " + //
+ " <column> " + //
+ " <v-button>" + //
+ " Button " + //
+ " </v-button> " + //
+ " </column> " + //
+ " </row> " + //
+ " </v-grid-layout> " + //
+ " </column> " + //
+ " </row> " + //
+ " </v-grid-layout> " + //
+ " </body>" + //
+ "</html>";
+ GridLayout outer = new GridLayout();
+ GridLayout inner = new GridLayout();
+ Button b = new Button("Button");
+ b.setCaptionAsHtml(true);
+ inner.addComponent(b);
+ outer.addComponent(inner);
+ testRead(design, outer);
+ testWrite(design, outer);
+
+ }
}