From f66e89662c091e082bd1d2feb6ac91513ccff273 Mon Sep 17 00:00:00 2001 From: Rafael Cavazin <rafaelcavazin@gmail.com> Date: Sun, 21 Jul 2013 09:59:00 -0400 Subject: [PATCH] Merge branch 'master' of https://github.com/gitblit/gitblit --- src/main/java/com/gitblit/wicket/panels/RefsPanel.java | 179 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 179 insertions(+), 0 deletions(-) diff --git a/src/main/java/com/gitblit/wicket/panels/RefsPanel.java b/src/main/java/com/gitblit/wicket/panels/RefsPanel.java new file mode 100644 index 0000000..e477b65 --- /dev/null +++ b/src/main/java/com/gitblit/wicket/panels/RefsPanel.java @@ -0,0 +1,179 @@ +/* + * Copyright 2011 gitblit.com. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.gitblit.wicket.panels; + +import java.text.MessageFormat; +import java.util.ArrayList; +import java.util.Collections; +import java.util.Comparator; +import java.util.List; +import java.util.Map; + +import org.apache.wicket.Component; +import org.apache.wicket.markup.html.WebPage; +import org.apache.wicket.markup.html.basic.Label; +import org.apache.wicket.markup.html.panel.Panel; +import org.apache.wicket.markup.repeater.Item; +import org.apache.wicket.markup.repeater.data.DataView; +import org.apache.wicket.markup.repeater.data.ListDataProvider; +import org.eclipse.jgit.lib.ObjectId; +import org.eclipse.jgit.revwalk.RevCommit; + +import com.gitblit.Constants; +import com.gitblit.models.RefModel; +import com.gitblit.utils.StringUtils; +import com.gitblit.wicket.WicketUtils; +import com.gitblit.wicket.pages.CommitPage; +import com.gitblit.wicket.pages.LogPage; +import com.gitblit.wicket.pages.TagPage; + +public class RefsPanel extends Panel { + + private static final long serialVersionUID = 1L; + + public RefsPanel(String id, final String repositoryName, RevCommit c, + Map<ObjectId, List<RefModel>> refs) { + this(id, repositoryName, refs.get(c.getId())); + } + + public RefsPanel(String id, final String repositoryName, List<RefModel> refs) { + super(id); + if (refs == null) { + refs = new ArrayList<RefModel>(); + } + Collections.sort(refs, new Comparator<RefModel>() { + @Override + public int compare(RefModel o1, RefModel o2) { + // sort remote heads last, otherwise sort by name + // this is so we can insert a break on the refs panel + // [head][branch][branch][tag][tag] + // [remote][remote][remote] + boolean remote1 = o1.displayName.startsWith(Constants.R_REMOTES); + boolean remote2 = o2.displayName.startsWith(Constants.R_REMOTES); + if (remote1 && remote2) { + // both are remote heads, sort by name + return o1.displayName.compareTo(o2.displayName); + } + if (remote1) { + // o1 is remote, o2 comes first + return 1; + } + if (remote2) { + // remote is o2, o1 comes first + return -1; + } + // standard sort + return o1.displayName.compareTo(o2.displayName); + } + }); + + // count remote and determine if we should insert a break + int remoteCount = 0; + for (RefModel ref : refs) { + if (ref.displayName.startsWith(Constants.R_REMOTES)) { + remoteCount++; + } + } + final boolean shouldBreak = remoteCount < refs.size(); + + ListDataProvider<RefModel> refsDp = new ListDataProvider<RefModel>(refs); + DataView<RefModel> refsView = new DataView<RefModel>("ref", refsDp) { + private static final long serialVersionUID = 1L; + private boolean alreadyInsertedBreak = !shouldBreak; + + public void populateItem(final Item<RefModel> item) { + RefModel entry = item.getModelObject(); + String name = entry.displayName; + String objectid = entry.getReferencedObjectId().getName(); + boolean breakLine = false; + Class<? extends WebPage> linkClass = CommitPage.class; + String cssClass = ""; + String tooltip = ""; + if (name.startsWith(Constants.R_HEADS)) { + // local branch + linkClass = LogPage.class; + name = name.substring(Constants.R_HEADS.length()); + cssClass = "localBranch"; + } else if (name.equals(Constants.HEAD)) { + // local head + linkClass = LogPage.class; + cssClass = "headRef"; + } else if (name.startsWith(Constants.R_CHANGES)) { + // Gerrit change ref + name = name.substring(Constants.R_CHANGES.length()); + // strip leading nn/ from nn/#####nn/ps = #####nn-ps + name = name.substring(name.indexOf('/') + 1).replace('/', '-'); + String [] values = name.split("-"); + tooltip = MessageFormat.format(getString("gb.reviewPatchset"), values[0], values[1]); + cssClass = "otherRef"; + } else if (name.startsWith(Constants.R_PULL)) { + // Pull Request ref + name = "pull #" + name.substring(Constants.R_PULL.length()); + if (name.endsWith("/head")) { + // strip pull request head from name + name = name.substring(0, name.length() - "/head".length()); + } + cssClass = "pullRef"; + } else if (name.startsWith(Constants.R_REMOTES)) { + // remote branch + linkClass = LogPage.class; + name = name.substring(Constants.R_REMOTES.length()); + cssClass = "remoteBranch"; + if (!alreadyInsertedBreak) { + breakLine = true; + alreadyInsertedBreak = true; + } + } else if (name.startsWith(Constants.R_TAGS)) { + // tag + if (entry.isAnnotatedTag()) { + linkClass = TagPage.class; + objectid = entry.getObjectId().getName(); + } else { + linkClass = CommitPage.class; + objectid = entry.getReferencedObjectId().getName(); + } + name = name.substring(Constants.R_TAGS.length()); + cssClass = "tagRef"; + } else if (name.startsWith(Constants.R_NOTES)) { + // codereview refs + linkClass = CommitPage.class; + cssClass = "otherRef"; + } else if (name.startsWith(com.gitblit.Constants.R_GITBLIT)) { + // gitblit refs + linkClass = LogPage.class; + cssClass = "otherRef"; + name = name.substring(com.gitblit.Constants.R_GITBLIT.length()); + } + + Component c = new LinkPanel("refName", null, name, linkClass, + WicketUtils.newObjectParameter(repositoryName, objectid)); + WicketUtils.setCssClass(c, cssClass); + if (StringUtils.isEmpty(tooltip)) { + WicketUtils.setHtmlTooltip(c, name); + } else { + WicketUtils.setHtmlTooltip(c, tooltip); + } + item.add(c); + Label lb = new Label("lineBreak", "<br/>"); + lb.setVisible(breakLine); + lb.setRenderBodyOnly(true); + item.add(lb.setEscapeModelStrings(false)); + item.setRenderBodyOnly(true); + } + }; + add(refsView); + } +} \ No newline at end of file -- Gitblit v1.9.1