From b0e164283fee6f993589cce849ba1fc7d294e89d Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Fri, 19 Oct 2012 22:47:33 -0400 Subject: [PATCH] New permissions UI for EditUser and EditTeam (issue 36) --- src/com/gitblit/wicket/pages/EditTeamPage.java | 25 +++++++++---------------- 1 files changed, 9 insertions(+), 16 deletions(-) diff --git a/src/com/gitblit/wicket/pages/EditTeamPage.java b/src/com/gitblit/wicket/pages/EditTeamPage.java index 9cbccb5..05c9121 100644 --- a/src/com/gitblit/wicket/pages/EditTeamPage.java +++ b/src/com/gitblit/wicket/pages/EditTeamPage.java @@ -40,12 +40,14 @@ import com.gitblit.GitBlit; import com.gitblit.GitBlitException; import com.gitblit.models.RepositoryModel; +import com.gitblit.models.RepositoryAccessPermission; import com.gitblit.models.TeamModel; import com.gitblit.utils.StringUtils; import com.gitblit.wicket.RequiresAdminRole; import com.gitblit.wicket.StringChoiceRenderer; import com.gitblit.wicket.WicketUtils; import com.gitblit.wicket.panels.BulletListPanel; +import com.gitblit.wicket.panels.RepositoryPermissionsPanel; @RequiresAdminRole public class EditTeamPage extends RootSubPage { @@ -59,6 +61,7 @@ super(); isCreate = true; setupPage(new TeamModel("")); + setStatelessHint(false); } public EditTeamPage(PageParameters params) { @@ -68,6 +71,7 @@ String name = WicketUtils.getTeamname(params); TeamModel model = GitBlit.self().getTeamModel(name); setupPage(model); + setStatelessHint(false); } protected void setupPage(final TeamModel teamModel) { @@ -94,11 +98,7 @@ List<String> postReceiveScripts = new ArrayList<String>(); final String oldName = teamModel.name; - - // repositories palette - final Palette<String> repositories = new Palette<String>("repositories", - new ListModel<String>(new ArrayList<String>(teamModel.repositories)), - new CollectionModel<String>(repos), new StringChoiceRenderer(), 10, false); + final List<RepositoryAccessPermission> permissions = teamModel.getRepositoryPermissions(); // users palette final Palette<String> users = new Palette<String>("users", new ListModel<String>( @@ -146,17 +146,10 @@ return; } } - Iterator<String> selectedRepositories = repositories.getSelectedChoices(); - List<String> repos = new ArrayList<String>(); - while (selectedRepositories.hasNext()) { - repos.add(selectedRepositories.next().toLowerCase()); + // update team permissions + for (RepositoryAccessPermission repositoryPermission : permissions) { + teamModel.setRepositoryPermission(repositoryPermission.repository, repositoryPermission.permission); } - if (repos.size() == 0) { - error(getString("gb.teamMustSpecifyRepository")); - return; - } - teamModel.repositories.clear(); - teamModel.repositories.addAll(repos); Iterator<String> selectedUsers = users.getSelectedChoices(); List<String> members = new ArrayList<String>(); @@ -231,7 +224,7 @@ : StringUtils.flattenStrings(teamModel.mailingLists, " ")); form.add(new TextField<String>("mailingLists", mailingLists)); - form.add(repositories); + form.add(new RepositoryPermissionsPanel("repositories", permissions, getAccessPermissions())); form.add(preReceivePalette); form.add(new BulletListPanel("inheritedPreReceive", "inherited", GitBlit.self() .getPreReceiveScriptsInherited(null))); -- Gitblit v1.9.1