aboutsummaryrefslogtreecommitdiffstats
path: root/documentation/articles/AccessingWebPageAndBrowserInformation.asciidoc
blob: 2aea7b8d1a95b4a4ddfe2b553ce506ce4038de7a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
[[accessing-web-page-and-browser-information]]
Accessing web page and browser information
------------------------------------------

Vaadin 7 includes a new *Page* class offering access to various
client-side information and events concerning the web page and browser
window in which the Vaadin UI resides. The Page instance corresponding
to a given UI is accessed via the `getPage()` method of the UI or using
a static method `Page.getCurrent()`.

You can access the browser window size and add size change listeners:

[source,java]
....
Page page = someUI.getPage();
page.addBrowserWindowResizeListener(new BrowserWindowResizeListener() {
  public void browserWindowResized(BrowserWindowResizeEvent event) {
    Notification.show("Window width=" + event.getWidth() + ", height=" + event.getHeight());
  }
});
....

You can access the optional fragment part of the location URI and add
fragment change listeners:

[source,java]
....
page.setUriFragment(page.getUriFragment() + "foo");
page.addUriFragmentChangedListener(new UriFragmentChangedListener() {
  public void uriFragmentChanged(UriFragmentChangedEvent event) {
    Notification.show("Fragment=" + event.getUriFragment());
  }
});
....

You can access client browser details:

[source,java]
....
Notification.show("IP" + browser.getAddress() +
                "User-Agent:" + browser.getBrowserApplication() +
                "Linux: " + browser.isLinux());
....

https://demo.vaadin.com/sampler/#foundation/advanced/browser-information[Live
Demo]

Note: If you are using a reverse proxy, you must get the value
`X-Forwarded-For` from request headers. You cannot get a browser name,
but you can check which browser are using.