Yuhi Ishikura
2013-06-02 7eb9828ec6a31ad372c6a1dac7fa042bcdbd6818
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;
@@ -29,11 +34,13 @@
import com.gitblit.Constants;
import com.gitblit.GitBlit;
import com.gitblit.Keys;
import com.gitblit.models.DailyLogEntry;
import com.gitblit.models.PushLogEntry;
import com.gitblit.models.RepositoryCommit;
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;
@@ -51,7 +58,7 @@
   
   private boolean hasMore;
   public PushesPanel(String wicketId, final RepositoryModel model, Repository r, int limit, int pageOffset) {
   public PushesPanel(String wicketId, final RepositoryModel model, Repository r, int limit, int pageOffset, boolean showRepo) {
      super(wicketId);
      boolean pageResults = limit <= 0;
      int pushesPerPage = GitBlit.getInteger(Keys.web.pushesPerPage, 10);
@@ -59,20 +66,59 @@
         pushesPerPage = 10;
      }
      final int hashLen = GitBlit.getInteger(Keys.web.shortCommitIdLength, 6);
      List<PushLogEntry> pushes;
      if (pageResults) {
         pushes = PushLogUtils.getPushLogByRef(model.name, r, pageOffset * pushesPerPage, pushesPerPage);
      } else {
         pushes = PushLogUtils.getPushLogByRef(model.name, r, limit);
      }
      // inaccurate way to determine if there are more commits.
      // works unless commits.size() represents the exact end.
      hasMore = pushes.size() >= pushesPerPage;
      hasPushes = pushes.size() > 0;
      setup(pushes, showRepo);
      // determine to show pager, more, or neither
      if (limit <= 0) {
         // no display limit
         add(new Label("morePushes").setVisible(false));
      } else {
         if (pageResults) {
            // paging
            add(new Label("morePushes").setVisible(false));
         } else {
            // more
            if (pushes.size() == limit) {
               // show more
               add(new LinkPanel("morePushes", "link", new StringResourceModel("gb.morePushes",
                     this, null), PushesPage.class,
                     WicketUtils.newRepositoryParameter(model.name)));
            } else {
               // no more
               add(new Label("morePushes").setVisible(false));
            }
         }
      }
   }
   public PushesPanel(String wicketId, List<PushLogEntry> pushes) {
      super(wicketId);
      hasPushes = pushes.size() > 0;
      setup(pushes, true);
      add(new Label("morePushes").setVisible(false));
   }
   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;
