package eu.etaxonomy.taxeditor.navigation.navigator;
import java.util.ArrayList;
+import java.util.Comparator;
import java.util.HashSet;
import java.util.List;
import java.util.Observable;
import eu.etaxonomy.cdm.api.conversation.IConversationEnabled;
import eu.etaxonomy.cdm.api.service.IClassificationService;
import eu.etaxonomy.cdm.model.common.CdmBase;
+import eu.etaxonomy.cdm.model.taxon.TaxonNaturalComparator;
+import eu.etaxonomy.cdm.model.taxon.TaxonNode;
+import eu.etaxonomy.cdm.model.taxon.TaxonNodeByRankAndNameComparator;
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeMap;
import eu.etaxonomy.taxeditor.model.DataChangeBridge;
import eu.etaxonomy.taxeditor.model.IDataChangeBehavior;
+import eu.etaxonomy.taxeditor.model.MessagingUtils;
import eu.etaxonomy.taxeditor.navigation.NavigationUtil;
import eu.etaxonomy.taxeditor.operation.IPostOperationEnabled;
+import eu.etaxonomy.taxeditor.preference.PreferencesUtil;
import eu.etaxonomy.taxeditor.store.CdmStore;
import eu.etaxonomy.taxeditor.store.LoginManager;
/** {@inheritDoc} */
@Override
protected IAdaptable getInitialInput() {
+ Comparator<TaxonNode> comparator;
+ if (PreferencesUtil.getSortNodesNaturally()){
+ comparator = new TaxonNaturalComparator();
+ } else{
+ comparator = new TaxonNodeByRankAndNameComparator();
+ }
+ TaxonNodeNavigatorComparator viewerComparator = new TaxonNodeNavigatorComparator(comparator);
+ this.getCommonViewer().setComparator(viewerComparator);
+ setLinkingEnabled(true);
+// this.getCommonViewer().addSelectionChangedListener(new ISelectionChangedListener() {
+//
+// @Override
+// public void selectionChanged(SelectionChangedEvent arg0) {
+// IStructuredSelection selection = (IStructuredSelection) getCommonViewer().getSelection();
+//
+// Object firstElement = selection.getFirstElement();
+// //
+// if (!(firstElement instanceof Classification)){
+// //NavigationUtil.selectInNavigator(firstElement, null);
+// NavigationUtil.openEditor(firstElement);
+// }
+//
+// }
+// } );
+
if (CdmStore.isActive()) {
+
// TODO when closing and reopening the taxon navigator
// we do not preserve state. Closing the view, in contrary to
// closing the whole application
if(getConversationHolder() != null){
getConversationHolder().bind();
//FIXME : Need to make sure this is a stable fix (ticket 3822)
- getConversationHolder().commit();
+ if(!getConversationHolder().isCompleted()){
+ getConversationHolder().commit();
+ }
}
getCommonViewer().refresh();
}
path += ((CdmBase) segment).getUuid().toString() + " ";
monitor.worked(1);
} else {
- NavigationUtil.warn(getClass(),
+ MessagingUtils.warn(getClass(),
"Non-taxon tree path segment " + segment);
}
}