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=3064e272d1735cc59eb1c096dca0bd0dbb8bb8ae;hb=5fd44a69159a8f9269494677e2b08d101cff80fc;hpb=f2d15e2ae5dd03cb5b77939349bc6a3a97869746 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 3064e27..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; @@ -75,7 +77,6 @@ public class QuickSearchView extends ViewPart implements Refreshable { @Override public void createPartControl(Composite parent) { - setTitleImage(ConnectImages.SEARCH); session = ConnectJcrUtils.login(repository); // MainLayout parent.setLayout(new GridLayout()); @@ -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; }