/*******************************************************************************
* Copyright (c) 2010-2015 Henshin developers. 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:
* TU Berlin, University of Luxembourg, SES S.A.
*******************************************************************************/
package de.tub.tfs.henshin.editor.actions.graph;
import java.util.List;
import org.eclipse.emf.ecore.EReference;
import org.eclipse.emf.henshin.model.Edge;
import org.eclipse.emf.henshin.model.Graph;
import org.eclipse.emf.henshin.model.Node;
import org.eclipse.gef.EditPart;
import org.eclipse.gef.commands.Command;
import org.eclipse.gef.ui.actions.SelectionAction;
import org.eclipse.jface.resource.ImageDescriptor;
import org.eclipse.jface.window.Window;
import org.eclipse.ui.IWorkbenchPart;
import de.tub.tfs.henshin.editor.commands.graph.CreateEdgeCommand;
import de.tub.tfs.henshin.editor.ui.dialog.CreateEdgeDialog;
import de.tub.tfs.henshin.editor.util.IconUtil;
import de.tub.tfs.henshin.model.layout.EContainerDescriptor;
/**
* The Class CreateEdgeAction.
*/
public class CreateEdgeAction extends SelectionAction {
/** The Constant ID. */
public static final String ID = "henshineditor.actions.CreateEdgeAction";
/** The graph. */
private Graph graph;
/**
* This constructor invokes the super constructor with the given
* {@code part}, sets the ID, action text, tool tip text, and initializes
* {@code targets} and {@code ereferences} to save the target nodes and the
* allow edges.
*
* @param part
* A workbench part.
*/
public CreateEdgeAction(IWorkbenchPart part) {
super(part);
setId(ID);
setText("Edge");
setToolTipText("Create Edge");
}
/*
* (non-Javadoc)
*
* @see org.eclipse.gef.ui.actions.WorkbenchPartAction#calculateEnabled()
*/
@Override
protected boolean calculateEnabled() {
List<?> selectedObjects = getSelectedObjects();
graph = null;
if (selectedObjects.size() == 1) {
Object selectedObject = selectedObjects.get(0);
if ((selectedObject instanceof EditPart)) {
EditPart editpart = (EditPart) selectedObject;
Object selectedModel = editpart.getModel();
if (selectedModel instanceof Graph) {
graph = (Graph) selectedModel;
}
if (selectedModel instanceof EContainerDescriptor
&& editpart.getAdapter(Edge.class) != null) {
graph = (Graph) ((EContainerDescriptor) selectedModel)
.getContainer();
}
}
}
return graph != null;
}
/**
* �berpr�ft vor dem Erzeugen einer Kante, ob �berhaupt Knoten
* vorhanden sind. Sind keine Knoten vorhanden, wird dies dem User
* mitgeteilt. Ist mindestens ein Knoten vorhanden, so wird �ber ein
* Dialog sowohl Ziel- als auch Startknoten abgefragt. Existiert zwischen
* Ziel und Startknoten bereits eine Kante, wird dies dem User mitgeteilt
* und das Hinzuf�gen abgebrochen. Existiert dort noch keine Kante, so
* wird diese �ber den execute Befehl hinzugef�gt und dem User wird das
* erzeugen der Kante mitgeteilt.
*/
@Override
public void run() {
CreateEdgeDialog dialog = new CreateEdgeDialog(getWorkbenchPart()
.getSite().getShell(), graph, "Create Edge");
dialog.open();
if (dialog.getReturnCode() == Window.OK) {
Node source = dialog.getSource();
Node target = dialog.getTarget();
EReference type = dialog.getEdgeType();
Command command = new CreateEdgeCommand(graph, source, target, type);
execute(command);
}
}
/*
* (non-Javadoc)
*
* @see org.eclipse.jface.action.Action#getImageDescriptor()
*/
@Override
public ImageDescriptor getImageDescriptor() {
return IconUtil.getDescriptor("edge18.png");
}
}