James Moger
2011-05-19 9da97003c7f33a64ae5060f413f9c4c5d26efe78
src/com/gitblit/wicket/WicketUtils.java
@@ -3,16 +3,22 @@
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.TimeZone;
import org.apache.wicket.Component;
import org.apache.wicket.PageParameters;
import org.apache.wicket.behavior.SimpleAttributeModifier;
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.html.image.ContextImage;
import org.apache.wicket.resource.ContextRelativeResource;
import org.eclipse.jgit.diff.DiffEntry.ChangeType;
import org.eclipse.jgit.lib.Constants;
import com.gitblit.GitBlit;
import com.gitblit.Keys;
import com.gitblit.utils.JGitUtils.SearchType;
import com.gitblit.utils.StringUtils;
import com.gitblit.utils.TimeUtils;
public class WicketUtils {
@@ -25,8 +31,30 @@
      container.add(new SimpleAttributeModifier("style", value));
   }
   public static void setHtmlTitle(Component container, String value) {
   public static void setHtmlTooltip(Component container, String value) {
      container.add(new SimpleAttributeModifier("title", value));
   }
   public static void setInputPlaceholder(Component container, String value) {
      container.add(new SimpleAttributeModifier("placeholder", value));
   }
   public static void setChangeTypeCssClass(Component container, ChangeType type) {
      switch (type) {
      case ADD:
         setCssClass(container, "addition");
         break;
      case COPY:
      case RENAME:
         setCssClass(container, "rename");
         break;
      case DELETE:
         setCssClass(container, "deletion");
         break;
      case MODIFY:
         setCssClass(container, "modification");
         break;
      }
   }
   public static void setTicketCssClass(Component container, String state) {
@@ -52,8 +80,77 @@
   public static Label createAuthorLabel(String wicketId, String author) {
      Label label = new Label(wicketId, author);
      WicketUtils.setHtmlTitle(label, author);
      WicketUtils.setHtmlTooltip(label, author);
      return label;
   }
   public static ContextImage getFileImage(String wicketId, String filename) {
      filename = filename.toLowerCase();
      if (filename.endsWith(".java")) {
         return newImage(wicketId, "file_java_16x16.png");
      } else if (filename.endsWith(".rb")) {
         return newImage(wicketId, "file_ruby_16x16.png");
      } else if (filename.endsWith(".php")) {
         return newImage(wicketId, "file_php_16x16.png");
      } else if (filename.endsWith(".cs")) {
         return newImage(wicketId, "file_cs_16x16.png");
      } else if (filename.endsWith(".cpp")) {
         return newImage(wicketId, "file_cpp_16x16.png");
      } else if (filename.endsWith(".c")) {
         return newImage(wicketId, "file_c_16x16.png");
      } else if (filename.endsWith(".h")) {
         return newImage(wicketId, "file_h_16x16.png");
      } else if (filename.endsWith(".sln")) {
         return newImage(wicketId, "file_vs_16x16.png");
      } else if (filename.endsWith(".csv") || filename.endsWith(".xls") || filename.endsWith(".xlsx")) {
         return newImage(wicketId, "file_excel_16x16.png");
      } else if (filename.endsWith(".doc") || filename.endsWith(".docx")) {
         return newImage(wicketId, "file_word_16x16.png");
      } else if (filename.endsWith(".ppt")) {
         return newImage(wicketId, "file_ppt_16x16.png");
      } else if (filename.endsWith(".zip")) {
         return newImage(wicketId, "file_zip_16x16.png");
      } else if (filename.endsWith(".pdf")) {
         return newImage(wicketId, "file_acrobat_16x16.png");
      } else if (filename.endsWith(".htm") || filename.endsWith(".html")) {
         return newImage(wicketId, "file_world_16x16.png");
      } else if (filename.endsWith(".xml")) {
         return newImage(wicketId, "file_code_16x16.png");
      } else if (filename.endsWith(".properties")) {
         return newImage(wicketId, "file_settings_16x16.png");
      }
      List<String> mdExtensions = GitBlit.self().settings().getStrings(Keys.web.markdownExtensions);
      for (String ext : mdExtensions) {
         if (filename.endsWith('.' + ext.toLowerCase())) {
            return newImage(wicketId, "file_world_16x16.png");
         }
      }
      return newImage(wicketId, "file_16x16.png");
   }
   public static ContextImage newClearPixel(String wicketId) {
      return newImage(wicketId, "pixel.png");
   }
   public static ContextImage newBlankImage(String wicketId) {
      return newImage(wicketId, "blank.png");
   }
   public static ContextImage newImage(String wicketId, String file) {
      return newImage(wicketId, file, null);
   }
   public static ContextImage newImage(String wicketId, String file, String tooltip) {
      ContextImage img = new ContextImage(wicketId, "/com/gitblit/wicket/resources/" + file);
      if (!StringUtils.isEmpty(tooltip)) {
         setHtmlTooltip(img, tooltip);
      }
      return img;
   }
   public static ContextRelativeResource getResource(String file) {
      return new ContextRelativeResource("/com/gitblit/wicket/resources/" + file);
   }
   public static PageParameters newRepositoryParameter(String repositoryName) {
@@ -61,14 +158,14 @@
   }
   public static PageParameters newObjectParameter(String repositoryName, String objectId) {
      if (objectId == null || objectId.trim().length() == 0) {
      if (StringUtils.isEmpty(objectId)) {
         return newRepositoryParameter(repositoryName);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + objectId);
   }
   public static PageParameters newPathParameter(String repositoryName, String objectId, String path) {
      if (path == null || path.trim().length() == 0) {
      if (StringUtils.isEmpty(path)) {
         return newObjectParameter(repositoryName, objectId);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + objectId + ",f=" + path);
@@ -79,6 +176,28 @@
         return newObjectParameter(repositoryName, objectId);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + objectId + ",page=" + pageNumber);
   }
   public static PageParameters newHistoryPageParameter(String repositoryName, String objectId, String path, int pageNumber) {
      if (pageNumber <= 1) {
         return newObjectParameter(repositoryName, objectId);
      }
      return new PageParameters("r=" + repositoryName + ",h=" + objectId + ",f=" + path + ",page=" + pageNumber);
   }
   public static PageParameters newBlobDiffParameter(String repositoryName, String baseCommitId, String commitId, String path) {
      return new PageParameters("r=" + repositoryName + ",h=" + commitId + ",f=" + path + ",hb=" + baseCommitId);
   }
   public static PageParameters newSearchParameter(String repositoryName, String commitId, String search, SearchType type) {
      if (StringUtils.isEmpty(commitId)) {
         return new PageParameters("r=" + repositoryName + ",s=" + search + ",st=" + type.name());
      }
      return new PageParameters("r=" + repositoryName + ",h=" + commitId + ",s=" + search + ",st=" + type.name());
   }
   public static PageParameters newSearchParameter(String repositoryName, String commitId, String search, SearchType type, int pageNumber) {
      return new PageParameters("r=" + repositoryName + ",h=" + commitId + ",s=" + search + ",st=" + type.name() + ",page=" + pageNumber);
   }
   public static String getRepositoryName(PageParameters params) {
@@ -93,8 +212,24 @@
      return params.getString("f", null);
   }
   public static String getBaseObjectId(PageParameters params) {
      return params.getString("hb", null);
   }
   public static String getSearchString(PageParameters params) {
      return params.getString("s", null);
   }
   public static String getSearchType(PageParameters params) {
      return params.getString("st", null);
   }
   public static int getPage(PageParameters params) {
      return params.getInt("page", 1); // index from 1
   }
   public static String getUsername(PageParameters params) {
      return params.getString("user", "");
   }
   public static Label createDateLabel(String wicketId, Date date, TimeZone timeZone) {
@@ -111,7 +246,7 @@
      }
      Label label = new Label(wicketId, dateString);
      WicketUtils.setCssClass(label, TimeUtils.timeAgoCss(date));
      WicketUtils.setHtmlTitle(label, title);
      WicketUtils.setHtmlTooltip(label, title);
      return label;
   }
@@ -123,7 +258,7 @@
      String dateString = df.format(date);
      String title = TimeUtils.timeAgo(date);
      Label label = new Label(wicketId, dateString);
      WicketUtils.setHtmlTitle(label, title);
      WicketUtils.setHtmlTooltip(label, title);
      return label;
   }
}