/**
* Copyright (C) 2007 EDIT
-* European Distributed Institute of Taxonomy
+* European Distributed Institute of Taxonomy
* http://www.e-taxonomy.eu
-*
+*
* The contents of this file are subject to the Mozilla Public License Version 1.1
* See LICENSE.TXT at the top of this package for the full license terms.
*/
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.swt.widgets.Display;
import org.eclipse.ui.IWorkbenchPage;
-import org.eclipse.ui.PartInitException;
import org.eclipse.ui.handlers.HandlerUtil;
+import eu.etaxonomy.cdm.api.service.config.TaxonDeletionConfigurator;
import eu.etaxonomy.cdm.model.common.CdmBase;
import eu.etaxonomy.cdm.model.taxon.Synonym;
import eu.etaxonomy.cdm.model.taxon.Taxon;
import eu.etaxonomy.taxeditor.editor.EditorUtil;
-import eu.etaxonomy.taxeditor.editor.MultiPageTaxonEditor;
import eu.etaxonomy.taxeditor.editor.Page;
import eu.etaxonomy.taxeditor.editor.name.TaxonNameEditor;
import eu.etaxonomy.taxeditor.editor.name.operation.DeleteMisapplicationOperation;
import eu.etaxonomy.taxeditor.editor.name.operation.DeleteSynonymOperation;
import eu.etaxonomy.taxeditor.editor.name.operation.DeleteTaxonOperation;
+import eu.etaxonomy.taxeditor.model.AbstractUtility;
import eu.etaxonomy.taxeditor.model.MessagingUtils;
import eu.etaxonomy.taxeditor.operation.AbstractPostOperation;
import eu.etaxonomy.taxeditor.operation.IPostOperationEnabled;
* @see org.eclipse.core.commands.IHandler#execute(org.eclipse.core.commands.ExecutionEvent)
*/
/** {@inheritDoc} */
- public Object execute(ExecutionEvent event) throws ExecutionException {
+ @Override
+ public Object execute(ExecutionEvent event) throws ExecutionException {
editor = (TaxonNameEditor) EditorUtil.getActiveEditorPage(Page.NAME);
-
+
Object selectedElement = EditorUtil.getSelection(event).getFirstElement();
-
+
doExecute(event, editor, selectedElement);
-
+
return null;
}
-
+
/**
* @param editor
* @param selectedElement
*/
protected void doExecute(ExecutionEvent event, TaxonNameEditor editor, Object selectedElement) {
AbstractPostOperation operation = null;
- String commandName = null;
+ String commandName = null;
try {
commandName = event.getCommand().getName();
} catch (NotDefinedException e) {
MessagingUtils.error(getClass(), e);
}
-
+
// synonym
if(selectedElement instanceof Synonym){
operation = new DeleteSynonymOperation(commandName, editor.getUndoContext(), editor.getTaxon(), (Synonym) selectedElement, editor);
if(! MessageDialog.openConfirm(HandlerUtil.getActiveShell(event), "Confirm Deletion", "Are you sure you want to delete the selected taxon?")){
return ;
}
+
IWorkbenchPage activePage = HandlerUtil.getActiveWorkbenchWindow(event).getActivePage();
-
- operation = new DeleteTaxonOperation(commandName, editor.getUndoContext(),(Taxon) selectedElement, null, activePage, this, editor);
+
+ operation = new DeleteTaxonOperation(commandName, editor.getUndoContext(),(Taxon) selectedElement, new TaxonDeletionConfigurator(), null, activePage, this, editor);
//editor.dispose();
-
+
}
else {
throw new IllegalArgumentException("Element has to be Synonym, Misapplication or Concept");
}
-
- EditorUtil.executeOperation(operation);
-
-
-
-
+
+ AbstractUtility.executeOperation(operation);
}
@Override
public boolean postOperation(CdmBase objectAffectedByOperation) {
Display.getDefault().asyncExec(new Runnable(){
- public void run() {
- EditorUtil.close(editor.getMultiPageTaxonEditor());
-
+ @Override
+ public void run() {
+ AbstractUtility.close(editor.getMultiPageTaxonEditor());
}
-
});
-
-
return true;
}
// TODO Auto-generated method stub
return false;
}
-
-
+
}
import org.eclipse.core.runtime.IAdaptable;\r
import org.eclipse.core.runtime.IProgressMonitor;\r
import org.eclipse.core.runtime.IStatus;\r
-import org.eclipse.ui.IEditorInput;\r
-import org.eclipse.ui.IEditorReference;\r
-import org.eclipse.ui.IPerspectiveDescriptor;\r
-import org.eclipse.ui.IViewPart;\r
import org.eclipse.ui.IWorkbenchPage;\r
-import org.eclipse.ui.PartInitException;\r
\r
import eu.etaxonomy.cdm.api.conversation.IConversationEnabled;\r
-import eu.etaxonomy.cdm.model.taxon.Taxon;\r
-import eu.etaxonomy.cdm.model.taxon.TaxonNode;\r
-import eu.etaxonomy.taxeditor.editor.EditorUtil;\r
-import eu.etaxonomy.taxeditor.editor.TaxonEditorInput;\r
+import eu.etaxonomy.cdm.api.service.config.TaxonDeletionConfigurator;\r
import eu.etaxonomy.taxeditor.operation.AbstractPersistentPostOperation;\r
import eu.etaxonomy.taxeditor.operation.IPostOperationEnabled;\r
\r
public class DeleteTaxonBaseOperation extends AbstractPersistentPostOperation {\r
- \r
- private IWorkbenchPage activePage;\r
- \r
+\r
+ protected TaxonDeletionConfigurator configurator;\r
+\r
public DeleteTaxonBaseOperation(String label, IUndoContext undoContext,\r
- Taxon taxon, IWorkbenchPage activePage, IPostOperationEnabled postOperationEnabled, IConversationEnabled conversationEnabled) {\r
+ TaxonDeletionConfigurator configurator, IWorkbenchPage activePage, IPostOperationEnabled postOperationEnabled, IConversationEnabled conversationEnabled) {\r
super(label, undoContext, postOperationEnabled,\r
conversationEnabled);\r
- this.activePage = activePage;\r
- \r
+ this.configurator = configurator;\r
+\r
}\r
\r
@Override\r
// TODO Auto-generated method stub\r
return null;\r
}\r
- \r
- protected void closeObsoleteEditor(Taxon taxon){\r
- for (IEditorReference ref : activePage.getEditorReferences()) {\r
- \r
- IViewPart view = activePage.findView("eu.etaxonomy.taxeditor.navigation.navigator");\r
- \r
- try {\r
- IEditorInput input = ref.getEditorInput(); \r
- if (input instanceof TaxonEditorInput) {\r
- TaxonNode node = ((TaxonEditorInput) input).getTaxonNode();\r
- if (taxonNode.equals(node)) {\r
- activePage.closeEditor(ref.getEditor(false), false);\r
- }\r
- }\r
- } catch (PartInitException e) {\r
- continue;\r
- }\r
- }\r
- }\r
}\r
-\r
-\r
import eu.etaxonomy.taxeditor.store.CdmStore;\r
\r
public class DeleteTaxonOperation extends DeleteTaxonBaseOperation{\r
- //private Taxon taxon;\r
- private final Classification classification;\r
-\r
-\r
\r
+ private final Classification classification;\r
\r
public DeleteTaxonOperation(String label, IUndoContext undoContext,\r
- Taxon taxon, Classification classification, IWorkbenchPage activePage, IPostOperationEnabled postOperationEnabled, IConversationEnabled conversationEnabled) {\r
- super(label, undoContext, taxon, activePage, postOperationEnabled, conversationEnabled);\r
+ Taxon taxon, TaxonDeletionConfigurator configurator, Classification classification, IWorkbenchPage activePage, IPostOperationEnabled postOperationEnabled, IConversationEnabled conversationEnabled) {\r
+ super(label, undoContext, configurator, activePage, postOperationEnabled, conversationEnabled);\r
this.element = taxon;\r
\r
Set<TaxonNode> nodes = taxon.getTaxonNodes();\r
\r
}\r
\r
-\r
-\r
@Override\r
public IStatus execute(IProgressMonitor monitor, IAdaptable info)\r
throws ExecutionException {\r
\r
ICdmApplicationConfiguration controller;\r
\r
- controller = (ICdmApplicationConfiguration) CdmStore.getCurrentApplicationConfiguration();\r
+ controller = CdmStore.getCurrentApplicationConfiguration();\r
\r
ITaxonService service = controller.getTaxonService();\r
- \r
\r
- DeleteResult result = service.deleteTaxon(element, new TaxonDeletionConfigurator(), classification);\r
+\r
+ DeleteResult result = service.deleteTaxon(element, configurator, classification);\r
if (result.isError()){\r
MessageDialog.openError(null, "Delete failed", result.getExceptions().get(0).getMessage());\r
}\r
\r
- //closeObsoleteEditor(taxon);\r
monitor.worked(40);\r
\r
\r
return null;\r
}\r
\r
-\r
-}\r
+}
\ No newline at end of file