James Moger
2011-07-27 f8dc86f1b362c2906ea302eb56928b59156cd484
src/com/gitblit/wicket/WicketUtils.java
@@ -22,14 +22,20 @@
import java.util.List;
import java.util.TimeZone;
import javax.servlet.http.HttpServletRequest;
import org.apache.wicket.Component;
import org.apache.wicket.PageParameters;
import org.apache.wicket.Request;
import org.apache.wicket.behavior.HeaderContributor;
import org.apache.wicket.behavior.SimpleAttributeModifier;
import org.apache.wicket.markup.html.IHeaderContributor;
import org.apache.wicket.markup.html.IHeaderResponse;
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.html.image.ContextImage;
import org.apache.wicket.protocol.http.WebRequest;
import org.apache.wicket.resource.ContextRelativeResource;
import org.eclipse.jgit.diff.DiffEntry.ChangeType;
import org.eclipse.jgit.lib.Constants;
import org.wicketstuff.googlecharts.AbstractChartData;
import org.wicketstuff.googlecharts.IChartData;
@@ -162,7 +168,7 @@
   }
   public static ContextImage newImage(String wicketId, String file, String tooltip) {
      ContextImage img = new ContextImage(wicketId, "/com/gitblit/wicket/resources/" + file);
      ContextImage img = new ContextImage(wicketId, file);
      if (!StringUtils.isEmpty(tooltip)) {
         setHtmlTooltip(img, tooltip);
      }
@@ -170,7 +176,42 @@
   }
   public static ContextRelativeResource getResource(String file) {
      return new ContextRelativeResource("/com/gitblit/wicket/resources/" + file);
      return new ContextRelativeResource(file);
   }
   public static String getHostURL(Request request) {
      HttpServletRequest req = ((WebRequest) request).getHttpServletRequest();
      return getHostURL(req);
   }
   public static String getHostURL(HttpServletRequest request) {
      StringBuilder sb = new StringBuilder();
      sb.append(request.getScheme());
      sb.append("://");
      sb.append(request.getServerName());
      if ((request.getScheme().equals("http") && request.getServerPort() != 80)
            || (request.getScheme().equals("https") && request.getServerPort() != 443)) {
         sb.append(":" + request.getServerPort());
      }
      return sb.toString();
   }
   public static HeaderContributor syndicationDiscoveryLink(final String feedTitle,
         final String url) {
      return new HeaderContributor(new IHeaderContributor() {
         private static final long serialVersionUID = 1L;
         public void renderHead(IHeaderResponse response) {
            String contentType = "application/rss+xml";
            StringBuffer buffer = new StringBuffer();
            buffer.append("<link rel=\"alternate\" ");
            buffer.append("type=\"").append(contentType).append("\" ");
            buffer.append("title=\"").append(feedTitle).append("\" ");
            buffer.append("href=\"").append(url).append("\" />");
            response.renderString(buffer.toString());
         }
      });
   }
   public static PageParameters newUsernameParameter(String username) {
@@ -193,6 +234,9 @@
      if (StringUtils.isEmpty(path)) {
         return newObjectParameter(repositoryName, objectId);
      }
      if (StringUtils.isEmpty(objectId)) {
         return new PageParameters("r=" + repositoryName + ",f=" + path);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + objectId + ",f=" + path);
   }
@@ -200,6 +244,9 @@
         int pageNumber) {
      if (pageNumber <= 1) {
         return newObjectParameter(repositoryName, objectId);
      }
      if (StringUtils.isEmpty(objectId)) {
         return new PageParameters("r=" + repositoryName + ",page=" + pageNumber);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + objectId + ",page=" + pageNumber);
   }
@@ -209,12 +256,18 @@
      if (pageNumber <= 1) {
         return newObjectParameter(repositoryName, objectId);
      }
      if (StringUtils.isEmpty(objectId)) {
         return new PageParameters("r=" + repositoryName + ",f=" + path + ",page=" + pageNumber);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + objectId + ",f=" + path
            + ",page=" + pageNumber);
   }
   public static PageParameters newBlobDiffParameter(String repositoryName, String baseCommitId,
         String commitId, String path) {
      if (StringUtils.isEmpty(commitId)) {
         return new PageParameters("r=" + repositoryName + ",f=" + path + ",hb=" + baseCommitId);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + commitId + ",f=" + path + ",hb="
            + baseCommitId);
   }
@@ -230,6 +283,10 @@
   public static PageParameters newSearchParameter(String repositoryName, String commitId,
         String search, SearchType type, int pageNumber) {
      if (StringUtils.isEmpty(commitId)) {
         return new PageParameters("r=" + repositoryName + ",s=" + search + ",st=" + type.name()
               + ",page=" + pageNumber);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + commitId + ",s=" + search
            + ",st=" + type.name() + ",page=" + pageNumber);
   }
@@ -239,7 +296,7 @@
   }
   public static String getObject(PageParameters params) {
      return params.getString("h", Constants.HEAD);
      return params.getString("h", null);
   }
   public static String getPath(PageParameters params) {
@@ -293,7 +350,12 @@
      if (timeZone != null) {
         df.setTimeZone(timeZone);
      }
      String dateString = df.format(date);
      String dateString;
      if (date.getTime() == 0) {
         dateString = "--";
      } else {
         dateString = df.format(date);
      }
      String title = TimeUtils.timeAgo(date);
      Label label = new Label(wicketId, dateString);
      WicketUtils.setHtmlTooltip(label, title);