com.klwork.explorer.ui.AbstractPage.java Source code

Java tutorial

Introduction

Here is the source code for com.klwork.explorer.ui.AbstractPage.java

Source

/* Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.klwork.explorer.ui;

import com.klwork.explorer.ui.custom.ToolBar;
import com.vaadin.ui.AbstractSelect;
import com.vaadin.ui.Component;
import com.vaadin.ui.CustomComponent;
import com.vaadin.ui.GridLayout;
import com.vaadin.ui.themes.Reindeer;

/**
 * Superclass for all Explorer pages
 * 
 * @author Joram Barrez
 * @author Frederik Heremans
 */
public abstract class AbstractPage extends CustomComponent {

    private static final long serialVersionUID = 1L;

    protected ToolBar toolBar;
    protected GridLayout grid;
    protected AbstractSelect select;
    protected boolean showEvents;

    // Overriding attach(), so we can construct the components first, before the UI is built,
    // that way, all member fields of subclasses are initialized properly
    //WW_TODO attach initUI
    @Override
    public void attach() {
        initUi();
    }

    /**
     * Override this method (and call super()) when you want to influence the UI.
     */
    protected void initUi() {
        //WW_TODO x initUI,?//?/
        //showEvents = getEventComponent() != null;
        showEvents = false;
        //GridLayout 3,3
        initMainLayout();
        setSizeFull();
        //,0, 0 , 1, 0 (
        addMenuBar();

        //? 0,1
        addSearch();

        //grid.addComponent(select, 0, 2),?table
        addSelectComponent();

        // 2, 0, 2, 2,,x
        if (showEvents) {
            addEventComponent();
        }
    }

    protected void addEventComponent() {
        grid.addComponent(getEventComponent(), 2, 0, 2, 2);
    }

    /**
     * Subclasses are expected to provide their own menuBar.
     */
    protected void addMenuBar() {
        ToolBar menuBar = createMenuBar();
        if (menuBar != null) {
            toolBar = createMenuBar();
            grid.addComponent(toolBar, 0, 0, 1, 0);
        }
    }

    public ToolBar getToolBar() {
        return toolBar;
    }

    protected abstract ToolBar createMenuBar();

    protected void initMainLayout() {
        if (showEvents) {
            grid = new GridLayout(3, 3);
            grid.setColumnExpandRatio(0, .20f);
            grid.setColumnExpandRatio(1, .57f);
            grid.setColumnExpandRatio(2, .23f);
        } else {
            grid = new GridLayout(2, 3);

            grid.setColumnExpandRatio(0, .20f);
            grid.setColumnExpandRatio(1, .80f);
        }

        grid.addStyleName(Reindeer.SPLITPANEL_SMALL);
        grid.setSizeFull();

        // Height division
        grid.setRowExpandRatio(2, 1.0f);

        setCompositionRoot(grid);
    }

    protected void addSearch() {
        Component searchComponent = getSearchComponent();
        if (searchComponent != null) {
            grid.addComponent(searchComponent, 0, 1);
        }
    }

    protected void addSelectComponent() {
        AbstractSelect select = createSelectComponent();
        if (select != null) {
            grid.addComponent(select, 0, 2);
        }
    }

    /**
     * Returns an implementation of {@link AbstractSelect},
     * which will be displayed on the left side of the page,
     * allowing to select elements from eg. a list, tree, etc.
     */
    protected abstract AbstractSelect createSelectComponent();

    /**
     * Refreshes the elements of the list, and selects the next
     * one (useful when the selected element is deleted).
     */
    public abstract void refreshSelectNext();

    /**
     * Select a specific element from the selection component.
     */
    public abstract void selectElement(int index);

    protected void setDetailComponent(Component detail) {
        if (grid.getComponent(1, 1) != null) {
            grid.removeComponent(1, 1);
        }
        if (detail != null) {
            grid.addComponent(detail, 1, 1, 1, 2);
        }
    }

    protected Component getDetailComponent() {
        return grid.getComponent(1, 0);
    }

    /**
     * Override to get the search component to display above the table. Return null
     * when no search should be displayed.
     */
    public Component getSearchComponent() {
        return null;
    }

    /**
     * Get the component to display the events in. 
     * 
     * Return null by default: no event-component will be used,
     * in that case the main UI will be two columns instead of three.
     * 
     * Override in case the event component must be shown:
     * three columns will be used then. 
     */
    protected Component getEventComponent() {
        return null;
    }

}