]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - eclipse/plugins/org.argeo.slc.client.ui/src/main/java/org/argeo/slc/client/ui/views/JcrExecutionModulesView.java
Working SLC RAP UI
[gpl/argeo-slc.git] / eclipse / plugins / org.argeo.slc.client.ui / src / main / java / org / argeo / slc / client / ui / views / JcrExecutionModulesView.java
index 41e0be09510dd81f3814ead5bdf0d72a75faa5ac..7e97d35e7325a9aac56e32b52827f70fed21a5a0 100644 (file)
@@ -5,14 +5,19 @@ import java.util.Arrays;
 import java.util.Comparator;
 import java.util.Iterator;
 import java.util.List;
+import java.util.SortedSet;
+import java.util.TreeSet;
 
 import javax.jcr.Node;
+import javax.jcr.NodeIterator;
 import javax.jcr.Property;
 import javax.jcr.RepositoryException;
 import javax.jcr.Session;
 import javax.jcr.nodetype.NodeType;
 import javax.jcr.observation.Event;
 import javax.jcr.observation.EventIterator;
+import javax.jcr.query.Query;
+import javax.jcr.query.QueryManager;
 
 import org.argeo.ArgeoException;
 import org.argeo.eclipse.ui.jcr.AsyncUiEventListener;
@@ -34,6 +39,7 @@ import org.eclipse.jface.viewers.IDoubleClickListener;
 import org.eclipse.jface.viewers.IStructuredSelection;
 import org.eclipse.jface.viewers.ITableLabelProvider;
 import org.eclipse.jface.viewers.TreeViewer;
+import org.eclipse.jface.viewers.Viewer;
 import org.eclipse.swt.SWT;
 import org.eclipse.swt.dnd.DND;
 import org.eclipse.swt.dnd.DragSourceAdapter;
@@ -49,8 +55,8 @@ import org.eclipse.ui.part.ViewPart;
 /** JCR based view of the execution modules. */
 public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
                SlcNames {
-//     private final static Log log = LogFactory
-//                     .getLog(JcrExecutionModulesView.class);
+       // private final static Log log = LogFactory
+       // .getLog(JcrExecutionModulesView.class);
 
        public static final String ID = "org.argeo.slc.client.ui.jcrExecutionModulesView";
 
@@ -62,7 +68,9 @@ public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
 
        public void createPartControl(Composite parent) {
                viewer = new TreeViewer(parent, SWT.MULTI | SWT.H_SCROLL | SWT.V_SCROLL);
-               ColumnViewerToolTipSupport.enableFor(viewer);
+               
+               // FIXME : does not work in RAP, find a way to have it for RCP only
+               //ColumnViewerToolTipSupport.enableFor(viewer);
 
                ViewContentProvider contentProvider = new ViewContentProvider(session);
 
@@ -91,7 +99,7 @@ public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
                        throw new SlcException("Cannot add observer", e);
                }
        }
-
+       
        public void setFocus() {
                viewer.getControl().setFocus();
        }
@@ -148,6 +156,20 @@ public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
                        }
                        return super.filterChildren(children);
                }
+
+               @Override
+               public boolean hasChildren(Object element) {
+                       if (element instanceof Node) {
+                               Node node = (Node) element;
+                               try {
+                                       if (node.isNodeType(SlcTypes.SLC_EXECUTION_FLOW))
+                                               return false;
+                               } catch (RepositoryException e) {
+                                       throw new SlcException("Cannot check has children", e);
+                               }
+                       }
+                       return super.hasChildren(element);
+               }
        }
 
        static class ViewComparator implements Comparator<Object> {
@@ -319,14 +341,7 @@ public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
                        try {
                                if (obj instanceof Node) {
                                        Node node = (Node) obj;
-                                       if (node.isNodeType(SLC_EXECUTION_FLOW)) {
-                                               List<String> paths = new ArrayList<String>();
-                                               paths.add(node.getPath());
-                                               IWorkbenchPage activePage = PlatformUI.getWorkbench()
-                                                               .getActiveWorkbenchWindow().getActivePage();
-                                               activePage.openEditor(new ProcessEditorInput(paths,
-                                                               true), ProcessEditor.ID);
-                                       } else if (node.isNodeType(SLC_EXECUTION_MODULE)) {
+                                       if (node.isNodeType(SLC_EXECUTION_MODULE)) {
                                                String name = node.getProperty(SLC_NAME).getString();
                                                String version = node.getProperty(SLC_VERSION)
                                                                .getString();
@@ -339,6 +354,32 @@ public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
                                                } else {
                                                        modulesManager.start(nameVersion);
                                                }
+                                       } else {
+                                               String path = node.getPath();
+                                               // TODO factorize with editor
+                                               QueryManager qm = node.getSession().getWorkspace()
+                                                               .getQueryManager();
+                                               String statement = "SELECT * FROM ["
+                                                               + SlcTypes.SLC_EXECUTION_FLOW
+                                                               + "] WHERE ISDESCENDANTNODE(['" + path
+                                                               + "']) OR ISSAMENODE(['" + path + "'])";
+                                               // log.debug(statement);
+                                               Query query = qm.createQuery(statement, Query.JCR_SQL2);
+
+                                               // order paths
+                                               SortedSet<String> paths = new TreeSet<String>();
+                                               for (NodeIterator nit = query.execute().getNodes(); nit
+                                                               .hasNext();) {
+                                                       paths.add(nit.nextNode().getPath());
+                                               }
+
+                                               // List<String> paths = new ArrayList<String>();
+                                               // paths.add(node.getPath());
+                                               IWorkbenchPage activePage = PlatformUI.getWorkbench()
+                                                               .getActiveWorkbenchWindow().getActivePage();
+                                               activePage.openEditor(new ProcessEditorInput(
+                                                               new ArrayList<String>(paths), true),
+                                                               ProcessEditor.ID);
                                        }
                                }
                        } catch (Exception e) {