package eu.etaxonomy.taxeditor.bulkeditor.handler;
+import java.util.ArrayList;
+import java.util.List;
+
import org.eclipse.core.commands.AbstractHandler;
import org.eclipse.core.commands.ExecutionEvent;
import org.eclipse.core.commands.ExecutionException;
import eu.etaxonomy.taxeditor.annotatedlineeditor.LineAnnotationModel;
import eu.etaxonomy.taxeditor.bulkeditor.BulkEditor;
import eu.etaxonomy.taxeditor.bulkeditor.internal.TaxeditorBulkeditorPlugin;
+import eu.etaxonomy.taxeditor.model.DeleteResultMessagingUtils;
import eu.etaxonomy.taxeditor.model.MessagingUtils;
import eu.etaxonomy.taxeditor.store.CdmStore;
LineAnnotation annotation = (LineAnnotation) model.getAnnotation(object);
DeleteResult result = new DeleteResult();
+ String errorMessage= "The object ";
//result.setError();
try {
ICdmApplicationConfiguration controller;
IOccurrenceService service = controller.getOccurrenceService();
if (object != null){
result = service.delete(((SpecimenOrObservationBase) object).getUuid());
+ errorMessage = "The specimen or observation ";
}
} else if (object instanceof Reference){
IReferenceService service = controller.getReferenceService();
if (object != null){
result = service.delete(((Reference) object).getUuid());
+ errorMessage = "The reference ";
}
} else if (object instanceof Group){
IGroupService service = controller.getGroupService();
if (object != null){
result = service.delete(((Group) object).getUuid());
+ errorMessage = "The group ";
}
}else if (object instanceof User){
IUserService service = controller.getUserService();
if (object != null){
result = service.delete(((User) object).getUuid());
+ errorMessage = "The user ";
}
} else if (object instanceof TaxonNameBase){
INameService service = controller.getNameService();
if (object != null){
NameDeletionConfigurator config = new NameDeletionConfigurator();
result = service.delete(((TaxonNameBase) object).getUuid(), config);
+ errorMessage = "The name ";
}
} else if (object instanceof TaxonBase){
ITaxonService service = controller.getTaxonService();
if (object != null){
if (object instanceof Taxon){
result = service.deleteTaxon(((TaxonBase) object).getUuid(), null, null);
+ errorMessage = "The taxon ";
}else{
result = service.deleteSynonym(((Synonym)object).getUuid(), null);
+ errorMessage = "The synonym ";
}
}
} else if (object instanceof TeamOrPersonBase){
IAgentService service = controller.getAgentService();
//TeamOrPersonBase teamOrPerson = (TeamOrPersonBase)service.load(((TeamOrPersonBase) object).getUuid());
result = service.delete(((TeamOrPersonBase)object).getUuid());
+ errorMessage = "The team or person ";
}
} catch (Exception e){
MessagingUtils.errorDialog("Exception occured. Delete not possible", getClass(), e.getMessage(), TaxeditorBulkeditorPlugin.PLUGIN_ID, null, true);
}
if (result.isError() || result.isAbort()){
if (!result.getExceptions().isEmpty()) {
- String message = null;
+ List<String> messages = new ArrayList<String>();
int i = result.getExceptions().size();
for (Exception e:result.getExceptions()){
- i--;
- message+= e.getMessage();
- if (i>0){
- message+= ", ";
- }
+ messages.add(e.getMessage());
}
+ errorMessage += "could not be deleted.";
-
- MessagingUtils.messageDialog("Delete not possible", getClass(), result.getExceptions().toString(), null);
+ DeleteResultMessagingUtils.messageDialogWithDetails(result,errorMessage, TaxeditorBulkeditorPlugin.PLUGIN_ID);
}else{
MessagingUtils.messageDialog("Delete not possible", getClass(), "The object could not be deleted. An exception occured.", null);
}
if (result.isOk() ){
((BulkEditor) editor).removeAnnotatedLine(annotation);
if(result.getUpdatedObjects().size() != 0 || !result.getExceptions().isEmpty()){
- MessagingUtils.informationDialog("Delete successfull", "The object is deleted but there are updated objects: " + result.toString());
+ List<String> messages = new ArrayList<String>();
+ int i = result.getExceptions().size();
+ for (Exception e:result.getExceptions()){
+ messages.add(e.getMessage());
+ }
+ errorMessage += "was deleted but there where updated objects";
+ DeleteResultMessagingUtils.messageDialogWithDetails(result, errorMessage, TaxeditorBulkeditorPlugin.PLUGIN_ID);
}
}
}
/* (non-Javadoc)
- * @see eu.etaxonomy.cdm.api.service.IService#merge(java.util.List, boolean)
+
+ * @see eu.etaxonomy.cdm.api.service.IDescriptionService#moveTaxonDescription(java.util.UUID, java.util.UUID)
*/
@Override
- public List<DescriptionBase> merge(List<DescriptionBase> arg0, boolean arg1) {
- return defaultService.merge(arg0, arg1);
+ public UpdateResult moveTaxonDescription(UUID descriptionUuid, UUID targetTaxonUuid) {
+ return defaultService.moveTaxonDescription(descriptionUuid, targetTaxonUuid);
}
/* (non-Javadoc)
- * @see eu.etaxonomy.cdm.api.service.IDescriptionService#moveTaxonDescription(java.util.UUID, java.util.UUID)
+ * @see eu.etaxonomy.cdm.api.service.IService#merge(java.util.List, boolean)
*/
@Override
- public UpdateResult moveTaxonDescription(UUID arg0, UUID arg1) {
+ public List<DescriptionBase> merge(List<DescriptionBase> arg0, boolean arg1) {
- return defaultService.moveTaxonDescription(arg0, arg1);
+ return defaultService.merge(arg0, arg1);
}
+
+
+
}
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
+import eu.etaxonomy.cdm.api.application.CdmApplicationRemoteController;
+import eu.etaxonomy.cdm.api.application.CdmApplicationState;
import eu.etaxonomy.cdm.api.conversation.IConversationEnabled;
import eu.etaxonomy.cdm.api.service.IDescriptionService;
import eu.etaxonomy.cdm.model.common.Annotation;
annotation.setAnnotationType(AnnotationType.TECHNICAL());
description.addAnnotation(annotation);
newAcceptedTaxonNode.getTaxon().addDescription(description);
- CdmStore.getService(IDescriptionService.class).merge(description);
+ if (CdmApplicationState.getCurrentAppConfig() instanceof CdmApplicationRemoteController) {
+ CdmStore.getService(IDescriptionService.class).merge(description);
+ } else {
+ CdmStore.getService(IDescriptionService.class).saveOrUpdate(description);
+ }
+
+ // CdmStore.getService(IDescriptionService.class).moveTaxonDescription(description.getUuid(), newAcceptedTaxonNode.getTaxon().getUuid());
monitor.worked(40);
return postExecute(description);
--- /dev/null
+// $Id$
+/**
+* Copyright (C) 2015 EDIT
+* 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.
+*/
+package eu.etaxonomy.taxeditor.model;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.eclipse.core.runtime.IStatus;
+import org.eclipse.core.runtime.Status;
+
+import eu.etaxonomy.cdm.api.service.DeleteResult;
+
+/**
+ * @author k.luther
+ * @date Oct 5, 2015
+ *
+ */
+public class DeleteResultMessagingUtils extends MessagingUtils {
+ /**
+ * Displays a message {@link org.eclipse.jface.dialogs.MessageDialog}.
+ *
+ * @param title
+ * @param source
+ * @param message
+ */
+ public static void messageDialogWithDetails(DeleteResult result, String message, String pluginId) {
+ if (result.isOk() && result.getExceptions().isEmpty()){
+ return;
+ }
+ List<String> details = new ArrayList<String>();
+ String title= "";
+
+ if (result.isOk() && result.getExceptions().size() > 0){
+ for (Exception e:result.getExceptions()){
+ details.add(e.getMessage());
+ }
+ title = "The delete was successfull.";
+ }
+ String stackTraceWithContext = getContextInfo(details);
+ CdmErrorDialog ced = new CdmErrorDialog(AbstractUtility.getShell(), title, message, new Status(IStatus.ERROR, pluginId, null), stackTraceWithContext);
+ ced.open();
+
+
+
+ }
+}