X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.app.ui%2Fsrc%2Forg%2Fargeo%2Fapp%2Fui%2Fpeople%2FUsersEntryArea.java;h=04cccf7b89f64dff6b43811bf248e643af155b74;hb=99a029d144e7aab7f8b5a9ac3a2c4383cae4a6f5;hp=14e4b26cc14c738209f60bf479443a2593b267b1;hpb=c68ffb7eadc935addc52bec34ffcbb20b6425b56;p=gpl%2Fargeo-suite.git diff --git a/org.argeo.app.ui/src/org/argeo/app/ui/people/UsersEntryArea.java b/org.argeo.app.ui/src/org/argeo/app/ui/people/UsersEntryArea.java index 14e4b26..04cccf7 100644 --- a/org.argeo.app.ui/src/org/argeo/app/ui/people/UsersEntryArea.java +++ b/org.argeo.app.ui/src/org/argeo/app/ui/people/UsersEntryArea.java @@ -7,6 +7,8 @@ import javax.jcr.Node; import javax.jcr.RepositoryException; import org.argeo.api.acr.Content; +import org.argeo.api.acr.ContentRepository; +import org.argeo.api.acr.ContentSession; import org.argeo.api.cms.CmsTheme; import org.argeo.api.cms.CmsView; import org.argeo.app.ui.SuiteEvent; @@ -23,12 +25,19 @@ import org.argeo.cms.swt.widgets.SwtTabularPart; import org.argeo.cms.ui.CmsUiProvider; import org.argeo.cms.ux.widgets.HierarchicalPart; import org.argeo.cms.ux.widgets.TabularPart; +import org.argeo.osgi.useradmin.FunctionalGroup; import org.argeo.osgi.useradmin.HierarchyUnit; +import org.argeo.osgi.useradmin.Organization; +import org.argeo.osgi.useradmin.Person; import org.argeo.osgi.useradmin.UserDirectory; +import org.argeo.util.LangUtils; +import org.argeo.util.naming.LdapAttrs; +import org.argeo.util.naming.LdapObjs; import org.eclipse.jface.window.Window; import org.eclipse.jface.wizard.Wizard; import org.eclipse.swt.SWT; import org.eclipse.swt.custom.SashForm; +import org.eclipse.swt.graphics.Image; import org.eclipse.swt.layout.GridData; import org.eclipse.swt.layout.GridLayout; import org.eclipse.swt.widgets.Composite; @@ -37,6 +46,7 @@ import org.eclipse.swt.widgets.TableItem; import org.eclipse.swt.widgets.ToolBar; import org.eclipse.swt.widgets.ToolItem; import org.eclipse.swt.widgets.TreeItem; +import org.osgi.service.useradmin.Group; import org.osgi.service.useradmin.Role; import org.osgi.service.useradmin.User; @@ -45,12 +55,16 @@ 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); CmsView cmsView = CmsSwtUtils.getCmsView(parent); parent.setLayout(new GridLayout()); + ContentSession contentSession = contentRepository.get(); + SashForm sashForm = new SashForm(parent, SWT.VERTICAL); CmsSwtUtils.fill(sashForm); @@ -66,19 +80,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(true))); } @Override protected void refreshItem(TreeItem parentItem, TreeItem item) { int index = getTree().indexOf(item); - HierarchyUnit parent = (HierarchyUnit) parentItem.getData(); - HierarchyUnit child = parent.getHierarchyChild(index); + Iterable children; + if (parentItem.getData() instanceof UserDirectory) + children = ((UserDirectory) parentItem.getData()).getRootHierarchyUnits(true); + else + children = ((HierarchyUnit) parentItem.getData()).getFunctionalHierachyUnits(); + HierarchyUnit child = LangUtils.getAt(children, index); item.setData(child); item.setText(child.getHierarchyUnitName()); - item.setItemCount(child.getHierarchyChildCount()); + item.setItemCount(LangUtils.size(child.getFunctionalHierachyUnits())); } @Override @@ -89,7 +107,7 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider { }; TabularPart usersView = new SwtTabularPart(sashForm, SWT.NONE) { - List roles; + List roles = new ArrayList<>(); @Override protected void refreshItem(TableItem item) { @@ -97,14 +115,31 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider { User role = (User) roles.get(index); item.setData(role); item.setText(role.getName()); + Image icon; + if (role instanceof Organization) { + icon = SuiteIcon.organisation.getSmallIcon(theme); + } else if (role instanceof FunctionalGroup) { + icon = SuiteIcon.group.getSmallIcon(theme); + } else if (role instanceof Person) { + icon = SuiteIcon.person.getSmallIcon(theme); + } else { + icon = null; + } + item.setImage(icon); } @Override protected int getItemCount() { + roles.clear(); HierarchyUnit hu = (HierarchyUnit) getInput(); if (hu == null) return 0; - roles = hu.getRoles(null, false); + for (HierarchyUnit directChild : hu.getDirectHierachyUnits()) { + if (!directChild.isFunctional()) { + roles.addAll(directChild.getHierarchyUnitRoles(null, false)); + } + } + // roles = hu.getHierarchyUnitRoles(null, false); return roles.size(); } @@ -124,8 +159,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) -> { @@ -164,6 +200,15 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider { // private String getUserProperty(Object element, String key) { // Object value = ((User) element).getProperties().get(key); // return value != null ? value.toString() : null; +// } + +// private boolean isOrganisation(Role role) { +// String[] objectClasses = role.getProperties().get(LdapAttrs.objectClasses.name()).toString().split("\\n"); +// for (String objectClass : objectClasses) { +// if (LdapObjs.organization.name().equalsIgnoreCase(objectClass)) +// return true; +// } +// return false; // } public void setCmsUserManager(CmsUserManager cmsUserManager) { @@ -175,4 +220,8 @@ public class UsersEntryArea implements SwtUiProvider, CmsUiProvider { return createUiPart(parent, JcrContent.nodeToContent(context)); } + public void setContentRepository(ContentRepository contentRepository) { + this.contentRepository = contentRepository; + } + }