From 9b26b74d198aa4efbe4b25f6667b98eb5261e13d Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Fri, 31 May 2013 20:08:50 -0400 Subject: [PATCH] Refinements to push log display and daily digests --- src/main/java/com/gitblit/wicket/panels/PushesPanel.java | 62 ++++++++++++++++++++++++++++-- 1 files changed, 57 insertions(+), 5 deletions(-) diff --git a/src/main/java/com/gitblit/wicket/panels/PushesPanel.java b/src/main/java/com/gitblit/wicket/panels/PushesPanel.java index 7bac70e..5c473f7 100644 --- a/src/main/java/com/gitblit/wicket/panels/PushesPanel.java +++ b/src/main/java/com/gitblit/wicket/panels/PushesPanel.java @@ -15,9 +15,14 @@ */ package com.gitblit.wicket.panels; +import java.text.DateFormat; import java.text.MessageFormat; +import java.text.SimpleDateFormat; import java.util.ArrayList; +import java.util.Calendar; +import java.util.Date; import java.util.List; +import java.util.TimeZone; import org.apache.wicket.markup.html.basic.Label; import org.apache.wicket.markup.repeater.Item; @@ -35,6 +40,7 @@ import com.gitblit.models.RepositoryModel; import com.gitblit.utils.PushLogUtils; import com.gitblit.utils.StringUtils; +import com.gitblit.utils.TimeUtils; import com.gitblit.wicket.WicketUtils; import com.gitblit.wicket.pages.CommitPage; import com.gitblit.wicket.pages.ComparePage; @@ -107,6 +113,12 @@ protected void setup(List<PushLogEntry> pushes, final boolean showRepo) { final int hashLen = GitBlit.getInteger(Keys.web.shortCommitIdLength, 6); + String dateFormat = GitBlit.getString(Keys.web.datestampLongFormat, "EEEE, MMMM d, yyyy"); + final TimeZone timezone = getTimeZone(); + final DateFormat df = new SimpleDateFormat(dateFormat); + df.setTimeZone(timezone); + final Calendar cal = Calendar.getInstance(timezone); + ListDataProvider<PushLogEntry> dp = new ListDataProvider<PushLogEntry>(pushes); DataView<PushLogEntry> pushView = new DataView<PushLogEntry>("push", dp) { private static final long serialVersionUID = 1L; @@ -116,15 +128,41 @@ String fullRefName = push.getChangedRefs().get(0); String shortRefName = fullRefName; boolean isTag = false; - if (shortRefName.startsWith(org.eclipse.jgit.lib.Constants.R_HEADS)) { - shortRefName = shortRefName.substring(org.eclipse.jgit.lib.Constants.R_HEADS.length()); - } else if (shortRefName.startsWith(org.eclipse.jgit.lib.Constants.R_TAGS)) { - shortRefName = shortRefName.substring(org.eclipse.jgit.lib.Constants.R_TAGS.length()); + boolean isPull = false; + if (shortRefName.startsWith(Constants.R_HEADS)) { + shortRefName = shortRefName.substring(Constants.R_HEADS.length()); + } else if (shortRefName.startsWith(Constants.R_TAGS)) { + shortRefName = shortRefName.substring(Constants.R_TAGS.length()); isTag = true; + } else if (shortRefName.startsWith(Constants.R_PULL)) { + shortRefName = "#" + shortRefName.substring(Constants.R_PULL.length()); + if (shortRefName.endsWith("/head")) { + // strip pull request head from name + shortRefName = shortRefName.substring(0, shortRefName.length() - "/head".length()); + } + isPull = true; } boolean isDigest = push instanceof DailyLogEntry; - pushItem.add(WicketUtils.createDateLabel("whenPushed", push.date, getTimeZone(), getTimeUtils())); + String fuzzydate; + TimeUtils tu = getTimeUtils(); + Date pushDate = push.date; + if (TimeUtils.isToday(pushDate, timezone)) { + fuzzydate = tu.today(); + } else if (TimeUtils.isYesterday(pushDate, timezone)) { + fuzzydate = tu.yesterday(); + } else { + // calculate a fuzzy time ago date + cal.setTime(pushDate); + cal.set(Calendar.HOUR_OF_DAY, 0); + cal.set(Calendar.MINUTE, 0); + cal.set(Calendar.SECOND, 0); + cal.set(Calendar.MILLISECOND, 0); + pushDate = cal.getTime(); + fuzzydate = getTimeUtils().timeAgo(pushDate); + } + pushItem.add(new Label("whenPushed", fuzzydate + ", " + df.format(pushDate))); + Label pushIcon = new Label("pushIcon"); if (showRepo) { // if we are showing the repo, we are showing multiple @@ -135,6 +173,8 @@ } if (isTag) { WicketUtils.setCssClass(pushIcon, "iconic-tag"); + } else if (isPull) { + WicketUtils.setCssClass(pushIcon, "iconic-share"); } else if (isDigest) { WicketUtils.setCssClass(pushIcon, "iconic-loop"); } else { @@ -163,6 +203,7 @@ switch(push.getChangeType(fullRefName)) { case CREATE: if (isTag) { + // new tag if (isDigest) { what = getString("gb.createdNewTag"); preposition = "gb.in"; @@ -170,7 +211,12 @@ what = getString("gb.pushedNewTag"); preposition = "gb.to"; } + } else if (isPull) { + // merged pull request + what = getString("gb.mergedPullRequest"); + preposition = "gb.in"; } else { + // new branch if (isDigest) { what = getString("gb.createdNewBranch"); preposition = "gb.in"; @@ -183,6 +229,8 @@ case DELETE: isDelete = true; if (isTag) { + what = getString("gb.deletedTag"); + } if (isPull) { what = getString("gb.deletedTag"); } else { what = getString("gb.deletedBranch"); @@ -217,6 +265,10 @@ // link to tag pushItem.add(new LinkPanel("refPushed", null, shortRefName, TagPage.class, WicketUtils.newObjectParameter(push.repository, fullRefName))); + } else if (isPull) { + // link to pull request + pushItem.add(new LinkPanel("refPushed", null, shortRefName, + TagPage.class, WicketUtils.newObjectParameter(push.repository, fullRefName))); } else { // link to tree pushItem.add(new LinkPanel("refPushed", null, shortRefName, -- Gitblit v1.9.1