From c3f4f124f1b9e45d7696f3c16f958d1c81ff280a Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Thu, 21 Apr 2011 21:46:47 -0400 Subject: [PATCH] Use markdown for welcome message. Simplify login page appearance. --- src/com/gitblit/wicket/WicketUtils.java | 181 +++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 165 insertions(+), 16 deletions(-) diff --git a/src/com/gitblit/wicket/WicketUtils.java b/src/com/gitblit/wicket/WicketUtils.java index 1d85a80..c8d605b 100644 --- a/src/com/gitblit/wicket/WicketUtils.java +++ b/src/com/gitblit/wicket/WicketUtils.java @@ -1,35 +1,184 @@ package com.gitblit.wicket; -import org.apache.wicket.AttributeModifier; +import java.text.DateFormat; +import java.text.SimpleDateFormat; +import java.util.Date; +import java.util.TimeZone; + import org.apache.wicket.Component; -import org.apache.wicket.model.AbstractReadOnlyModel; +import org.apache.wicket.PageParameters; +import org.apache.wicket.behavior.SimpleAttributeModifier; +import org.apache.wicket.markup.html.basic.Label; +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 { public static void setCssClass(Component container, String value) { - container.add(newAttributeModifier("class", value)); + container.add(new SimpleAttributeModifier("class", value)); } public static void setCssStyle(Component container, String value) { - container.add(newAttributeModifier("style", value)); + container.add(new SimpleAttributeModifier("style", value)); } public static void setHtmlTitle(Component container, String value) { - container.add(newAttributeModifier("title", value)); + container.add(new SimpleAttributeModifier("title", value)); } - private static AttributeModifier newAttributeModifier(String attrib, final String value) { - return new AttributeModifier(attrib, true, new AbstractReadOnlyModel<String>() { - private static final long serialVersionUID = 1L; - - @Override - public String getObject() { - return 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 String breakLines(String string) { - return string.replace("\r", "<br/>").replace("\n", "<br/>"); + public static void setTicketCssClass(Component container, String state) { + String css = null; + if (state.equals("open")) { + css = "bug_open"; + } else if (state.equals("hold")) { + css = "bug_hold"; + } else if (state.equals("resolved")) { + css = "bug_resolved"; + } else if (state.equals("invalid")) { + css = "bug_invalid"; + } + if (css != null) { + setCssClass(container, css); + } + } + + public static void setAlternatingBackground(Component c, int i) { + String clazz = i % 2 == 0 ? "dark" : "light"; + setCssClass(c, clazz); + } + + public static Label createAuthorLabel(String wicketId, String author) { + Label label = new Label(wicketId, author); + WicketUtils.setHtmlTitle(label, author); + return label; + } + + public static PageParameters newRepositoryParameter(String repositoryName) { + return new PageParameters("r=" + repositoryName); + } + + public static PageParameters newObjectParameter(String repositoryName, String objectId) { + 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 (StringUtils.isEmpty(path)) { + return newObjectParameter(repositoryName, objectId); + } + return new PageParameters("r=" + repositoryName + ",h=" + objectId + ",f=" + path); + } + + public static PageParameters newLogPageParameter(String repositoryName, String objectId, int pageNumber) { + if (pageNumber <= 1) { + 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) { + return params.getString("r", ""); + } + + public static String getObject(PageParameters params) { + return params.getString("h", Constants.HEAD); + } + + 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 Label createDateLabel(String wicketId, Date date, TimeZone timeZone) { + DateFormat df = new SimpleDateFormat(GitBlit.self().settings().getString(Keys.web.datestampShortFormat, "MM/dd/yy")); + if (timeZone != null) { + df.setTimeZone(timeZone); + } + String dateString = df.format(date); + String title = TimeUtils.timeAgo(date); + if ((System.currentTimeMillis() - date.getTime()) < 10 * 24 * 60 * 60 * 1000l) { + String tmp = dateString; + dateString = title; + title = tmp; + } + Label label = new Label(wicketId, dateString); + WicketUtils.setCssClass(label, TimeUtils.timeAgoCss(date)); + WicketUtils.setHtmlTitle(label, title); + return label; + } + + public static Label createTimestampLabel(String wicketId, Date date, TimeZone timeZone) { + DateFormat df = new SimpleDateFormat(GitBlit.self().settings().getString(Keys.web.datetimestampLongFormat, "EEEE, MMMM d, yyyy h:mm a z")); + if (timeZone != null) { + df.setTimeZone(timeZone); + } + String dateString = df.format(date); + String title = TimeUtils.timeAgo(date); + Label label = new Label(wicketId, dateString); + WicketUtils.setHtmlTitle(label, title); + return label; } } -- Gitblit v1.9.1