Change directory display name.
[gpl/argeo-suite.git] / org.argeo.app.ui / src / org / argeo / app / ui / people / UsersEntryArea.java
index 14e4b26cc14c738209f60bf479443a2593b267b1..d0e24d5bb5a4129e6022cfbea49fcc499460d4d2 100644 (file)
@@ -7,6 +7,7 @@ import javax.jcr.Node;
 import javax.jcr.RepositoryException;
 
 import org.argeo.api.acr.Content;
+import org.argeo.api.acr.ContentRepository;
 import org.argeo.api.cms.CmsTheme;
 import org.argeo.api.cms.CmsView;
 import org.argeo.app.ui.SuiteEvent;
@@ -25,6 +26,7 @@ import org.argeo.cms.ux.widgets.HierarchicalPart;
 import org.argeo.cms.ux.widgets.TabularPart;
 import org.argeo.osgi.useradmin.HierarchyUnit;
 import org.argeo.osgi.useradmin.UserDirectory;
+import org.argeo.util.LangUtils;
 import org.eclipse.jface.window.Window;
 import org.eclipse.jface.wizard.Wizard;
 import org.eclipse.swt.SWT;
@@ -45,6 +47,8 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider {
 
        private CmsUserManager cmsUserManager;
 
+       private ContentRepository contentRepository;
+
        @Override
        public Control createUiPart(Composite parent, Content context) {
                CmsTheme theme = CmsSwtUtils.getCmsTheme(parent);
@@ -66,19 +70,23 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider {
                                int index = getTree().indexOf(item);
                                UserDirectory directory = (UserDirectory) directories.get(index);
                                item.setData(directory);
-                               item.setText(directory.getBasePath());
+                               item.setText(directory.getName());
 
-                               item.setItemCount(directory.getHierarchyChildCount());
+                               item.setItemCount(LangUtils.size(directory.getRootHierarchyUnits()));
                        }
 
                        @Override
                        protected void refreshItem(TreeItem parentItem, TreeItem item) {
                                int index = getTree().indexOf(item);
-                               HierarchyUnit parent = (HierarchyUnit) parentItem.getData();
-                               HierarchyUnit child = parent.getHierarchyChild(index);
+                               Iterable<HierarchyUnit> children;
+                               if (parentItem.getData() instanceof UserDirectory)
+                                       children = ((UserDirectory) parentItem.getData()).getRootHierarchyUnits();
+                               else
+                                       children = ((HierarchyUnit) parentItem.getData()).getDirectHierachyUnits();
+                               HierarchyUnit child = LangUtils.getAt(children, index);
                                item.setData(child);
                                item.setText(child.getHierarchyUnitName());
-                               item.setItemCount(child.getHierarchyChildCount());
+                               item.setItemCount(LangUtils.size(child.getDirectHierachyUnits()));
                        }
 
                        @Override
@@ -104,7 +112,7 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider {
                                HierarchyUnit hu = (HierarchyUnit) getInput();
                                if (hu == null)
                                        return 0;
-                               roles = hu.getRoles(null, false);
+                               roles = hu.getHierarchyUnitRoles(null, false);
                                return roles.size();
                        }
 
@@ -124,8 +132,9 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider {
 
                // CONTROLLER
                directoriesView.onSelected((o) -> {
-                       HierarchyUnit hu = (HierarchyUnit) o;
-                       usersView.setInput(hu);
+                       if (o instanceof HierarchyUnit) {
+                               usersView.setInput((HierarchyUnit) o);
+                       }
                });
 
                usersView.onSelected((o) -> {
@@ -175,4 +184,8 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider {
                return createUiPart(parent, JcrContent.nodeToContent(context));
        }
 
+       public void setContentRepository(ContentRepository contentRepository) {
+               this.contentRepository = contentRepository;
+       }
+
 }