James Moger
2012-10-22 eba89539a29deba954035056437279088c3e047b
src/com/gitblit/wicket/panels/HistoryPanel.java
@@ -30,33 +30,34 @@
import org.eclipse.jgit.lib.Repository;
import org.eclipse.jgit.revwalk.RevCommit;
import com.gitblit.Constants;
import com.gitblit.GitBlit;
import com.gitblit.Keys;
import com.gitblit.models.PathModel;
import com.gitblit.models.PathModel.PathChangeModel;
import com.gitblit.models.RefModel;
import com.gitblit.utils.JGitUtils;
import com.gitblit.utils.JGitUtils.SearchType;
import com.gitblit.utils.StringUtils;
import com.gitblit.wicket.LinkPanel;
import com.gitblit.wicket.WicketUtils;
import com.gitblit.wicket.models.PathModel;
import com.gitblit.wicket.models.PathModel.PathChangeModel;
import com.gitblit.wicket.pages.BlobDiffPage;
import com.gitblit.wicket.pages.BlobPage;
import com.gitblit.wicket.pages.CommitDiffPage;
import com.gitblit.wicket.pages.CommitPage;
import com.gitblit.wicket.pages.HistoryPage;
import com.gitblit.wicket.pages.SearchPage;
import com.gitblit.wicket.pages.GitSearchPage;
import com.gitblit.wicket.pages.TreePage;
public class HistoryPanel extends BasePanel {
   private static final long serialVersionUID = 1L;
   private boolean hasMore = false;
   private boolean hasMore;
   public HistoryPanel(String wicketId, final String repositoryName, final String objectId, final String path, Repository r, int limit, int pageOffset) {
   public HistoryPanel(String wicketId, final String repositoryName, final String objectId,
         final String path, Repository r, int limit, int pageOffset, boolean showRemoteRefs) {
      super(wicketId);
      boolean pageResults = limit <= 0;
      int itemsPerPage = GitBlit.self().settings().getInteger(Keys.web.itemsPerPage, 50);
      int itemsPerPage = GitBlit.getInteger(Keys.web.itemsPerPage, 50);
      if (itemsPerPage <= 1) {
         itemsPerPage = 50;
      }
@@ -73,11 +74,12 @@
      }
      final boolean isTree = matchingPath == null ? true : matchingPath.isTree();
      final Map<ObjectId, List<String>> allRefs = JGitUtils.getAllRefs(r);
      final Map<ObjectId, List<RefModel>> allRefs = JGitUtils.getAllRefs(r, showRemoteRefs);
      List<RevCommit> commits;
      if (pageResults) {
         // Paging result set
         commits = JGitUtils.getRevLog(r, objectId, path, pageOffset * itemsPerPage, itemsPerPage);
         commits = JGitUtils.getRevLog(r, objectId, path, pageOffset * itemsPerPage,
               itemsPerPage);
      } else {
         // Fixed size result set
         commits = JGitUtils.getRevLog(r, objectId, path, 0, limit);
@@ -95,18 +97,21 @@
      ListDataProvider<RevCommit> dp = new ListDataProvider<RevCommit>(commits);
      DataView<RevCommit> logView = new DataView<RevCommit>("commit", dp) {
         private static final long serialVersionUID = 1L;
         int counter = 0;
         int counter;
         public void populateItem(final Item<RevCommit> item) {
            final RevCommit entry = item.getModelObject();
            final Date date = JGitUtils.getCommitDate(entry);
            item.add(WicketUtils.createDateLabel("commitDate", date, getTimeZone()));
            item.add(WicketUtils.createDateLabel("commitDate", date, getTimeZone(), getTimeUtils()));
            // author search link
            String author = entry.getAuthorIdent().getName();
            LinkPanel authorLink = new LinkPanel("commitAuthor", "list", author, SearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, author, SearchType.AUTHOR));
            setPersonSearchTooltip(authorLink, author, SearchType.AUTHOR);
            LinkPanel authorLink = new LinkPanel("commitAuthor", "list", author,
                  GitSearchPage.class,
                  WicketUtils.newSearchParameter(repositoryName, objectId,
                        author, Constants.SearchType.AUTHOR));
            setPersonSearchTooltip(authorLink, author, Constants.SearchType.AUTHOR);
            item.add(authorLink);
            // merge icon
@@ -117,8 +122,15 @@
            }
            String shortMessage = entry.getShortMessage();
            String trimmedMessage = StringUtils.trimShortLog(shortMessage);
            LinkPanel shortlog = new LinkPanel("commitShortMessage", "list subject", trimmedMessage, CommitPage.class, WicketUtils.newObjectParameter(repositoryName, entry.getName()));
            String trimmedMessage = shortMessage;
            if (allRefs.containsKey(entry.getId())) {
               trimmedMessage = StringUtils.trimString(shortMessage, Constants.LEN_SHORTLOG_REFS);
            } else {
               trimmedMessage = StringUtils.trimString(shortMessage, Constants.LEN_SHORTLOG);
            }
            LinkPanel shortlog = new LinkPanel("commitShortMessage", "list subject",
                  trimmedMessage, CommitPage.class, WicketUtils.newObjectParameter(
                        repositoryName, entry.getName()));
            if (!shortMessage.equals(trimmedMessage)) {
               WicketUtils.setHtmlTooltip(shortlog, shortMessage);
            }
@@ -128,14 +140,20 @@
            if (isTree) {
               Fragment links = new Fragment("historyLinks", "treeLinks", this);
               links.add(new BookmarkablePageLink<Void>("tree", TreePage.class, WicketUtils.newObjectParameter(repositoryName, entry.getName())));
               links.add(new BookmarkablePageLink<Void>("commitdiff", CommitDiffPage.class, WicketUtils.newObjectParameter(repositoryName, entry.getName())));
               links.add(new BookmarkablePageLink<Void>("tree", TreePage.class, WicketUtils
                     .newObjectParameter(repositoryName, entry.getName())));
               links.add(new BookmarkablePageLink<Void>("commitdiff", CommitDiffPage.class,
                     WicketUtils.newObjectParameter(repositoryName, entry.getName())));
               item.add(links);
            } else {
               Fragment links = new Fragment("historyLinks", "blobLinks", this);
               links.add(new BookmarkablePageLink<Void>("view", BlobPage.class, WicketUtils.newPathParameter(repositoryName, entry.getName(), path)));
               links.add(new BookmarkablePageLink<Void>("commitdiff", CommitDiffPage.class, WicketUtils.newObjectParameter(repositoryName, entry.getName())));
               links.add(new BookmarkablePageLink<Void>("difftocurrent", BlobDiffPage.class, WicketUtils.newBlobDiffParameter(repositoryName, entry.getName(), objectId, path)).setEnabled(counter > 0));
               links.add(new BookmarkablePageLink<Void>("view", BlobPage.class, WicketUtils
                     .newPathParameter(repositoryName, entry.getName(), path)));
               links.add(new BookmarkablePageLink<Void>("commitdiff", CommitDiffPage.class,
                     WicketUtils.newObjectParameter(repositoryName, entry.getName())));
               links.add(new BookmarkablePageLink<Void>("difftocurrent", BlobDiffPage.class,
                     WicketUtils.newBlobDiffParameter(repositoryName, entry.getName(),
                           objectId, path)).setEnabled(counter > 0));
               item.add(links);
            }
@@ -157,7 +175,9 @@
            // more
            if (commits.size() == limit) {
               // show more
               add(new LinkPanel("moreHistory", "link", new StringResourceModel("gb.moreHistory", this, null), HistoryPage.class, WicketUtils.newPathParameter(repositoryName, objectId, path)));
               add(new LinkPanel("moreHistory", "link", new StringResourceModel(
                     "gb.moreHistory", this, null), HistoryPage.class,
                     WicketUtils.newPathParameter(repositoryName, objectId, path)));
            } else {
               // no more
               add(new Label("moreHistory", "").setVisible(false));