From 5316d20e861640867d10405b25cfe75aeca0a34c Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Fri, 11 Jan 2013 23:50:59 -0500 Subject: [PATCH] Fanout service for Sparkleshare clients --- src/com/gitblit/wicket/panels/TeamsPanel.java | 37 ++++++++++++++++++++++--------------- 1 files changed, 22 insertions(+), 15 deletions(-) diff --git a/src/com/gitblit/wicket/panels/TeamsPanel.java b/src/com/gitblit/wicket/panels/TeamsPanel.java index 33afb51..b76388b 100644 --- a/src/com/gitblit/wicket/panels/TeamsPanel.java +++ b/src/com/gitblit/wicket/panels/TeamsPanel.java @@ -18,6 +18,7 @@ import java.text.MessageFormat; import java.util.List; +import org.apache.wicket.markup.html.basic.Label; import org.apache.wicket.markup.html.link.BookmarkablePageLink; import org.apache.wicket.markup.html.link.Link; import org.apache.wicket.markup.html.panel.Fragment; @@ -26,6 +27,7 @@ import org.apache.wicket.markup.repeater.data.ListDataProvider; import com.gitblit.GitBlit; +import com.gitblit.models.TeamModel; import com.gitblit.wicket.WicketUtils; import com.gitblit.wicket.pages.EditTeamPage; @@ -38,11 +40,11 @@ Fragment adminLinks = new Fragment("adminPanel", "adminLinks", this); adminLinks.add(new BookmarkablePageLink<Void>("newTeam", EditTeamPage.class)); - add(adminLinks.setVisible(showAdmin)); + add(adminLinks.setVisible(showAdmin && GitBlit.self().supportsTeamMembershipChanges(null))); - final List<String> teamnames = GitBlit.self().getAllTeamnames(); - DataView<String> teamsView = new DataView<String>("teamRow", new ListDataProvider<String>( - teamnames)) { + final List<TeamModel> teams = GitBlit.self().getAllTeams(); + DataView<TeamModel> teamsView = new DataView<TeamModel>("teamRow", + new ListDataProvider<TeamModel>(teams)) { private static final long serialVersionUID = 1L; private int counter; @@ -52,31 +54,36 @@ counter = 0; } - public void populateItem(final Item<String> item) { - final String entry = item.getModelObject(); - LinkPanel editLink = new LinkPanel("teamname", "list", entry, EditTeamPage.class, - WicketUtils.newTeamnameParameter(entry)); - WicketUtils.setHtmlTooltip(editLink, getString("gb.edit") + " " + entry); + public void populateItem(final Item<TeamModel> item) { + final TeamModel entry = item.getModelObject(); + LinkPanel editLink = new LinkPanel("teamname", "list", entry.name, + EditTeamPage.class, WicketUtils.newTeamnameParameter(entry.name)); + WicketUtils.setHtmlTooltip(editLink, getString("gb.edit") + " " + entry.name); item.add(editLink); + item.add(new Label("members", entry.users.size() > 0 ? ("" + entry.users.size()) + : "")); + item.add(new Label("repositories", + entry.repositories.size() > 0 ? ("" + entry.repositories.size()) : "")); Fragment teamLinks = new Fragment("teamLinks", "teamAdminLinks", this); teamLinks.add(new BookmarkablePageLink<Void>("editTeam", EditTeamPage.class, - WicketUtils.newTeamnameParameter(entry))); + WicketUtils.newTeamnameParameter(entry.name))); Link<Void> deleteLink = new Link<Void>("deleteTeam") { private static final long serialVersionUID = 1L; @Override public void onClick() { - if (GitBlit.self().deleteTeam(entry)) { - teamnames.remove(entry); - info(MessageFormat.format("Team ''{0}'' deleted.", entry)); + if (GitBlit.self().deleteTeam(entry.name)) { + teams.remove(entry); + info(MessageFormat.format("Team ''{0}'' deleted.", entry.name)); } else { - error(MessageFormat.format("Failed to delete team ''{0}''!", entry)); + error(MessageFormat + .format("Failed to delete team ''{0}''!", entry.name)); } } }; deleteLink.add(new JavascriptEventConfirmation("onclick", MessageFormat.format( - "Delete team \"{0}\"?", entry))); + "Delete team \"{0}\"?", entry.name))); teamLinks.add(deleteLink); item.add(teamLinks); -- Gitblit v1.9.1