/*******************************************************************************
* Copyright (c) 2011, 2012 Wind River Systems, Inc. and others. All rights reserved.
* This program and the accompanying materials are made available under the terms
* of the Eclipse Public License v1.0 which accompanies this distribution, and is
* available at http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Wind River Systems - initial API and implementation
*******************************************************************************/
package org.eclipse.tcf.te.ui.forms.parts;
import org.eclipse.core.runtime.Assert;
import org.eclipse.jface.viewers.DoubleClickEvent;
import org.eclipse.jface.viewers.IDoubleClickListener;
import org.eclipse.jface.viewers.ISelectionChangedListener;
import org.eclipse.jface.viewers.SelectionChangedEvent;
import org.eclipse.jface.viewers.StructuredViewer;
import org.eclipse.jface.viewers.TreeViewer;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.ui.forms.IManagedForm;
import org.eclipse.ui.forms.widgets.FormToolkit;
/**
* Abstract tree section implementation.
*/
public abstract class AbstractTreeSection extends AbstractStructuredViewerSection implements ISelectionChangedListener, IDoubleClickListener {
/**
* Tree section tree part adapter implementation.
*/
protected class TreePartAdapter extends TreePart {
/**
* Constructor.
*
* @param labels The list of label to apply to the created buttons in the given order. Must not be <code>null</code>.
*/
public TreePartAdapter(String[] labels) {
super(labels);
}
/* (non-Javadoc)
* @see org.eclipse.tcf.te.ui.forms.parts.TablePart#selectionChanged(org.eclipse.jface.viewers.SelectionChangedEvent)
*/
@Override
public void selectionChanged(SelectionChangedEvent event) {
getManagedForm().fireSelectionChanged(AbstractTreeSection.this, event.getSelection());
AbstractTreeSection.this.selectionChanged(event);
}
/* (non-Javadoc)
* @see org.eclipse.tcf.te.ui.forms.parts.TablePart#doubleClick(org.eclipse.jface.viewers.DoubleClickEvent)
*/
@Override
public void doubleClick(DoubleClickEvent event) {
AbstractTreeSection.this.doubleClick(event);
}
/* (non-Javadoc)
* @see org.eclipse.tcf.te.ui.forms.parts.AbstractPartWithButtons#onButtonSelected(org.eclipse.swt.widgets.Button)
*/
@Override
protected void onButtonSelected(Button button) {
AbstractTreeSection.this.onButtonSelected(button);
}
/* (non-Javadoc)
* @see org.eclipse.tcf.te.ui.forms.parts.AbstractPartWithButtons#createButtonsPanel(org.eclipse.swt.widgets.Composite, org.eclipse.ui.forms.widgets.FormToolkit)
*/
@Override
protected Composite createButtonsPanel(Composite parent, FormToolkit toolkit) {
Composite panel = super.createButtonsPanel(parent, toolkit);
initializeButtonsEnablement();
if (parent.getData("filtered") != null) { //$NON-NLS-1$
GridLayout layout = (GridLayout) panel.getLayout();
layout.marginHeight = 28;
}
return panel;
}
/* (non-Javadoc)
* @see org.eclipse.tcf.te.ui.forms.parts.AbstractPartWithButtons#onButtonCreated(org.eclipse.swt.widgets.Button)
*/
@Override
protected void onButtonCreated(Button button) {
AbstractTreeSection.this.onButtonCreated(button);
}
/* (non-Javadoc)
* @see org.eclipse.tcf.te.ui.forms.parts.TreePart#createTreeViewer(org.eclipse.swt.widgets.Composite, int)
*/
@Override
protected TreeViewer createTreeViewer(Composite parent, int style) {
return AbstractTreeSection.this.createTreeViewer(parent, style);
}
/* (non-Javadoc)
* @see org.eclipse.tcf.te.ui.forms.parts.TreePart#configureTreeViewer(org.eclipse.jface.viewers.TreeViewer)
*/
@Override
protected void configureTreeViewer(TreeViewer viewer) {
super.configureTreeViewer(viewer);
AbstractTreeSection.this.configureTreeViewer(viewer);
}
}
/**
* Constructor.
*
* @param form The parent managed form. Must not be <code>null</code>.
* @param parent The parent composite. Must not be <code>null</code>.
* @param style The section style.
* @param labels The list of label to apply to the created buttons in the given order. Must not be <code>null</code>.
*/
public AbstractTreeSection(IManagedForm form, Composite parent, int style, String[] labels) {
this(form, parent, style, true, labels);
}
/**
* Constructor.
*
* @param form The parent managed form. Must not be <code>null</code>.
* @param parent The parent composite. Must not be <code>null</code>.
* @param style The section style.
* @param titleBar If <code>true</code>, the title bar style bit is added to <code>style</code>.
* @param labels The list of label to apply to the created buttons in the given order. Must not be <code>null</code>.
*/
public AbstractTreeSection(IManagedForm form, Composite parent, int style, boolean titleBar, String[] labels) {
super(form, parent, style, titleBar, labels);
}
/* (non-Javadoc)
* @see org.eclipse.tcf.te.ui.forms.parts.AbstractStructuredViewerSection#createViewerPart(java.lang.String[])
*/
@Override
protected AbstractStructuredViewerPart createViewerPart(String[] labels) {
return new TreePartAdapter(labels);
}
/**
* Returns the tree part instance.
*
* @return The tree part instance.
*/
public TreePart getTreePart() {
return (TreePart)getViewerPart();
}
/**
* Reveals the tree viewer instance to clients.
*
* @return The tree viewer instance or <code>null</code>.
*/
public TreeViewer getViewer() {
StructuredViewer viewer = getTreePart().getViewer();
return viewer instanceof TreeViewer ? (TreeViewer)viewer : null;
}
/**
* Creates the tree viewer instance.
*
* @param parent The parent composite. Must not be <code>null</code>.
* @param style The viewer style.
*
* @return The tree viewer instance.
*/
protected TreeViewer createTreeViewer(Composite parent, int style) {
return new TreeViewer(parent, style);
}
/**
* Configures the tree viewer instance.
*
* @param viewer The tree viewer instance. Must not be <code>null</code<.
*/
protected void configureTreeViewer(TreeViewer viewer) {
Assert.isNotNull(viewer);
}
/* (non-Javadoc)
* @see org.eclipse.jface.viewers.ISelectionChangedListener#selectionChanged(org.eclipse.jface.viewers.SelectionChangedEvent)
*/
@Override
public void selectionChanged(SelectionChangedEvent event) {
}
/* (non-Javadoc)
* @see org.eclipse.jface.viewers.IDoubleClickListener#doubleClick(org.eclipse.jface.viewers.DoubleClickEvent)
*/
@Override
public void doubleClick(DoubleClickEvent event) {
}
/**
* Called from {@link TreePartAdapter#createButtonsPanel(Composite, FormToolkit)}.
*
* @param button The created button. Must not be <code>null</code>.
*/
protected void onButtonCreated(Button button) {
}
/**
* Initialize the enablement of the buttons in the buttons bar.
* <p>
* Called from {@link TreePartAdapter#createButtonsPanel(Composite, FormToolkit)}.
*/
protected void initializeButtonsEnablement() {
}
/**
* Indicates whether the sections parent page has become the active in the editor.
*
* @param active <code>True</code> if the parent page should be visible, <code>false</code> otherwise.
*/
public void setActive(boolean active) {
}
}