Sub-Windows

Live Demo

Sub-windows are floating panels within a native browser window. Unlike native browser windows, sub-windows are managed by the client-side runtime of Vaadin using HTML features. Vaadin allows opening, closing, resizing, maximizing and restoring sub-windows, as well as scrolling the window content.

subwindow basic

A Sub-Window

Sub-windows are typically used for Dialog Windows and Multiple Document Interface applications. Sub-windows are by default not modal; you can set them modal as described in Modal Sub-Windows.

Opening and Closing Sub-Windows

You can open a new sub-window by creating a new Window object and adding it to the UI with addWindow(), typically in some event listener. A sub-window needs a content component, which is typically a layout.

In the following, we display a sub-window immediately when a UI opens:

Java

  1. public static class SubWindowUI extends UI {
  2. @Override
  3. protected void init(VaadinRequest request) {
  4. // Some other UI content
  5. setContent(new Label("Here's my UI"));
  6. // Create a sub-window and set the content
  7. Window subWindow = new Window("Sub-window");
  8. VerticalLayout subContent = new VerticalLayout();
  9. subContent.setMargin(true);
  10. subWindow.setContent(subContent);
  11. // Put some components in it
  12. subContent.addComponent(new Label("Meatball sub"));
  13. subContent.addComponent(new Button("Awlright"));
  14. // Center it in the browser window
  15. subWindow.center();
  16. // Open it in the UI
  17. addWindow(subWindow);
  18. }
  19. }

The result was shown in A Sub-Window. Sub-windows by default have undefined size in both dimensions, so they will shrink to fit the content.

The user can close a sub-window by clicking the close button in the upper-right corner of the window. The button is controlled by the closable property, so you can disable it with setClosable(false). You can also use keyboard shortcuts for closing a sub-window. You can manage the shortcuts with the addCloseShortcut(), removeCloseShortcut(), removeAllCloseShortcuts(), hasCloseShortcut(), and getCloseShortcuts() methods.

You close a sub-window also programmatically by calling the close() for the sub-window, typically in a click listener for an OK or Cancel button. You can also call removeWindow() for the current UI.

Sub-Window Management

Usually, you would extend the Window class for your specific sub-window as follows:

Java

  1. // Define a sub-window by inheritance
  2. class MySub extends Window {
  3. public MySub() {
  4. super("Subs on Sale"); // Set window caption
  5. center();
  6. // Some basic content for the window
  7. VerticalLayout content = new VerticalLayout();
  8. content.addComponent(new Label("Just say it's OK!"));
  9. content.setMargin(true);
  10. setContent(content);
  11. // Disable the close button
  12. setClosable(false);
  13. // Trivial logic for closing the sub-window
  14. Button ok = new Button("OK");
  15. ok.addClickListener(new ClickListener() {
  16. public void buttonClick(ClickEvent event) {
  17. close(); // Close the sub-window
  18. }
  19. });
  20. content.addComponent(ok);
  21. }
  22. }

You could open the window as follows:

Java

  1. // Some UI logic to open the sub-window
  2. final Button open = new Button("Open Sub-Window");
  3. open.addClickListener(new ClickListener() {
  4. public void buttonClick(ClickEvent event) {
  5. MySub sub = new MySub();
  6. // Add it to the root component
  7. UI.getCurrent().addWindow(sub);
  8. }
  9. });

Window Positioning

When created, a sub-window will have an undefined default size and position. You can specify the size of a window with setHeight() and setWidth() methods. You can set the position of the window with setPositionX() and setPositionY() methods.

Java

  1. // Create a new sub-window
  2. mywindow = new Window("My Dialog");
  3. // Set window size.
  4. mywindow.setHeight("200px");
  5. mywindow.setWidth("400px");
  6. // Set window position.
  7. mywindow.setPositionX(200);
  8. mywindow.setPositionY(50);
  9. UI.getCurrent().addWindow(mywindow);

Scrolling Sub-Window Content

If a sub-window has a fixed or percentual size and its content becomes too big to fit in the content area, a scroll bar will appear for the particular direction. On the other hand, if the sub-window has undefined size in the direction, it will fit the size of the content and never get a scroll bar. Scroll bars in sub-windows are handled with regular HTML features, namely overflow: auto property in CSS.

As Window extends Panel, windows are also Scrollable. Note that the interface defines programmatic scrolling, not scrolling by the user. Please see “Panel”.

Modal Sub-Windows

A modal window is a sub-window that prevents interaction with the other UI. Dialog windows, as illustrated in Modal Sub-Window, are typical cases of modal windows. The advantage of modal windows is limiting the scope of user interaction to a sub-task, so changes in application state are more limited. The disadvantage of modal windows is that they can restrict workflow too much.

You can make a sub-window modal with setModal(true).

subwindow modal

Modal Sub-Window

Depending on the theme, the parent window may be grayed when the modal window is open.

Warning
Security Warning

Modality of child windows is purely a client-side feature and can be circumvented with client-side attack code. You should not trust in the modality of child windows in security-critical situations such as login windows.