]> 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
Update license header
[gpl/argeo-slc.git] / eclipse / plugins / org.argeo.slc.client.ui / src / main / java / org / argeo / slc / client / ui / views / JcrExecutionModulesView.java
index db5490391ad0bfaa3dad504078359286bdb21f0b..5b10af6e042937188771012dc9205b11328547fc 100644 (file)
@@ -25,6 +25,7 @@ import org.argeo.eclipse.ui.jcr.AsyncUiEventListener;
 import org.argeo.eclipse.ui.jcr.DefaultNodeLabelProvider;
 import org.argeo.eclipse.ui.jcr.NodeElementComparer;
 import org.argeo.eclipse.ui.jcr.SimpleNodeContentProvider;
+import org.argeo.eclipse.ui.specific.EclipseUiSpecificUtils;
 import org.argeo.slc.BasicNameVersion;
 import org.argeo.slc.NameVersion;
 import org.argeo.slc.SlcException;
@@ -35,6 +36,10 @@ import org.argeo.slc.execution.ExecutionModulesManager;
 import org.argeo.slc.jcr.SlcJcrConstants;
 import org.argeo.slc.jcr.SlcNames;
 import org.argeo.slc.jcr.SlcTypes;
+import org.eclipse.core.runtime.IProgressMonitor;
+import org.eclipse.core.runtime.IStatus;
+import org.eclipse.core.runtime.Status;
+import org.eclipse.core.runtime.jobs.Job;
 import org.eclipse.jface.viewers.DoubleClickEvent;
 import org.eclipse.jface.viewers.IDoubleClickListener;
 import org.eclipse.jface.viewers.IStructuredSelection;
@@ -69,12 +74,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);
-
-               // FIXME : does not work in RAP, find a way to have it for RCP only
-               // ColumnViewerToolTipSupport.enableFor(viewer);
+               EclipseUiSpecificUtils.enableToolTipSupport(viewer);
 
                ViewContentProvider contentProvider = new ViewContentProvider(session);
-
                viewer.setContentProvider(contentProvider);
                viewer.setComparer(new NodeElementComparer());
                final ViewLabelProvider viewLabelProvider = new ViewLabelProvider();
@@ -247,8 +249,9 @@ public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
 
                                        if (session.itemExists(path)) {
                                                Node parentNode = session.getNode(path);// .getParent();
-                                               if (log.isDebugEnabled())
-                                                       log.debug("Refresh " + parentNode);
+                                               if (log.isTraceEnabled())
+                                                       log.trace("Refresh " + parentNode + " after event "
+                                                                       + event);
                                                viewer.refresh(parentNode);
                                        }
                                } catch (RepositoryException e) {
@@ -273,7 +276,10 @@ public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
 
                @Override
                protected String getText(Node node) throws RepositoryException {
-                       if (node.getName().equals(SLC_EXECUTION_SPECS))
+                       if (node.isNodeType(NodeType.MIX_TITLE)
+                                       && node.hasProperty(Property.JCR_TITLE))
+                               return node.getProperty(Property.JCR_TITLE).getString();
+                       else if (node.getName().equals(SLC_EXECUTION_SPECS))
                                return "Execution Specifications";
                        else if (node.getPath().equals(
                                        SlcJcrConstants.VM_AGENT_FACTORY_PATH))
@@ -336,15 +342,33 @@ public class JcrExecutionModulesView extends ViewPart implements SlcTypes,
                                                String name = node.getProperty(SLC_NAME).getString();
                                                String version = node.getProperty(SLC_VERSION)
                                                                .getString();
-                                               NameVersion nameVersion = new BasicNameVersion(name,
-                                                               version);
+                                               final NameVersion nameVersion = new BasicNameVersion(
+                                                               name, version);
                                                Boolean started = node.getProperty(SLC_STARTED)
                                                                .getBoolean();
+
+                                               Job job;
                                                if (started) {
-                                                       modulesManager.stop(nameVersion);
+                                                       job = new Job("Stop " + nameVersion) {
+                                                               protected IStatus run(IProgressMonitor monitor) {
+                                                                       monitor.beginTask("Stop " + nameVersion, 1);
+                                                                       modulesManager.stop(nameVersion);
+                                                                       monitor.worked(1);
+                                                                       return Status.OK_STATUS;
+                                                               }
+                                                       };
                                                } else {
-                                                       modulesManager.start(nameVersion);
+                                                       job = new Job("Start " + nameVersion) {
+                                                               protected IStatus run(IProgressMonitor monitor) {
+                                                                       monitor.beginTask("Start " + nameVersion, 1);
+                                                                       modulesManager.start(nameVersion);
+                                                                       monitor.worked(1);
+                                                                       return Status.OK_STATUS;
+                                                               }
+                                                       };
                                                }
+                                               job.setUser(true);
+                                               job.schedule();
                                        } else {
                                                String path = node.getPath();
                                                // TODO factorize with editor