+/*
+ * Copyright (C) 2007-2012 Mathieu Baudier
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
package org.argeo.jcr.ui.explorer.utils;
import javax.jcr.Node;
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);
}
- // File or not, we always open the corresponding node Editor.
- String repositoryAlias = getRepositoryAlias(obj);
- String workspaceName = node.getSession().getWorkspace()
- .getName();
- String path = node.getPath();
-
- if (log.isDebugEnabled()) {
- log.debug("RepoAlias: " + repositoryAlias + " - WS Name: "
- + workspaceName + " - path:" + path);
- }
- GenericNodeEditorInput gnei = new GenericNodeEditorInput(
- repositoryAlias, workspaceName, path);
-
- GenericNodeEditor gne = (GenericNodeEditor) JcrExplorerPlugin
- .getDefault().getWorkbench().getActiveWorkbenchWindow()
- .getActivePage().openEditor(gnei, GenericNodeEditor.ID);
- gne.setCurrentNode(node);
-
+ GenericNodeEditorInput gnei = new GenericNodeEditorInput(node);
+ JcrExplorerPlugin.getDefault().getWorkbench()
+ .getActiveWorkbenchWindow().getActivePage()
+ .openEditor(gnei, GenericNodeEditor.ID);
} catch (RepositoryException re) {
throw new ArgeoException(
"Repository error while getting node info", re);
}
}
}
-
- // 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();
- }
}