From 9f30ebf6662c99a5b6b2e1be2e0c25ed01571592 Mon Sep 17 00:00:00 2001 From: Teemu Suo-Anttila Date: Mon, 12 Sep 2016 12:43:01 +0300 Subject: Support finding components in v7 packages with ComponentLocator Change-Id: I60eabf3b1c6363be505a2d21f7ed439c5357f61f --- .../VaadinFinderLocatorStrategy.java | 41 ++++++++++++++++------ 1 file changed, 31 insertions(+), 10 deletions(-) (limited to 'client/src') diff --git a/client/src/main/java/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java b/client/src/main/java/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java index 3ba6284cf2..3f46a0a812 100644 --- a/client/src/main/java/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java +++ b/client/src/main/java/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java @@ -609,12 +609,11 @@ public class VaadinFinderLocatorStrategy implements LocatorStrategy { List ids = getIDsForConnector(connector); - Integer[] widgetTags = client.getConfiguration() - .getTagsForServerSideClassName(getFullClassName(widgetName)); - if (widgetTags.length == 0) { - widgetTags = client.getConfiguration() - .getTagsForServerSideClassName( - getFullClassName("com.vaadin.ui." + widgetName)); + List widgetTags = new ArrayList<>(); + widgetTags.addAll(getTags(widgetName)); + + if (widgetTags.size() == 0) { + widgetTags.addAll(getTags("com.vaadin.ui" + widgetName)); } for (int i = 0, l = ids.size(); i < l; ++i) { @@ -627,7 +626,7 @@ public class VaadinFinderLocatorStrategy implements LocatorStrategy { final String simpleName = getSimpleClassName(name); final String fullName = getFullClassName(name); - if (widgetTags.length > 0) { + if (widgetTags.size() > 0) { Integer[] foundTags = client.getConfiguration() .getTagsForServerSideClassName(fullName); for (int tag : foundTags) { @@ -655,6 +654,28 @@ public class VaadinFinderLocatorStrategy implements LocatorStrategy { } + /** + * Gets the tags for server side class name. Also includes tags for older + * components in v7 package. + * + * @param widgetName + * the server side class name for widget + * @return list of tags + */ + private List getTags(String widgetName) { + List widgetTags = new ArrayList<>(); + Arrays.stream(client.getConfiguration() + .getTagsForServerSideClassName(getFullClassName(widgetName))) + .forEach(widgetTags::add); + if (widgetName.startsWith("com.vaadin.ui")) { + Arrays.stream(client.getConfiguration() + .getTagsForServerSideClassName(getFullClassName(widgetName + .replace("com.vaadin.ui", "com.vaadin.v7.ui")))) + .forEach(widgetTags::add); + } + return widgetTags; + } + /** * Extracts the name of the widget class from a path fragment * @@ -738,9 +759,9 @@ public class VaadinFinderLocatorStrategy implements LocatorStrategy { return list; } - private boolean tagsMatch(Integer[] targets, Integer tag) { - for (int i = 0; i < targets.length; ++i) { - if (targets[i].equals(tag)) { + private boolean tagsMatch(List targets, Integer tag) { + for (int i = 0; i < targets.size(); ++i) { + if (targets.get(i).equals(tag)) { return true; } } -- cgit v1.2.3