diff options
author | Erik Lumme <erik@vaadin.com> | 2017-09-14 13:25:06 +0300 |
---|---|---|
committer | Erik Lumme <erik@vaadin.com> | 2017-09-14 13:25:06 +0300 |
commit | 77c61ecb71c9a86a6abc722844fededc071daae8 (patch) | |
tree | 7d222c0318eb535c41a7f55cd2898a0da4ab12b3 /documentation | |
parent | a40be2471984c218b641c3c9a133055d19d32bc4 (diff) | |
download | vaadin-framework-77c61ecb71c9a86a6abc722844fededc071daae8.tar.gz vaadin-framework-77c61ecb71c9a86a6abc722844fededc071daae8.zip |
Migrate CreatingAnApplicationWithDIfferentFeaturesForDIfferentClients
Diffstat (limited to 'documentation')
-rw-r--r-- | documentation/articles/CreatingAnApplicationWithDifferentFeaturesForDifferentClients.asciidoc | 71 | ||||
-rw-r--r-- | documentation/articles/contents.asciidoc | 1 |
2 files changed, 72 insertions, 0 deletions
diff --git a/documentation/articles/CreatingAnApplicationWithDifferentFeaturesForDifferentClients.asciidoc b/documentation/articles/CreatingAnApplicationWithDifferentFeaturesForDifferentClients.asciidoc new file mode 100644 index 0000000000..c8b073868f --- /dev/null +++ b/documentation/articles/CreatingAnApplicationWithDifferentFeaturesForDifferentClients.asciidoc @@ -0,0 +1,71 @@ +[[creating-an-application-with-different-features-for-different-clients]] +Creating an application with different features for different clients +--------------------------------------------------------------------- + +Providing different features for different clients can be done by +creating a specialized UIProvider for the application. + +We start by creating the specialized UI's + +[source,java] +.... +public class DefaultUI extends UI { + @Override + protected void init(VaadinRequest request) { + setContent( + new Label("This browser does not support touch events")); + } +} +.... + +[source,java] +.... +public class TouchUI extends UI { + @Override + protected void init(VaadinRequest request) { + WebBrowser webBrowser = getPage().getWebBrowser(); + String screenSize = "" + webBrowser.getScreenWidth() + "x" + + webBrowser.getScreenHeight(); + setContent(new Label("Using a touch enabled device with screen size" + + screenSize)); + } +} +.... + +We then define an UIProvider which knows what UI the application should +return. + +[source,java] +.... +public class DifferentFeaturesForDifferentClients extends UIProvider { + + @Override + public Class<? extends UI> getUIClass(UIClassSelectionEvent event) { + // could also use browser version etc. + if (event.getRequest().getHeader("user-agent").contains("mobile")) { + return TouchUI.class; + } else { + return DefaultUI.class; + } + } +} +.... + +Now that we have an `UIProvider` we need to tell Vaadin to use it. This is +most easily done by defining the `UIProvider` class in web.xml instead of +defining a UI class. + +[source,xml] +.... +<servlet> + <servlet-name>My Vaadin App</servlet-name> + <servlet-class>com.vaadin.server.VaadinServlet</servlet-class> + <init-param> + <description>Vaadin UI</description> + <param-name>UIProvider</param-name> + <param-value>com.example.myexampleproject.DifferentFeaturesForDifferentClients</param-value> + </init-param> +</servlet> +.... + +Each UI can have its own feature set, layout and theme. diff --git a/documentation/articles/contents.asciidoc b/documentation/articles/contents.asciidoc index 3f697441d0..549d75c4cd 100644 --- a/documentation/articles/contents.asciidoc +++ b/documentation/articles/contents.asciidoc @@ -7,3 +7,4 @@ - link:OfflineModeForTouchKit4MobileApps.asciidoc[Offline mode for TouchKit 4 mobile apps] - link:CreatingYourOwnConverterForString.asciidoc[Creating your own converter for String] - link:ChangingTheDefaultConvertersForAnApplication.asciidoc[Changing the default converters for an application] +- link:CreatingAnApplicationWithDifferentFeaturesForDifferentClients.asciidoc[Creating an application with different features for different clients] |