From a75a1819f4c7fa5080ddb47545fe9012a842e5b3 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Wed, 20 Jul 2011 21:08:57 -0400 Subject: [PATCH] Misc fixes. --- src/com/gitblit/wicket/WicketUtils.java | 111 ++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 109 insertions(+), 2 deletions(-) diff --git a/src/com/gitblit/wicket/WicketUtils.java b/src/com/gitblit/wicket/WicketUtils.java index ac31488..1897aca 100644 --- a/src/com/gitblit/wicket/WicketUtils.java +++ b/src/com/gitblit/wicket/WicketUtils.java @@ -17,21 +17,32 @@ import java.text.DateFormat; import java.text.SimpleDateFormat; +import java.util.Collection; import java.util.Date; 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; import com.gitblit.GitBlit; import com.gitblit.Keys; +import com.gitblit.models.Metric; import com.gitblit.utils.JGitUtils.SearchType; import com.gitblit.utils.StringUtils; import com.gitblit.utils.TimeUtils; @@ -158,7 +169,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); } @@ -166,7 +177,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) { @@ -295,4 +341,65 @@ WicketUtils.setHtmlTooltip(label, title); return label; } + + public static IChartData getChartData(Collection<Metric> metrics) { + final double[] commits = new double[metrics.size()]; + final double[] tags = new double[metrics.size()]; + int i = 0; + double max = 0; + for (Metric m : metrics) { + commits[i] = m.count; + if (m.tag > 0) { + tags[i] = m.count; + } else { + tags[i] = -1d; + } + max = Math.max(max, m.count); + i++; + } + IChartData data = new AbstractChartData(max) { + private static final long serialVersionUID = 1L; + + public double[][] getData() { + return new double[][] { commits, tags }; + } + }; + return data; + } + + public static double maxValue(Collection<Metric> metrics) { + double max = Double.MIN_VALUE; + for (Metric m : metrics) { + if (m.count > max) { + max = m.count; + } + } + return max; + } + + public static IChartData getScatterData(Collection<Metric> metrics) { + final double[] y = new double[metrics.size()]; + final double[] x = new double[metrics.size()]; + int i = 0; + double max = 0; + for (Metric m : metrics) { + y[i] = m.count; + if (m.duration > 0) { + x[i] = m.duration; + } else { + x[i] = -1d; + } + max = Math.max(max, m.count); + i++; + } + IChartData data = new AbstractChartData(max) { + private static final long serialVersionUID = 1L; + + public double[][] getData() { + return new double[][] { x, y }; + } + }; + return data; + } + } -- Gitblit v1.9.1