blob: 33c99eab2869c0741cf180b03670648341294e5c [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2006, 2008 Oracle. 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:
* Oracle - initial API and implementation
******************************************************************************/
package org.eclipse.jpt.ui.details;
import org.eclipse.core.runtime.content.IContentType;
import org.eclipse.jpt.core.JpaStructureNode;
import org.eclipse.jpt.ui.WidgetFactory;
import org.eclipse.swt.widgets.Composite;
/**
* This provider is responsible to create the {@link JpaDetailsPage}
* responsible to show the information for a given content node id.
*
* @see JpaDetailsPage
*
* @version 2.2
* @since 2.0
*
* Provisional API: This interface is part of an interim API that is still
* under development and expected to change significantly before reaching
* stability. It is available at this early stage to solicit feedback from
* pioneering adopters on the understanding that any code that uses this API
* will almost certainly be broken (repeatedly) as the API evolves.
*/
public interface JpaDetailsProvider
{
/**
* Creates a new details page based on the given content node id.
*
* @param parent The parent container
* @param contentNodeId The unique identifier used to determine which details
* page to create
* @param widgetFactory The factory used to create various widgets
*/
//TODO Should we pass in JpaUiFactory so these pages can be built using the factory and overriden?
JpaDetailsPage<? extends JpaStructureNode> buildDetailsPage(
Composite parent,
WidgetFactory widgetFactory);
/**
* Return the id of the corresponding JpaStructureNode.
*/
String getId();
/**
* Return the content type of the reosurce
*/
IContentType getContentType();
}