aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2012-04-19 17:33:18 +0300
committerArtur Signell <artur@vaadin.com>2012-04-19 22:10:41 +0300
commit2db8b527fc089a853bee7fdb5226aa890aa193b4 (patch)
tree15d90edbf77b41a15c01782d653944aa6d122dfb
parent6f03d2c4c94374143c9c8fab9c375f780b3064c0 (diff)
downloadvaadin-framework-2db8b527fc089a853bee7fdb5226aa890aa193b4.tar.gz
vaadin-framework-2db8b527fc089a853bee7fdb5226aa890aa193b4.zip
Method for finding the first ancestor of a given type (#8182)
-rw-r--r--src/com/vaadin/ui/AbstractComponent.java53
-rw-r--r--tests/testbench/com/vaadin/tests/components/window/CloseSubWindow.java2
2 files changed, 27 insertions, 28 deletions
diff --git a/src/com/vaadin/ui/AbstractComponent.java b/src/com/vaadin/ui/AbstractComponent.java
index cca0edc001..79a07ae00e 100644
--- a/src/com/vaadin/ui/AbstractComponent.java
+++ b/src/com/vaadin/ui/AbstractComponent.java
@@ -534,6 +534,31 @@ public abstract class AbstractComponent implements Component, MethodEventSource
return parent;
}
+ /**
+ * Returns the closest ancestor with the given type.
+ * <p>
+ * To find the Window that contains the component, use {@code Window w =
+ * getParent(Window.class);}
+ * </p>
+ *
+ * @param <T>
+ * The type of the ancestor
+ * @param parentType
+ * The ancestor class we are looking for
+ * @return The first ancestor that can be assigned to the given class. Null
+ * if no ancestor with the correct type could be found.
+ */
+ public <T extends HasComponents> T findAncestor(Class<T> parentType) {
+ HasComponents p = getParent();
+ while (p != null) {
+ if (parentType.isAssignableFrom(p.getClass())) {
+ return parentType.cast(p);
+ }
+ p = p.getParent();
+ }
+ return null;
+ }
+
/*
* Sets the parent component. Don't add a JavaDoc comment here, we use the
* default documentation from implemented interface.
@@ -1461,7 +1486,7 @@ public abstract class AbstractComponent implements Component, MethodEventSource
private void setActionManagerViewer() {
if (actionManager != null && getRoot() != null) {
// Attached and has action manager
- Window w = findParentOfType(Window.class, this);
+ Window w = findAncestor(Window.class);
if (w != null) {
actionManager.setViewer(w);
} else {
@@ -1471,32 +1496,6 @@ public abstract class AbstractComponent implements Component, MethodEventSource
}
- /**
- * Helper method for finding the first parent component of a given type.
- * Useful e.g. for finding the Window the component is inside.
- *
- * @param <T>
- * @param parentType
- * The type to look for
- * @param c
- * The target component
- * @return A parent component of type {@literal parentType} or null if no
- * parent component in the hierarchy can be assigned to the given
- * type.
- */
- private static <T extends Component> T findParentOfType(
- Class<T> parentType, Component c) {
- Component p = c.getParent();
- if (p == null) {
- return null;
- }
-
- if (parentType.isAssignableFrom(p.getClass())) {
- return (T) p;
- }
- return findParentOfType(parentType, p);
- }
-
public void addShortcutListener(ShortcutListener shortcut) {
getActionManager().addAction(shortcut);
}
diff --git a/tests/testbench/com/vaadin/tests/components/window/CloseSubWindow.java b/tests/testbench/com/vaadin/tests/components/window/CloseSubWindow.java
index 4cd3854d6f..bcfbc7f55a 100644
--- a/tests/testbench/com/vaadin/tests/components/window/CloseSubWindow.java
+++ b/tests/testbench/com/vaadin/tests/components/window/CloseSubWindow.java
@@ -37,7 +37,7 @@ public class CloseSubWindow extends TestBase {
Button closeButton = new Button("Close");
closeButton.addListener(new ClickListener() {
public void buttonClick(ClickEvent event) {
- window.close();
+ event.getButton().findAncestor(Window.class).close();
}
});
window.addComponent(closeButton);