First part of the refactoring: clean backends.
[gpl/argeo-suite.git] / org.argeo.suite.workbench.rap / src / org / argeo / suite / workbench / parts / AbstractSuiteDashboard.java
index 1b0b9500eabc71c4f587dc8c7219530429f9529c..e18d202e035e6aea4b16c493fd83550c5267bb48 100644 (file)
@@ -1,9 +1,18 @@
 package org.argeo.suite.workbench.parts;
 
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.jcr.Node;
 import javax.jcr.Repository;
 import javax.jcr.Session;
 
+import org.argeo.cms.ui.workbench.util.CommandUtils;
 import org.argeo.cms.util.CmsUtils;
+import org.argeo.connect.documents.DocumentsService;
+import org.argeo.connect.resources.ResourceService;
+import org.argeo.connect.activities.ActivityService;
+import org.argeo.connect.activities.ActivitiesTypes;
 import org.argeo.connect.people.PeopleService;
 import org.argeo.connect.people.workbench.rap.PeopleStyles;
 import org.argeo.connect.people.workbench.rap.editors.util.EntityEditorInput;
@@ -13,11 +22,14 @@ import org.argeo.eclipse.ui.EclipseUiUtils;
 import org.argeo.jcr.JcrUtils;
 import org.eclipse.core.runtime.IProgressMonitor;
 import org.eclipse.swt.SWT;
+import org.eclipse.swt.events.SelectionAdapter;
+import org.eclipse.swt.events.SelectionEvent;
 import org.eclipse.swt.graphics.Image;
 import org.eclipse.swt.layout.GridData;
 import org.eclipse.swt.layout.GridLayout;
 import org.eclipse.swt.widgets.Composite;
 import org.eclipse.swt.widgets.Label;
+import org.eclipse.swt.widgets.Link;
 import org.eclipse.ui.IEditorInput;
 import org.eclipse.ui.IEditorSite;
 import org.eclipse.ui.PartInitException;
@@ -29,7 +41,10 @@ public abstract class AbstractSuiteDashboard extends EditorPart {
 
        // DEPENDENCY INJECTION
        private Repository repository;
+       private ResourceService resourceService;
+       private ActivityService activityService;
        private PeopleService peopleService;
+       private DocumentsService documentsService;
        private AppWorkbenchService appWorkbenchService;
 
        private Session session;
@@ -116,6 +131,25 @@ public abstract class AbstractSuiteDashboard extends EditorPart {
                return bodyCmp;
        }
 
+       protected Link createOpenEntityEditorLink(final AppWorkbenchService peopleUiService, Composite parent,
+                       final String label, final Node entity) {
+               Link link = new Link(parent, SWT.NONE);
+               link.setText("<a>" + label + "</a>");
+               link.setLayoutData(EclipseUiUtils.fillWidth());
+               link.addSelectionListener(new SelectionAdapter() {
+                       private static final long serialVersionUID = 1L;
+
+                       @Override
+                       public void widgetSelected(final SelectionEvent event) {
+                               Map<String, String> params = new HashMap<String, String>();
+                               // FIXME
+                               params.put("param.jcrId", ConnectJcrUtils.getIdentifier(entity));
+                               CommandUtils.callCommand(peopleUiService.getOpenEntityEditorCmdId(), params);
+                       }
+               });
+               return link;
+       }
+
        // LIFE CYCLE
        @Override
        public void dispose() {
@@ -149,16 +183,29 @@ public abstract class AbstractSuiteDashboard extends EditorPart {
        }
 
        // Expose to implementing classes
+       protected Session getSession() {
+               return session;
+       }
+
+       public ResourceService getResourceService() {
+               return resourceService;
+       }
+       
+       protected ActivityService getActivityService() {
+               return activityService;
+       }
+
        protected PeopleService getPeopleService() {
                return peopleService;
        }
 
-       protected AppWorkbenchService getAppWorkbenchService() {
-               return appWorkbenchService;
+       protected DocumentsService getDocumentsService() {
+               return documentsService;
        }
 
-       protected Session getSession() {
-               return session;
+
+       protected AppWorkbenchService getAppWorkbenchService() {
+               return appWorkbenchService;
        }
 
        protected Image getLogoImg() {
@@ -174,11 +221,25 @@ public abstract class AbstractSuiteDashboard extends EditorPart {
                this.repository = repository;
        }
 
-       public void setAppWorkbenchService(AppWorkbenchService appWorkbenchService) {
-               this.appWorkbenchService = appWorkbenchService;
+       public void setResourceService(ResourceService resourceService) {
+               this.resourceService = resourceService;
+       }
+       
+       public void setActivityService(ActivityService activityService) {
+               this.activityService = activityService;
+       }
+
+       public void setDocumentsService(DocumentsService documentsService) {
+               this.documentsService = documentsService;
        }
 
        public void setPeopleService(PeopleService peopleService) {
                this.peopleService = peopleService;
        }
+
+
+       public void setAppWorkbenchService(AppWorkbenchService appWorkbenchService) {
+               this.appWorkbenchService = appWorkbenchService;
+       }
+
 }