]> git.argeo.org Git - lgpl/argeo-commons.git/blobdiff - security/plugins/org.argeo.security.ui.admin/src/main/java/org/argeo/security/ui/admin/commands/AddRole.java
Remove old interfaces
[lgpl/argeo-commons.git] / security / plugins / org.argeo.security.ui.admin / src / main / java / org / argeo / security / ui / admin / commands / AddRole.java
index 047c167e07f34590e8f67c499de989276e712eea..d550484fcf0c0d5cdd578faebdebd2f894b5735f 100644 (file)
@@ -2,10 +2,13 @@ package org.argeo.security.ui.admin.commands;
 
 import org.argeo.ArgeoException;
 import org.argeo.security.UserAdminService;
+import org.argeo.security.ui.admin.editors.ArgeoUserEditor;
 import org.argeo.security.ui.admin.views.RolesView;
 import org.eclipse.core.commands.AbstractHandler;
 import org.eclipse.core.commands.ExecutionEvent;
 import org.eclipse.core.commands.ExecutionException;
+import org.eclipse.ui.IEditorReference;
+import org.eclipse.ui.IWorkbenchPage;
 import org.eclipse.ui.handlers.HandlerUtil;
 
 /** Add a new role. */
@@ -30,6 +33,17 @@ public class AddRole extends AbstractHandler {
                        throw new ArgeoException("Role " + role + " already exists");
                userAdminService.newRole(role);
                rolesView.refresh();
+
+               // refresh editors
+               IEditorReference[] refs = HandlerUtil.getActiveWorkbenchWindow(event)
+                               .getActivePage()
+                               .findEditors(null, ArgeoUserEditor.ID, IWorkbenchPage.MATCH_ID);
+               for (IEditorReference ref : refs) {
+                       ArgeoUserEditor userEditor = (ArgeoUserEditor) ref.getEditor(false);
+                       if (userEditor != null) {
+                               userEditor.refresh();
+                       }
+               }
                return null;
        }