X-Git-Url: https://git.argeo.org/?p=gpl%2Fargeo-suite.git;a=blobdiff_plain;f=org.argeo.suite.workbench.rap%2Fsrc%2Forg%2Fargeo%2Fsuite%2Fworkbench%2Fparts%2FQuickSearchView.java;h=c8ebdb2ea693059fd719388f7a85250aca08494f;hp=50340be5afd7f50d679bbbb71754a57642365ba0;hb=a4592339d582315077ae7bb87043a6ec7a8bd4a2;hpb=7f5c5f481fc1d86e289c89c1692d7d9c24ab9de6 diff --git a/org.argeo.suite.workbench.rap/src/org/argeo/suite/workbench/parts/QuickSearchView.java b/org.argeo.suite.workbench.rap/src/org/argeo/suite/workbench/parts/QuickSearchView.java index 50340be..c8ebdb2 100644 --- a/org.argeo.suite.workbench.rap/src/org/argeo/suite/workbench/parts/QuickSearchView.java +++ b/org.argeo.suite.workbench.rap/src/org/argeo/suite/workbench/parts/QuickSearchView.java @@ -6,6 +6,9 @@ import javax.jcr.NodeIterator; import javax.jcr.Repository; import javax.jcr.RepositoryException; import javax.jcr.Session; +import javax.jcr.observation.Event; +import javax.jcr.observation.EventIterator; +import javax.jcr.observation.EventListener; import javax.jcr.query.Query; import javax.jcr.query.QueryResult; @@ -16,13 +19,13 @@ import org.argeo.cms.util.CmsUtils; import org.argeo.connect.ConnectTypes; import org.argeo.connect.resources.ResourcesService; import org.argeo.connect.ui.ConnectUiConstants; +import org.argeo.connect.ui.Refreshable; +import org.argeo.connect.ui.SystemWorkbenchService; import org.argeo.connect.ui.util.BasicNodeListContentProvider; +import org.argeo.connect.ui.util.JcrViewerDClickListener; import org.argeo.connect.ui.widgets.DelayedText; import org.argeo.connect.util.ConnectJcrUtils; import org.argeo.connect.util.XPathUtils; -import org.argeo.connect.workbench.Refreshable; -import org.argeo.connect.workbench.SystemWorkbenchService; -import org.argeo.connect.workbench.util.JcrViewerDClickListener; import org.argeo.eclipse.ui.EclipseUiUtils; import org.argeo.jcr.JcrUtils; import org.argeo.people.PeopleService; @@ -81,6 +84,20 @@ public class QuickSearchView extends ViewPart implements Refreshable { entityViewer = createListPart(parent, new EntitySingleColumnLabelProvider(resourcesService, activitiesService, peopleService, systemWorkbenchService)); refreshFilteredList(); + + try { + session.getWorkspace().getObservationManager().addEventListener(new EventListener() { + + @Override + public void onEvent(EventIterator events) { + parent.getDisplay().asyncExec(() -> refreshFilteredList()); + } + }, Event.PROPERTY_CHANGED | Event.NODE_ADDED | Event.NODE_REMOVED | Event.PROPERTY_ADDED, "/", true, null, + new String[] { ConnectTypes.CONNECT_ENTITY }, true); + } catch (RepositoryException e) { + throw new SuiteWorkbenchException("Cannot add JCR observer", e); + } + } public void addFilterPanel(Composite parent) { @@ -154,7 +171,7 @@ public class QuickSearchView extends ViewPart implements Refreshable { CmsUtils.setItemHeight(table, 26); v.setContentProvider(new BasicNodeListContentProvider()); - v.addDoubleClickListener(new JcrViewerDClickListener()); + v.addDoubleClickListener(new JcrViewerDClickListener(systemWorkbenchService)); return v; } @@ -223,11 +240,11 @@ public class QuickSearchView extends ViewPart implements Refreshable { public void setResourcesService(ResourcesService resourcesService) { this.resourcesService = resourcesService; } - + public void setActivitiesService(ActivitiesService activitiesService) { this.activitiesService = activitiesService; } - + public void setPeopleService(PeopleService peopleService) { this.peopleService = peopleService; }