James Moger
2014-05-29 2c50880dbd5de292e37d2533fccfcb62f6be9f95
src/main/java/com/gitblit/wicket/panels/ProjectRepositoryPanel.java
@@ -15,7 +15,6 @@
 */
package com.gitblit.wicket.panels;
import java.text.MessageFormat;
import java.util.Map;
import org.apache.wicket.Component;
@@ -24,15 +23,13 @@
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.html.link.BookmarkablePageLink;
import org.apache.wicket.markup.html.link.ExternalLink;
import org.apache.wicket.markup.html.link.Link;
import org.apache.wicket.markup.html.panel.Fragment;
import com.gitblit.Constants.AccessRestrictionType;
import com.gitblit.GitBlit;
import com.gitblit.Keys;
import com.gitblit.SyndicationServlet;
import com.gitblit.models.RepositoryModel;
import com.gitblit.models.UserModel;
import com.gitblit.servlet.SyndicationServlet;
import com.gitblit.utils.ArrayUtils;
import com.gitblit.utils.StringUtils;
import com.gitblit.wicket.GitBlitWebSession;
@@ -51,8 +48,8 @@
         final Map<AccessRestrictionType, String> accessRestrictions) {
      super(wicketId);
      final boolean showSwatch = GitBlit.getBoolean(Keys.web.repositoryListSwatches, true);
      final boolean showSize = GitBlit.getBoolean(Keys.web.showRepositorySizes, true);
      final boolean showSwatch = app().settings().getBoolean(Keys.web.repositoryListSwatches, true);
      final boolean showSize = app().settings().getBoolean(Keys.web.showRepositorySizes, true);
      // repository swatch
      Component swatch;
@@ -110,7 +107,7 @@
      } else {
         String owner = "";
         for (String username : entry.owners) {
            UserModel ownerModel = GitBlit.self().getUserModel(username);
            UserModel ownerModel = app().users().getUserModel(username);
            if (ownerModel != null) {
               owner = ownerModel.getDisplayName();
@@ -130,38 +127,10 @@
         user = UserModel.ANONYMOUS;
      }
      Fragment repositoryLinks;
      boolean showOwner = entry.isOwner(user.username);
      // owner of personal repository gets admin powers
      boolean showAdmin = isAdmin || entry.isUsersPersonalRepository(user.username);
      if (showAdmin || showOwner) {
         repositoryLinks = new Fragment("repositoryLinks", showAdmin ? "repositoryAdminLinks"
               : "repositoryOwnerLinks", this);
      if (user.canAdmin(entry)) {
         repositoryLinks = new Fragment("repositoryLinks", "repositoryOwnerLinks", this);
         repositoryLinks.add(new BookmarkablePageLink<Void>("editRepository", EditRepositoryPage.class,
               WicketUtils.newRepositoryParameter(entry.name)));
         if (showAdmin) {
            Link<Void> deleteLink = new Link<Void>("deleteRepository") {
               private static final long serialVersionUID = 1L;
               @Override
               public void onClick() {
                  if (GitBlit.self().deleteRepositoryModel(entry)) {
                     // redirect to the owning page
                     if (entry.isPersonalRepository()) {
                        setResponsePage(getPage().getClass(), WicketUtils.newUsernameParameter(entry.projectPath.substring(1)));
                     } else {
                        setResponsePage(getPage().getClass(), WicketUtils.newProjectParameter(entry.projectPath));
                     }
                  } else {
                     error(MessageFormat.format(getString("gb.repositoryDeleteFailed"), entry));
                  }
               }
            };
            deleteLink.add(new JavascriptEventConfirmation("onclick", MessageFormat.format(
                  localizer.getString("gb.deleteRepository", parent), entry)));
            repositoryLinks.add(deleteLink);
         }
      } else {
         repositoryLinks = new Fragment("repositoryLinks", "repositoryUserLinks", this);
      }