summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorArtur Signell <artur.signell@itmill.com>2010-09-20 13:36:49 +0000
committerArtur Signell <artur.signell@itmill.com>2010-09-20 13:36:49 +0000
commit5ed9d2639ae85fe3ac0404208576fc324ce0db94 (patch)
tree645a1d5fbba1a5f5cd33fb893e90f6be0e53f1e0 /src
parent0422f3d4a40c2c02530c21b2bbc62289896a4f3e (diff)
downloadvaadin-framework-5ed9d2639ae85fe3ac0404208576fc324ce0db94.tar.gz
vaadin-framework-5ed9d2639ae85fe3ac0404208576fc324ce0db94.zip
Javadoc
svn changeset:15072/svn branch:6.4
Diffstat (limited to 'src')
-rw-r--r--src/com/vaadin/terminal/gwt/client/ui/SubPartAware.java36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/com/vaadin/terminal/gwt/client/ui/SubPartAware.java b/src/com/vaadin/terminal/gwt/client/ui/SubPartAware.java
index 2a1bef71ff..55360cf01f 100644
--- a/src/com/vaadin/terminal/gwt/client/ui/SubPartAware.java
+++ b/src/com/vaadin/terminal/gwt/client/ui/SubPartAware.java
@@ -4,11 +4,47 @@
package com.vaadin.terminal.gwt.client.ui;
import com.google.gwt.user.client.Element;
+import com.vaadin.terminal.gwt.client.ComponentLocator;
+import com.vaadin.terminal.gwt.client.Paintable;
+/**
+ * Interface implemented by {@link Paintable}s which can provide identifiers for
+ * at least one element inside the component. Used by {@link ComponentLocator}.
+ *
+ */
public interface SubPartAware {
+ /**
+ * Locates an element inside a component using the identifier provided in
+ * {@code subPart}. The {@code subPart} identifier is component specific and
+ * may be any string of characters, numbers, space characters and brackets.
+ *
+ * @param subPart
+ * The identifier for the element inside the component
+ * @return The element identified by subPart or null if the element could
+ * not be found.
+ */
Element getSubPartElement(String subPart);
+ /**
+ * Provides an identifier that identifies the element within the component.
+ * The {@code subElement} is a part of the component and must never be null.
+ * <p>
+ * <b>Note!</b>
+ * {@code getSubPartElement(getSubPartName(element)) == element} is <i>not
+ * always</i> true. A component can choose to provide a more generic
+ * identifier for any given element if the results of all interactions with
+ * {@code subElement} are the same as interactions with the element
+ * identified by the return value. For example a button can return an
+ * identifier for the root element even though a DIV inside the button was
+ * passed as {@code subElement} because interactions with the DIV and the
+ * root button element produce the same result.
+ *
+ * @param subElement
+ * The element the identifier string should uniquely identify
+ * @return An identifier that uniquely identifies {@code subElement} or null
+ * if no identifier could be provided.
+ */
String getSubPartName(Element subElement);
} \ No newline at end of file