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=89de0eb593b1df8b081d802a57248c2066617b06;hb=5fd44a69159a8f9269494677e2b08d101cff80fc;hpb=992786cb0367dd6ca79522f4eb7d1f29fe2748cc 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 89de0eb..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; @@ -46,6 +49,8 @@ import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Table; import org.eclipse.swt.widgets.TableColumn; import org.eclipse.swt.widgets.Text; +import org.eclipse.ui.IViewSite; +import org.eclipse.ui.PartInitException; import org.eclipse.ui.part.ViewPart; /** A table with a quick search field. */ @@ -65,6 +70,11 @@ public class QuickSearchView extends ViewPart implements Refreshable { private TableViewer entityViewer; private Text filterTxt; + @Override + public void init(IViewSite site) throws PartInitException { + super.init(site); + } + @Override public void createPartControl(Composite parent) { session = ConnectJcrUtils.login(repository); @@ -74,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) { @@ -216,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; }