summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorLeif Åstrand <leif@vaadin.com>2012-02-15 18:06:16 +0200
committerLeif Åstrand <leif@vaadin.com>2012-02-15 18:06:16 +0200
commit3ff57aaa66c1910eca584621c46166a330bffd7f (patch)
tree3ce91ad93ccbdb1275d9ed3519bbadc18dc7a3aa /src
parentba602f376b2a86f66d557c3b8c4d67bac61da017 (diff)
downloadvaadin-framework-3ff57aaa66c1910eca584621c46166a330bffd7f.tar.gz
vaadin-framework-3ff57aaa66c1910eca584621c46166a330bffd7f.zip
Simulate ChildComponentContainer in the new OrderedLayouts (#8313)
Diffstat (limited to 'src')
-rw-r--r--src/com/vaadin/terminal/gwt/client/ComponentLocator.java52
1 files changed, 52 insertions, 0 deletions
diff --git a/src/com/vaadin/terminal/gwt/client/ComponentLocator.java b/src/com/vaadin/terminal/gwt/client/ComponentLocator.java
index f49f99a477..0a35c2d32c 100644
--- a/src/com/vaadin/terminal/gwt/client/ComponentLocator.java
+++ b/src/com/vaadin/terminal/gwt/client/ComponentLocator.java
@@ -12,6 +12,7 @@ import com.google.gwt.user.client.ui.HasWidgets;
import com.google.gwt.user.client.ui.RootPanel;
import com.google.gwt.user.client.ui.Widget;
import com.vaadin.terminal.gwt.client.ui.SubPartAware;
+import com.vaadin.terminal.gwt.client.ui.VMeasuringOrderedLayout;
import com.vaadin.terminal.gwt.client.ui.VView;
import com.vaadin.terminal.gwt.client.ui.VWindow;
@@ -457,6 +458,57 @@ public class ComponentLocator {
int widgetPosition = Integer.parseInt(indexString.substring(0,
indexString.length() - 1));
+ /*
+ * The new ordered layotus do not contain
+ * ChildComponentContainer widgets. This is instead simulated by
+ * constructing a path step that would find the desired widget
+ * from the layout and injecting it as the next search step
+ * (which would originally have found the widget inside the
+ * ChildComponentContainer)
+ */
+ if (w instanceof VMeasuringOrderedLayout
+ && "ChildComponentContainer".equals(widgetClassName)
+ && i + 1 < parts.length) {
+
+ VMeasuringOrderedLayout layout = (VMeasuringOrderedLayout) w;
+
+ String nextPart = parts[i + 1];
+ String[] nextSplit = nextPart.split("\\[", 2);
+ String nextWidgetClassName = nextSplit[0];
+
+ // Find the n:th child and count the number of children with
+ // the same type before it
+ int nextIndex = 0;
+ for (Widget child : layout) {
+ // Don't count captions
+ if (child instanceof VCaption) {
+ continue;
+ }
+
+ boolean matchingType = nextWidgetClassName.equals(Util
+ .getSimpleName(child));
+ if (widgetPosition == 0) {
+ // This is the n:th child
+
+ // Error if not the expected type
+ if (!matchingType) {
+ return null;
+ }
+ break;
+ } else if (matchingType) {
+ // If this was another child of the expected type,
+ // increase the count for the next step
+ nextIndex++;
+ }
+ widgetPosition--;
+ }
+
+ // Advance to the next step, this time checking for the
+ // actual child widget
+ parts[i + 1] = nextWidgetClassName + '[' + nextIndex + ']';
+ continue;
+ }
+
// Locate the child
Iterator<? extends Widget> iterator;