Adding a view

In the following, we’re going to create a new view and add it to the navigation, step-by-step. The view we are creating here is an "About" view.

Creating a design

The views of bakery are built with Vaadin Designer. We start off by creating a new Vaadin Platform Design named about-view.js in src/main/resources/static/frontend/src. Designer will add the .js suffix for us. Check "Create Java companion file", pick "Java source root" as src/main/java and set "Java package" as com.vaadin.starter.bakery.ui. Vaadin Designer also will create a corresponding class.

Open the generated about-view.js template in Designer’s source mode and replace the contents with this:

import {html, PolymerElement} from '@polymer/polymer/polymer-element.js';

 * `about-view`
 * AboutView element.
 * @customElement
 * @polymer
class AboutView extends PolymerElement {

    static get template() {
        return html`
            <style include="shared-styles">
                 :host {
                     display: flex;
                     flex-direction: column;
                 div {
                     margin: auto;
                This is a new web application based on the <a href="">Vaadin Bakery App Starter.</a>

    static get is() {
        return 'about-view';

    static get properties() {
        return {
            // Declare your properties here.

customElements.define(, AboutView);

This defines the about-view as web component that displays a simple text and a link. You can add new components and content to this template.


Open the Java class AboutView in the com.vaadin.starter.bakery.ui package. AboutView instance will be initialized when the user wants to enter the view.

Add the Route annotation to the class:

@Route(value = "about", layout = MainView.class)

Now we have a valid view in our application, and you can access it at http://localhost:8080/about. Any logic or configuration that you want to add into the view goes here.

Process navigation

You can control the view navigation logic by implementing BeforeEnterObserver or BeforeLeaveObserver. More about navigation lifecycle.

Including the view to the application menu

The last thing for us is to add the view in our UI. This is achieved by adding the following into the getAvailableTabs method of MainView:

if (SecurityUtils.isAccessGranted(AboutView.class)) {
  tabs.add(createTab(VaadinIcon.QUESTION_CIRCLE_O, "About", AboutView.class));

After this change, the view also appears in the application main menu.

You probably want to add the parameters as constants in BakeryConst instead of using strings here directly. This is left as an exercise for the reader.

Restricting access to the view.

If you want to restrict access to some views, you can require the user to have certain roles by adding an annotation. Restricting access to the about view might not make much sense usually, but we’ll do it anyway by adding the following annotation to AboutView:


@Secured(Role.ADMIN) will require that the logged in user has the ADMIN role to be able to access the view. If the user does not have the role, then the link to the view will not present in the menu and the user will get an "Access denied" message in case he tries to access it with a direct URL or otherwise.

Data binding

There are several ways to exchange data between server and client.

Bind by Id

Any element in the design can be bound by id. For example, drag h1 element from Designer Palette to Outline.

Template can be edited in source code mode as well.

To bind new element to the server-side just check Java check-box at the Outline. Go to, Designer generated there the following code:

@Id("h1") private H1 h1;

As an example, add such constructor:

public AboutView() {
    h1.setText("About view");

Bind by Polymer template property