import javax.jcr.RepositoryException;
import javax.jcr.nodetype.NodeType;
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
import org.argeo.ArgeoException;
+import org.argeo.eclipse.ui.jcr.utils.JcrFileProvider;
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;
-import org.eclipse.jface.viewers.ITreeContentProvider;
import org.eclipse.jface.viewers.TreeViewer;
import org.eclipse.ui.PartInitException;
/**
- *
* Centralizes the management of double click on a NodeTreeViewer
- *
*/
public class GenericNodeDoubleClickListener implements IDoubleClickListener {
- private final static Log log = LogFactory
- .getLog(GenericNodeDoubleClickListener.class);
+ // private final static Log log = LogFactory
+ // .getLog(GenericNodeDoubleClickListener.class);
private TreeViewer nodeViewer;
private JcrFileProvider jfp;
.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
// various
// repository.
// TODO : enhanced that.
- ITreeContentProvider itcp = (ITreeContentProvider) nodeViewer
- .getContentProvider();
- jfp.setRootNodes((Object[]) itcp.getElements(null));
+ // ITreeContentProvider itcp = (ITreeContentProvider)
+ // nodeViewer
+ // .getContentProvider();
+ jfp.setReferenceNode(node);
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();
- }
}