import org.argeo.ArgeoException;
import org.argeo.eclipse.ui.specific.FileHandler;
import org.argeo.jcr.ui.explorer.JcrExplorerPlugin;
-import org.argeo.jcr.ui.explorer.browser.NodeContentProvider;
-import org.argeo.jcr.ui.explorer.browser.RepositoryNode;
-import org.argeo.jcr.ui.explorer.browser.WorkspaceNode;
import org.argeo.jcr.ui.explorer.editors.GenericNodeEditor;
import org.argeo.jcr.ui.explorer.editors.GenericNodeEditorInput;
+import org.argeo.jcr.ui.explorer.model.RepositoryNode;
+import org.argeo.jcr.ui.explorer.model.SingleJcrNode;
+import org.argeo.jcr.ui.explorer.model.WorkspaceNode;
import org.eclipse.jface.viewers.DoubleClickEvent;
import org.eclipse.jface.viewers.IDoubleClickListener;
import org.eclipse.jface.viewers.IStructuredSelection;
.getFirstElement();
if (obj instanceof RepositoryNode) {
RepositoryNode rpNode = (RepositoryNode) obj;
- rpNode.login();
- nodeViewer.refresh(obj);
+ if (rpNode.getChildren().length == 0) {
+ rpNode.login();
+ nodeViewer.refresh(obj);
+ }
+ // else do nothing
} else if (obj instanceof WorkspaceNode) {
((WorkspaceNode) obj).login();
nodeViewer.refresh(obj);
- } else if (obj instanceof Node) {
- Node node = (Node) obj;
+ } else if (obj instanceof SingleJcrNode) {
+ SingleJcrNode sjn = (SingleJcrNode) obj;
+ Node node = sjn.getNode();
try {
if (node.isNodeType(NodeType.NT_FILE)) {
// double click on a file node triggers its opening
// TODO : enhanced that.
ITreeContentProvider itcp = (ITreeContentProvider) nodeViewer
.getContentProvider();
- jfp.setRootNodes((Object[]) itcp.getElements(null));
+ // jfp.setRootNodes((Object[]) itcp.getElements(null));
fileHandler.openFile(name, id);
}
GenericNodeEditorInput gnei = new GenericNodeEditorInput(node);
}
}
}
-
- // Enhance this method
- private String getRepositoryAlias(Object element) {
- NodeContentProvider ncp = (NodeContentProvider) nodeViewer
- .getContentProvider();
- Object parent = element;
- while (!(ncp.getParent(parent) instanceof RepositoryNode)
- && parent != null)
- parent = ncp.getParent(parent);
- return parent == null ? null : ((RepositoryNode) parent).getName();
- }
}