diff options
author | Henri Sara <henri.sara@gmail.com> | 2017-06-28 11:35:35 +0300 |
---|---|---|
committer | Ilia Motornyi <elmot@vaadin.com> | 2017-06-28 11:35:35 +0300 |
commit | 29a4578a8d52c0720ff16cedf783223fdc4ea533 (patch) | |
tree | f7b37914a805c451f7a9273df0ac627a25b1171e | |
parent | 6ed5f2a0df068dba713d8e24dc9f78e2a0829a73 (diff) | |
download | vaadin-framework-29a4578a8d52c0720ff16cedf783223fdc4ea533.tar.gz vaadin-framework-29a4578a8d52c0720ff16cedf783223fdc4ea533.zip |
Add isExpanded() method to Tree and TreeGrid
Fixes #9595
4 files changed, 29 insertions, 6 deletions
diff --git a/server/src/main/java/com/vaadin/ui/Tree.java b/server/src/main/java/com/vaadin/ui/Tree.java index 35bc680213..cd53d1bc08 100644 --- a/server/src/main/java/com/vaadin/ui/Tree.java +++ b/server/src/main/java/com/vaadin/ui/Tree.java @@ -413,6 +413,17 @@ public class Tree<T> extends Composite } /** + * Returns whether a given item is expanded or collapsed. + * + * @param item + * the item to check + * @return true if the item is expanded, false if collapsed + */ + public boolean isExpanded(T item) { + return treeGrid.isExpanded(item); + } + + /** * This method is a shorthand that delegates to the currently set selection * model. * @@ -767,7 +778,7 @@ public class Tree<T> extends Composite /** * Sets the height of a row. If -1 (default), the row height is calculated * based on the theme for an empty row before the Tree is displayed. - * + * * @param rowHeight * The height of a row in pixels or -1 for automatic calculation */ @@ -777,7 +788,7 @@ public class Tree<T> extends Composite /** * Sets the content mode of the item caption. - * + * * @param contentMode * the content mode */ diff --git a/server/src/main/java/com/vaadin/ui/TreeGrid.java b/server/src/main/java/com/vaadin/ui/TreeGrid.java index d32ff1464a..703a83192a 100644 --- a/server/src/main/java/com/vaadin/ui/TreeGrid.java +++ b/server/src/main/java/com/vaadin/ui/TreeGrid.java @@ -52,8 +52,6 @@ import com.vaadin.shared.ui.treegrid.TreeGridState; import com.vaadin.ui.declarative.DesignAttributeHandler; import com.vaadin.ui.declarative.DesignContext; import com.vaadin.ui.declarative.DesignFormatter; -import com.vaadin.ui.renderers.AbstractRenderer; -import com.vaadin.ui.renderers.Renderer; /** * A grid component for displaying hierarchical tabular data. @@ -383,6 +381,17 @@ public class TreeGrid<T> extends Grid<T> }); } + /** + * Returns whether a given item is expanded or collapsed. + * + * @param item + * the item to check + * @return true if the item is expanded, false if collapsed + */ + public boolean isExpanded(T item) { + return getDataCommunicator().isExpanded(item); + } + @Override protected TreeGridState getState() { return (TreeGridState) super.getState(); diff --git a/server/src/test/java/com/vaadin/tests/components/TreeTest.java b/server/src/test/java/com/vaadin/tests/components/TreeTest.java index 9224934a4c..c4ee9ae3d5 100644 --- a/server/src/test/java/com/vaadin/tests/components/TreeTest.java +++ b/server/src/test/java/com/vaadin/tests/components/TreeTest.java @@ -56,8 +56,7 @@ public class TreeTest { treeData.addItem(null, "Foo"); treeData.addItem("Foo", "Bar"); treeData.addItem("Foo", "Baz"); - tree.setDataProvider( - new TreeDataProvider<>(treeData)); + tree.setDataProvider(new TreeDataProvider<>(treeData)); TreeCollapseExpandListener listener = new TreeCollapseExpandListener( tree); @@ -66,9 +65,11 @@ public class TreeTest { Assert.assertFalse(listener.isExpanded()); tree.expand("Foo"); + Assert.assertTrue("Item not expanded", tree.isExpanded("Foo")); Assert.assertTrue("Expand event not fired", listener.isExpanded()); Assert.assertFalse(listener.isCollapsed()); tree.collapse("Foo"); + Assert.assertFalse("Item not collapsed", tree.isExpanded("Foo")); Assert.assertTrue("Collapse event not fired", listener.isCollapsed()); } diff --git a/server/src/test/java/com/vaadin/tests/components/treegrid/TreeGridTest.java b/server/src/test/java/com/vaadin/tests/components/treegrid/TreeGridTest.java index 1f900688c4..fdaacae48b 100644 --- a/server/src/test/java/com/vaadin/tests/components/treegrid/TreeGridTest.java +++ b/server/src/test/java/com/vaadin/tests/components/treegrid/TreeGridTest.java @@ -35,11 +35,13 @@ public class TreeGridTest { // Test expand event Assert.assertFalse(expandEventFired); treeGrid.expand("Foo"); + Assert.assertTrue("Item not expanded", treeGrid.isExpanded("Foo")); Assert.assertTrue("Expand event not fired", expandEventFired); // Test collapse event Assert.assertFalse(collapseEventFired); treeGrid.collapse("Foo"); + Assert.assertFalse("Item not collapsed", treeGrid.isExpanded("Foo")); Assert.assertTrue("Collapse event not fired", collapseEventFired); } } |