diff options
author | Teemu Suo-Anttila <teemusa@vaadin.com> | 2016-05-10 15:54:22 +0300 |
---|---|---|
committer | Vaadin Code Review <review@vaadin.com> | 2016-05-11 08:40:32 +0000 |
commit | 790b9cbada28b972f3c1dabc0ebe65d4af380e58 (patch) | |
tree | 8f5bb1167b54fa29e893fa3013fd602eb54e1f0b | |
parent | 14eebabd5a127b4b1bb4b9d084ec35069389971c (diff) | |
download | vaadin-framework-790b9cbada28b972f3c1dabc0ebe65d4af380e58.tar.gz vaadin-framework-790b9cbada28b972f3c1dabc0ebe65d4af380e58.zip |
Fix UIProvider backwards compatibility with AppWidgetset
Change-Id: Ia3171f4398caa9824f9b511da6576baa7b40be07
-rw-r--r-- | all/src/main/templates/release-notes.html | 2 | ||||
-rw-r--r-- | server/src/main/java/com/vaadin/server/BootstrapHandler.java | 2 | ||||
-rw-r--r-- | server/src/main/java/com/vaadin/server/UIProvider.java | 34 |
3 files changed, 30 insertions, 8 deletions
diff --git a/all/src/main/templates/release-notes.html b/all/src/main/templates/release-notes.html index 6c522ef4d6..77cce634f4 100644 --- a/all/src/main/templates/release-notes.html +++ b/all/src/main/templates/release-notes.html @@ -112,7 +112,7 @@ <ul> <li>Vaadin artifacts no longer bring a transitive dependency to javax.servlet:servlet-api.</li> <li>System properties now override application parameters for settings such as production mode (see above).</li> - <li>The return type of UIProvider.getWidgetset() and BootstrapHandler.getWidgetsetForUI() has changed.</li> + <li>The return type of BootstrapHandler.getWidgetsetForUI() has changed.</li> </ul> <h3 id="knownissues">Known Issues and Limitations</h3> <ul> diff --git a/server/src/main/java/com/vaadin/server/BootstrapHandler.java b/server/src/main/java/com/vaadin/server/BootstrapHandler.java index b766dfc92c..d3a988bea3 100644 --- a/server/src/main/java/com/vaadin/server/BootstrapHandler.java +++ b/server/src/main/java/com/vaadin/server/BootstrapHandler.java @@ -470,7 +470,7 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler { UICreateEvent event = new UICreateEvent(context.getRequest(), context.getUIClass()); WidgetsetInfo widgetset = context.getBootstrapResponse() - .getUIProvider().getWidgetset(event); + .getUIProvider().getWidgetsetInfo(event); if (widgetset == null) { // TODO do we want to move WidgetsetInfoImpl elsewhere? widgetset = new WidgetsetInfoImpl(request.getService() diff --git a/server/src/main/java/com/vaadin/server/UIProvider.java b/server/src/main/java/com/vaadin/server/UIProvider.java index 9b0087185b..31a6f2a662 100644 --- a/server/src/main/java/com/vaadin/server/UIProvider.java +++ b/server/src/main/java/com/vaadin/server/UIProvider.java @@ -127,6 +127,30 @@ public abstract class UIProvider implements Serializable { * Finds the widgetset to use for a specific UI. If no specific widgetset is * required, <code>null</code> is returned. * <p> + * This method uses the Widgetset definition priority order from + * {@link #getWidgetsetInfo(UICreateEvent)}. + * <p> + * <strong>Note:</strong> This method exists only for backwards + * compatibility and overriding it won't have the effect it used to. + * + * @param event + * the UI create event with information about the UI and the + * current request. + * @return the name of the widgetset, or <code>null</code> if the default + * widgetset should be used + * @deprecated This method has been replaced by + * {@link #getWidgetsetInfo(UICreateEvent)} in 7.7 + */ + @Deprecated + public String getWidgetset(UICreateEvent event) { + WidgetsetInfo widgetsetInfo = getWidgetsetInfo(event); + return widgetsetInfo != null ? widgetsetInfo.getWidgetsetName() : null; + } + + /** + * Finds the widgetset to use for a specific UI. If no specific widgetset is + * required, <code>null</code> is returned. + * <p> * The default implementation uses the following order of priority for * finding the widgetset information: * <ul> @@ -137,17 +161,15 @@ public abstract class UIProvider implements Serializable { * <li>null to use the default widgetset otherwise</li> * </ul> * - * Note that the return type of this method changed in Vaadin 7.7. + * @since 7.7 * * @param event * the UI create event with information about the UI and the * current request. - * @return the name of the widgetset, or <code>null</code> if the default - * widgetset should be used - * - * @since 7.7 + * @return the widgetset info, or <code>null</code> if the default widgetset + * should be used */ - public WidgetsetInfo getWidgetset(UICreateEvent event) { + public WidgetsetInfo getWidgetsetInfo(UICreateEvent event) { Widgetset uiWidgetset = getAnnotationFor(event.getUIClass(), Widgetset.class); |