From 4be52863f9ec6bfbfec12fdc1aa3cefa867a1945 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Wed, 21 Mar 2012 22:39:30 -0400 Subject: [PATCH] Adjusted spacing on activity page --- src/com/gitblit/wicket/pages/EditTeamPage.java | 80 ++++++++++++++++++++++++++++++++++------ 1 files changed, 68 insertions(+), 12 deletions(-) diff --git a/src/com/gitblit/wicket/pages/EditTeamPage.java b/src/com/gitblit/wicket/pages/EditTeamPage.java index c5c240f..2ed5fba 100644 --- a/src/com/gitblit/wicket/pages/EditTeamPage.java +++ b/src/com/gitblit/wicket/pages/EditTeamPage.java @@ -24,9 +24,9 @@ import java.util.Set; import org.apache.wicket.PageParameters; +import org.apache.wicket.behavior.SimpleAttributeModifier; import org.apache.wicket.extensions.markup.html.form.palette.Palette; import org.apache.wicket.markup.html.form.Button; -import org.apache.wicket.markup.html.form.ChoiceRenderer; import org.apache.wicket.markup.html.form.Form; import org.apache.wicket.markup.html.form.TextField; import org.apache.wicket.model.CompoundPropertyModel; @@ -42,7 +42,9 @@ 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; @RequiresAdminRole public class EditTeamPage extends RootSubPage { @@ -73,7 +75,7 @@ } else { super.setupPage(getString("gb.edit"), teamModel.name); } - + CompoundPropertyModel<TeamModel> model = new CompoundPropertyModel<TeamModel>(teamModel); List<String> repos = new ArrayList<String>(); @@ -84,17 +86,42 @@ } } StringUtils.sortRepositorynames(repos); - + List<String> teamUsers = new ArrayList<String>(teamModel.users); Collections.sort(teamUsers); - + List<String> preReceiveScripts = new ArrayList<String>(); + 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 ChoiceRenderer<String>("", ""), 10, false); + new CollectionModel<String>(repos), new StringChoiceRenderer(), 10, false); + + // users palette final Palette<String> users = new Palette<String>("users", new ListModel<String>( new ArrayList<String>(teamUsers)), new CollectionModel<String>(GitBlit.self() - .getAllUsernames()), new ChoiceRenderer<String>("", ""), 10, false); + .getAllUsernames()), new StringChoiceRenderer(), 10, false); + + // pre-receive palette + if (teamModel.preReceiveScripts != null) { + preReceiveScripts.addAll(teamModel.preReceiveScripts); + } + final Palette<String> preReceivePalette = new Palette<String>("preReceiveScripts", + new ListModel<String>(preReceiveScripts), new CollectionModel<String>(GitBlit + .self().getPreReceiveScriptsUnused(null)), new StringChoiceRenderer(), + 12, true); + + // post-receive palette + if (teamModel.postReceiveScripts != null) { + postReceiveScripts.addAll(teamModel.postReceiveScripts); + } + final Palette<String> postReceivePalette = new Palette<String>("postReceiveScripts", + new ListModel<String>(postReceiveScripts), new CollectionModel<String>(GitBlit + .self().getPostReceiveScriptsUnused(null)), new StringChoiceRenderer(), + 12, true); + Form<TeamModel> form = new Form<TeamModel>("editForm", model) { private static final long serialVersionUID = 1L; @@ -123,6 +150,10 @@ while (selectedRepositories.hasNext()) { repos.add(selectedRepositories.next().toLowerCase()); } + if (repos.size() == 0) { + error("A team must specify at least one repository."); + return; + } teamModel.repositories.clear(); teamModel.repositories.addAll(repos); @@ -147,7 +178,25 @@ teamModel.mailingLists.clear(); teamModel.mailingLists.addAll(list); } - + + // pre-receive scripts + List<String> preReceiveScripts = new ArrayList<String>(); + Iterator<String> pres = preReceivePalette.getSelectedChoices(); + while (pres.hasNext()) { + preReceiveScripts.add(pres.next()); + } + teamModel.preReceiveScripts.clear(); + teamModel.preReceiveScripts.addAll(preReceiveScripts); + + // post-receive scripts + List<String> postReceiveScripts = new ArrayList<String>(); + Iterator<String> post = postReceivePalette.getSelectedChoices(); + while (post.hasNext()) { + postReceiveScripts.add(post.next()); + } + teamModel.postReceiveScripts.clear(); + teamModel.postReceiveScripts.addAll(postReceiveScripts); + try { GitBlit.self().updateTeamModel(oldName, teamModel, isCreate); } catch (GitBlitException e) { @@ -159,13 +208,14 @@ // create another team info(MessageFormat.format("New team ''{0}'' successfully created.", teamModel.name)); - setResponsePage(EditTeamPage.class); - } else { - // back to users page - setResponsePage(UsersPage.class); } + // back to users page + setResponsePage(UsersPage.class); } }; + + // do not let the browser pre-populate these fields + form.add(new SimpleAttributeModifier("autocomplete", "off")); // field names reflective match TeamModel fields form.add(new TextField<String>("name")); @@ -173,8 +223,14 @@ mailingLists = new Model<String>(teamModel.mailingLists == null ? "" : StringUtils.flattenStrings(teamModel.mailingLists, " ")); form.add(new TextField<String>("mailingLists", mailingLists)); - + form.add(repositories); + form.add(preReceivePalette); + form.add(new BulletListPanel("inheritedPreReceive", "inherited", GitBlit.self() + .getPreReceiveScriptsInherited(null))); + form.add(postReceivePalette); + form.add(new BulletListPanel("inheritedPostReceive", "inherited", GitBlit.self() + .getPostReceiveScriptsInherited(null))); form.add(new Button("save")); Button cancel = new Button("cancel") { -- Gitblit v1.9.1