@@ -82,40 +128,109 @@
            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()));
            pushItem.add(new GravatarImage("whoAvatar", push.getCommitterIdent(), 40));
            if (push.user.username.equals(push.user.emailAddress) && push.user.emailAddress.indexOf('@') > -1) {
               // username is an email address - 1.2.1 push log bug
               pushItem.add(new Label("whoPushed", push.user.getDisplayName()));
            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 {
               // link to user acount page
               pushItem.add(new LinkPanel("whoPushed", null, push.user.getDisplayName(),
                  UserPage.class, WicketUtils.newUsernameParameter(push.user.username)));
               // 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
               // repos.  use the repository hash color to differentiate
               // the icon.
                   String color = StringUtils.getColor(StringUtils.stripDotGit(push.repository));
                   WicketUtils.setCssStyle(pushIcon, "color: " + color);
            }
            if (isTag) {
               WicketUtils.setCssClass(pushIcon, "iconic-tag");
            } else if (isPull) {
               WicketUtils.setCssClass(pushIcon, "iconic-share");
            } else if (isDigest) {
               WicketUtils.setCssClass(pushIcon, "iconic-loop");
            } else {
               WicketUtils.setCssClass(pushIcon, "iconic-upload");
            }
            pushItem.add(pushIcon);
                if (isDigest && !isTag) {
                   pushItem.add(new Label("whoPushed").setVisible(false));
                } else {
                   if (push.user.username.equals(push.user.emailAddress) && push.user.emailAddress.indexOf('@') > -1) {
                      // username is an email address - 1.2.1 push log bug
                      pushItem.add(new Label("whoPushed", push.user.getDisplayName()));
                   } else {
                      // link to user account page
                      pushItem.add(new LinkPanel("whoPushed", null, push.user.getDisplayName(),
                            UserPage.class, WicketUtils.newUsernameParameter(push.user.username)));
                   }
                }
            
            String preposition = "gb.at";
            String preposition = "gb.of";
            boolean isDelete = false;
            boolean isRewind = false;
            String what;
            String by = null;
            switch(push.getChangeType(fullRefName)) {
            case CREATE:
               if (isTag) {
                  what = getString("gb.pushedNewTag");
                  // new tag
                  if (isDigest) {
                     what = getString("gb.createdNewTag");
                     preposition = "gb.in";
                  } else {
                     what = getString("gb.pushedNewTag");
                     preposition = "gb.to";
                  }
               } else if (isPull) {
                  // merged pull request
                  what = getString("gb.mergedPullRequest");
                  preposition = "gb.in";
               } else {
                  what = getString("gb.pushedNewBranch");
                  // new branch
                  if (isDigest) {
                     what = getString("gb.createdNewBranch");
                     preposition = "gb.in";
                  } else {
                     what = getString("gb.pushedNewBranch");
                     preposition = "gb.to";
                  }
               }
               preposition = "gb.to";
               break;
            case DELETE:
               isDelete = true;
               if (isTag) {
                  what = getString("gb.deletedTag");
               } if (isPull) {
                  what = getString("gb.deletedTag");
               } else {
                  what = getString("gb.deletedBranch");
@@ -125,10 +240,21 @@
            case UPDATE_NONFASTFORWARD:
               isRewind = true;
            default:
               what = MessageFormat.format(push.getCommitCount() > 1 ? getString("gb.pushedNCommitsTo") : getString("gb.pushedOneCommitTo") , push.getCommitCount());
               if (isDigest) {
                  what = MessageFormat.format(push.getCommitCount() > 1 ? getString("gb.commitsTo") : getString("gb.oneCommitTo"), push.getCommitCount());
               } else {
                  what = MessageFormat.format(push.getCommitCount() > 1 ? getString("gb.pushedNCommitsTo") : getString("gb.pushedOneCommitTo") , push.getCommitCount());
               }
               if (push.getAuthorCount() == 1) {
                  by = MessageFormat.format(getString("gb.byOneAuthor"), push.getAuthorIdent().getName());
               } else {
                  by = MessageFormat.format(getString("gb.byNAuthors"), push.getAuthorCount());
               }
               break;
            }
            pushItem.add(new Label("whatPushed", what));
            pushItem.add(new Label("byAuthors", by).setVisible(!StringUtils.isEmpty(by)));
            
            pushItem.add(new Label("refRewind", getString("gb.rewind")).setVisible(isRewind));
            
@@ -138,20 +264,31 @@
            } else if (isTag) {
               // link to tag
               pushItem.add(new LinkPanel("refPushed", null, shortRefName,
                     TagPage.class, WicketUtils.newObjectParameter(model.name, fullRefName)));
                     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,
                  TreePage.class, WicketUtils.newObjectParameter(model.name, fullRefName)));
                  TreePage.class, WicketUtils.newObjectParameter(push.repository, fullRefName)));
            }
            
            // to/from/etc
            pushItem.add(new Label("repoPreposition", getString(preposition)));
            String repoName = StringUtils.stripDotGit(model.name);
            pushItem.add(new LinkPanel("repoPushed", null, repoName,
                  SummaryPage.class, WicketUtils.newRepositoryParameter(model.name)));
            if (showRepo) {
               // to/from/etc
               pushItem.add(new Label("repoPreposition", getString(preposition)));
               String repoName = StringUtils.stripDotGit(push.repository);
               pushItem.add(new LinkPanel("repoPushed", null, repoName,
                     SummaryPage.class, WicketUtils.newRepositoryParameter(push.repository)));
            } else {
               // do not display repository name if we are viewing the push
               // log of a repository.
               pushItem.add(new Label("repoPreposition").setVisible(false));
               pushItem.add(new Label("repoPushed").setVisible(false));
            }
            int maxCommitCount = 5;
            List<RepositoryCommit> commits = push.getCommits();
            if (commits.size() > maxCommitCount) {
@@ -173,6 +310,8 @@
               String startRangeId = push.getOldId(fullRefName);
               pushItem.add(new LinkPanel("compareLink", null, compareLinkText, ComparePage.class, WicketUtils.newRangeParameter(push.repository, startRangeId, endRangeId)));
            }
            final boolean showSwatch = showRepo && GitBlit.getBoolean(Keys.web.repositoryListSwatches, true);
            
            ListDataProvider<RepositoryCommit> cdp = new ListDataProvider<RepositoryCommit>(commits);
            DataView<RepositoryCommit> commitsView = new DataView<RepositoryCommit>("commit", cdp) {
@@ -202,7 +341,7 @@
                  }
                  LinkPanel shortlog = new LinkPanel("commitShortMessage", "list",
                        trimmedMessage, CommitPage.class, WicketUtils.newObjectParameter(
                              model.name, commit.getName()));
                              push.repository, commit.getName()));
                  if (!shortMessage.equals(trimmedMessage)) {
                     WicketUtils.setHtmlTooltip(shortlog, shortMessage);
                  }
@@ -211,39 +350,24 @@
                  // commit hash link
                  LinkPanel commitHash = new LinkPanel("hashLink", null, commit.getName().substring(0, hashLen),
                        CommitPage.class, WicketUtils.newObjectParameter(
                              model.name, commit.getName()));
                              push.repository, commit.getName()));
                  WicketUtils.setCssClass(commitHash, "shortsha1");
                  WicketUtils.setHtmlTooltip(commitHash, commit.getName());
                  commitItem.add(commitHash);
                  if (showSwatch) {
                     // set repository color
                     String color = StringUtils.getColor(StringUtils.stripDotGit(push.repository));
                     WicketUtils.setCssStyle(commitItem, MessageFormat.format("border-left: 2px solid {0};", color));
                  }
               }
            };
            pushItem.add(commitsView);
         }
      };
      add(pushView);
      // determine to show pager, more, or neither
      if (limit <= 0) {
         // no display limit
         add(new Label("morePushes").setVisible(false));
      } else {
         if (pageResults) {
            // paging
            add(new Label("morePushes").setVisible(false));
         } else {
            // more
            if (pushes.size() == limit) {
               // show more
               add(new LinkPanel("morePushes", "link", new StringResourceModel("gb.morePushes",
                     this, null), PushesPage.class,
                     WicketUtils.newRepositoryParameter(model.name)));
            } else {
               // no more
               add(new Label("morePushes").setVisible(false));
            }
         }
      }
   }
   public boolean hasMore() {