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=e0afd192921a5d29a353f214e76c86a8894da059;hp=7ec41886643693fe5387a7cb3031e462e7923598;hb=5fd44a69159a8f9269494677e2b08d101cff80fc;hpb=aa6195b8e01aa1f82b6a5d0ec562a0aeaf9aeef2 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 7ec4188..e0afd19 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; @@ -15,7 +18,6 @@ import org.argeo.activities.ActivitiesService; import org.argeo.cms.util.CmsUtils; import org.argeo.connect.ConnectTypes; import org.argeo.connect.resources.ResourcesService; -import org.argeo.connect.ui.ConnectImages; import org.argeo.connect.ui.ConnectUiConstants; import org.argeo.connect.ui.util.BasicNodeListContentProvider; import org.argeo.connect.ui.widgets.DelayedText; @@ -71,7 +73,6 @@ public class QuickSearchView extends ViewPart implements Refreshable { @Override public void init(IViewSite site) throws PartInitException { super.init(site); - setTitleImage(ConnectImages.SEARCH); } @Override @@ -83,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) { @@ -225,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; }