summaryrefslogtreecommitdiffstats
path: root/documentation
diff options
context:
space:
mode:
authorErik Lumme <erik@vaadin.com>2017-09-14 13:25:06 +0300
committerErik Lumme <erik@vaadin.com>2017-09-14 13:25:06 +0300
commit77c61ecb71c9a86a6abc722844fededc071daae8 (patch)
tree7d222c0318eb535c41a7f55cd2898a0da4ab12b3 /documentation
parenta40be2471984c218b641c3c9a133055d19d32bc4 (diff)
downloadvaadin-framework-77c61ecb71c9a86a6abc722844fededc071daae8.tar.gz
vaadin-framework-77c61ecb71c9a86a6abc722844fededc071daae8.zip
Migrate CreatingAnApplicationWithDIfferentFeaturesForDIfferentClients
Diffstat (limited to 'documentation')
-rw-r--r--documentation/articles/CreatingAnApplicationWithDifferentFeaturesForDifferentClients.asciidoc71
-rw-r--r--documentation/articles/contents.asciidoc1
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]