All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.activiti.explorer.ui.AbstractPage Maven / Gradle / Ivy

There is a newer version: 5.23.0
Show newest version
/* 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 org.activiti.explorer.ui;

import org.activiti.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
  @Override
  public void attach() {
   initUi();
  }
  
  /**
   * Override this method (and call super()) when you want to influence the UI.
   */
  protected void initUi() {
    showEvents = getEventComponent() != null;
    
    addMainLayout();
    setSizeFull();
    addMenuBar();
    addSearch();
    addSelectComponent();
    if(showEvents) {
      addEventComponent();
    }
  }
  
  protected void addEventComponent() {
    grid.addComponent(getEventComponent(), 2, 0, 2, 2);
  }

  /**
   * Subclasses are expected to provide their own menuBar.
   */
  protected void addMenuBar() {
    
    // Remove any old menu bar
    String activeEntry = null;
    if (toolBar != null) {
      activeEntry = toolBar.getCurrentEntryKey();
      grid.removeComponent(toolBar);
    }
    
    // Create menu bar
    ToolBar menuBar = createMenuBar();
    if (menuBar != null) {
      toolBar = createMenuBar();
      grid.addComponent(toolBar, 0, 0 , 1, 0);
      
      if (activeEntry != null) {
        toolBar.setActiveEntry(activeEntry);
      }
    }
  }
  
  public ToolBar getToolBar() {
    return toolBar;
  }
  
  protected abstract ToolBar createMenuBar();
  
  protected void addMainLayout() {
    if(showEvents) {
      grid = new GridLayout(3, 3);
      grid.setColumnExpandRatio(0, .25f);
      grid.setColumnExpandRatio(1, .52f);
      grid.setColumnExpandRatio(2, .23f);
    } else {
      grid = new GridLayout(2, 3);

      grid.setColumnExpandRatio(0, .25f);
      grid.setColumnExpandRatio(1, .75f);
    }
    
    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;
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy