From f90dc635928f367f9078f814488c7e385ebc4e2e Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Fri, 20 May 2011 17:31:07 -0400 Subject: [PATCH] Documentation. --- src/com/gitblit/wicket/WicketUtils.java | 132 +++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 125 insertions(+), 7 deletions(-) diff --git a/src/com/gitblit/wicket/WicketUtils.java b/src/com/gitblit/wicket/WicketUtils.java index 0a1c3a0..f0ccbf4 100644 --- a/src/com/gitblit/wicket/WicketUtils.java +++ b/src/com/gitblit/wicket/WicketUtils.java @@ -3,16 +3,21 @@ 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; @@ -26,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) { @@ -53,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) { @@ -81,7 +177,7 @@ } 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); @@ -93,7 +189,17 @@ 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) { return params.getString("r", ""); } @@ -105,13 +211,25 @@ public static String getPath(PageParameters params) { 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) { @@ -128,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; } @@ -140,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; } } -- Gitblit v1.9.1