From 8427e93f25fb79bc39dbd31ce13fab637e7cfdff Mon Sep 17 00:00:00 2001
From: Jeroen Baten <jeroen@jeroenbaten.nl>
Date: Fri, 04 Jan 2013 11:34:24 -0500
Subject: [PATCH] Completed Dutch translation
---
groovy/sendmail-html.groovy | 232 +++++++++++++++++++++++++--------------------------------
1 files changed, 102 insertions(+), 130 deletions(-)
diff --git a/groovy/sendmail-html.groovy b/groovy/sendmail-html.groovy
index fb89a14..1692073 100644
--- a/groovy/sendmail-html.groovy
+++ b/groovy/sendmail-html.groovy
@@ -89,7 +89,7 @@
com.gitblit.models.UserModel userModel = user
// Indicate we have started the script
-logger.info("sendmail hook triggered by ${user.username} for ${repository.name}")
+logger.info("sendmail-html hook triggered by ${user.username} for ${repository.name}")
/*
* Primitive email notification.
@@ -115,7 +115,7 @@
}
// add all mailing lists defined in gitblit.properties or web.xml
-toAddresses.addAll(gitblit.getStrings(Keys.mail.mailingLists))
+toAddresses.addAll(GitBlit.getStrings(Keys.mail.mailingLists))
// add all team mailing lists
def teams = gitblit.getRepositoryTeams(repository)
@@ -135,9 +135,10 @@
def baseCommitUrl = url + "/commit?r=$repo&h="
def baseBlobDiffUrl = url + "/blobdiff/?r=$repo&h="
def baseCommitDiffUrl = url + "/commitdiff/?r=$repo&h="
+def forwardSlashChar = gitblit.getString(Keys.web.forwardSlashCharacter, '/')
if (gitblit.getBoolean(Keys.web.mountParameters, true)) {
- repo = repo.replace('/', gitblit.getString(Keys.web.forwardSlashCharacter, '/')).replace('/', '%2F')
+ repo = repo.replace('/', forwardSlashChar).replace('/', '%2F')
summaryUrl = url + "/summary/$repo"
baseCommitUrl = url + "/commit/$repo/"
baseBlobDiffUrl = url + "/blobdiff/$repo/"
@@ -151,6 +152,9 @@
def baseCommitDiffUrl
def baseBlobDiffUrl
def mountParameters
+ def forwardSlashChar
+ def includeGravatar
+ def shortCommitIdLength
def commitCount = 0
def commands
def writer = new StringWriter();
@@ -158,109 +162,58 @@
def writeStyle() {
builder.style(type:"text/css", '''
- th, td {
- padding: 2px;
+ .table td {
+ vertical-align: middle;
}
- thead {
- text-align: left;
- font-weight: bold;
- }
- thead tr {
- border-bottom: 1px dotted #000;
- }
- a {
- text-decoration: none;
- }
- .commits-table {
- border-collapse: collapse;
- font-family: sans-serif;
- width: 100%;
- }
- .label-commit {
- border-radius:4px;
- background-color: #3A87AD;
- padding: 2px 4px;
- color: white;
- vertical-align: baseline;
- font-weight: bold;
- font-family: monospace;
- }
- .label-add {
- border-radius:4px;
- background-color: green;
- padding: 2px 4px;
- color: white;
- vertical-align: baseline;
- font-weight: bold;
- font-family: monospace;
- }
- .label-delete {
- border-radius:4px;
- background-color: grey;
- padding: 2px 4px;
- color: white;
- vertical-align: baseline;
- font-weight: bold;
- font-family: monospace;
- }
- .label-rename {
- border-radius:4px;
- background-color: blue;
- padding: 2px 4px;
- color: white;
- vertical-align: baseline;
- font-weight: bold;
- font-family: monospace;
- }
- .label-modify {
- border-radius:4px;
- background-color: orange;
- padding: 2px 4px;
- color: white;
- vertical-align: baseline;
- font-weight: bold;
- font-family: monospace;
- }
- .label-copy {
- border-radius:4px;
- background-color: teal;
- padding: 2px 4px;
- color: white;
- vertical-align: baseline;
- font-weight: bold;
- font-family: monospace;
+ tr.noborder td {
+ border: none;
+ padding-top: 0px;
}
.gravatar-column {
width: 5%;
}
.author-column {
- width: 10%;
+ width: 20%;
}
.commit-column {
width: 5%;
}
.status-column {
width: 10%;
- padding-bottom: 5px;
- padding-top: 5px;
+ }
+ .table-disable-hover.table tbody tr:hover td,
+ .table-disable-hover.table tbody tr:hover th {
+ background-color: inherit;
+ }
+ .table-disable-hover.table-striped tbody tr:nth-child(odd):hover td,
+ .table-disable-hover.table-striped tbody tr:nth-child(odd):hover th {
+ background-color: #f9f9f9;
}
''')
}
def writeBranchTitle(type, name, action, number) {
- builder.h2 {
- mkp.yield "$type "
- span(style:"font-family: monospace;", name )
- mkp.yield " $action ($number commits)"
+ builder.div('class' : 'pageTitle') {
+ builder.span('class':'project') {
+ mkp.yield "$type "
+ span('class': 'repository', name )
+ if (number > 0) {
+ mkp.yield " $action ($number commits)"
+ } else {
+ mkp.yield " $action"
+ }
+ }
}
}
def writeBranchDeletedTitle(type, name) {
- builder.h2 {
- mkp.yield "$type "
- span(style:"font-family: monospace;", name )
- mkp.yield " deleted"
- }
+ builder.div('class' : 'pageTitle', 'style':'color:red') {
+ builder.span('class':'project') {
+ mkp.yield "$type "
+ span('class': 'repository', name )
+ mkp.yield " deleted"
+ }
+ }
}
def commitUrl(RevCommit commit) {
@@ -272,7 +225,7 @@
}
def encoded(String path) {
- path.replace('/', '!')
+ path.replace('/', forwardSlashChar).replace('/', '%2F')
}
def blobDiffUrl(objectId, path) {
@@ -285,12 +238,12 @@
}
- def writeCommitTable(commits) {
+ def writeCommitTable(commits, includeChangedPaths=true) {
// Write commits table
- builder.table('class':"commits-table") {
+ builder.table('class':"table table-disable-hover") {
thead {
tr {
- th(colspan:2, "Author")
+ th(colspan: includeGravatar ? 2 : 1, "Author")
th( "Commit" )
th( "Message" )
}
@@ -301,84 +254,90 @@
for (commit in commits) {
writeCommit(commit)
- // Write detail on that particular commit
- tr {
- td (colspan:3)
- td { writeStatusTable(commit) }
- }
+ if (includeChangedPaths) {
+ // Write detail on that particular commit
+ tr('class' : 'noborder') {
+ td (colspan: includeGravatar ? 3 : 2)
+ td (colspan:2) { writeStatusTable(commit) }
+ }
+ }
}
}
}
}
def writeCommit(commit) {
- def abbreviated = repository.newObjectReader().abbreviate(commit.id, 6).name()
+ def abbreviated = repository.newObjectReader().abbreviate(commit.id, shortCommitIdLength).name()
def author = commit.authorIdent.name
def email = commit.authorIdent.emailAddress
def message = commit.shortMessage
builder.tr {
- td('class':"gravatar-column") {
- img(src:gravatarUrl(email))
- }
- td('class':"author-column") { p(author) }
+ if (includeGravatar) {
+ td('class':"gravatar-column") {
+ img(src:gravatarUrl(email), 'class':"gravatar")
+ }
+ }
+ td('class':"author-column", author)
td('class':"commit-column") {
a(href:commitUrl(commit)) {
- span('class':"label-commit", abbreviated )
+ span('class':"label label-info", abbreviated )
}
}
td {
mkp.yield message
- a(href:commitDiffUrl(commit), " [commitdiff]" )
+ a('class':'link', href:commitDiffUrl(commit), " [commitdiff]" )
}
}
}
- def writeStatusLabel(style, label) {
- builder.span('class' : style, label )
+ def writeStatusLabel(style, tooltip) {
+ builder.span('class' : style, 'title' : tooltip )
}
- def writeAddStatusLine(ObjectId id, FileHeader header) {
- builder.td('class':"status-column") {
- a(href:blobDiffUrl(id, header.newPath)) { writeStatusLabel("label-add", "add") }
+ def writeAddStatusLine(ObjectId id, FileHeader header) {
+ builder.td('class':'changeType') {
+ writeStatusLabel("addition", "addition")
}
builder.td {
- span(style:'font-family: monospace;', header.newPath)
+ a(href:blobDiffUrl(id, header.newPath), header.newPath)
}
}
def writeCopyStatusLine(ObjectId id, FileHeader header) {
- builder.td('class':"status-column") {
- a(href:blobDiffUrl(id, header.newPath)) { writeStatusLabel("label-copy", "copy") }
+ builder.td('class':'changeType') {
+ writeStatusLabel("rename", "rename")
}
builder.td() {
- span(style : "font-family: monospace; ", header.oldPath + " copied to " + header.newPath)
+ a(href:blobDiffUrl(id, header.newPath), header.oldPath + " copied to " + header.newPath)
}
}
def writeDeleteStatusLine(ObjectId id, FileHeader header) {
- builder.td('class':"status-column") {
- a(href:blobDiffUrl(id, header.oldPath)) { writeStatusLabel("label-delete", "delete") }
+ builder.td('class':'changeType') {
+ writeStatusLabel("deletion", "deletion")
}
builder.td() {
- span(style : "font-family: monospace; ", header.oldPath)
+ a(href:blobDiffUrl(id, header.oldPath), header.oldPath)
}
}
def writeModifyStatusLine(ObjectId id, FileHeader header) {
- builder.td('class':"status-column") {
- a(href:blobDiffUrl(id, header.oldPath)) { writeStatusLabel("label-modify", "modify") }
+ builder.td('class':'changeType') {
+ writeStatusLabel("modification", "modification")
}
builder.td() {
- span(style : "font-family: monospace; ", header.oldPath)
+ a(href:blobDiffUrl(id, header.oldPath), header.oldPath)
}
}
def writeRenameStatusLine(ObjectId id, FileHeader header) {
- builder.td('class':"status-column") {
- a(href:blobDiffUrl(id, header.newPath)) { writeStatusLabel("label-rename", "rename") }
+ builder.td('class':'changeType') {
+ writeStatusLabel("rename", "rename")
}
builder.td() {
- span(style : "font-family: monospace; ", header.olPath + " -> " + header.newPath)
+ mkp.yield header.oldPath
+ mkp.yieldUnescaped "<b> -&rt; </b>"
+ a(href:blobDiffUrl(id, header.newPath), header.newPath)
}
}
@@ -411,16 +370,17 @@
formatter.setDiffComparator(RawTextComparator.DEFAULT);
def diffs
- RevWalk rw = new RevWalk(repository);
+ RevWalk rw = new RevWalk(repository)
if (commit.parentCount > 0) {
- RevCommit parent = commit.parents[0]
+ RevCommit parent = rw.parseCommit(commit.parents[0].id)
diffs = formatter.scan(parent.tree, commit.tree)
} else {
diffs = formatter.scan(new EmptyTreeIterator(),
new CanonicalTreeParser(null, rw.objectReader, commit.tree))
}
+ rw.dispose()
// Write status table
- builder.table('class':"commits-table") {
+ builder.table('class':"plain") {
tbody() {
for (DiffEntry entry in diffs) {
FileHeader header = formatter.toFileHeader(entry)
@@ -467,11 +427,14 @@
head {
link(rel:"stylesheet", href:"${url}/bootstrap/css/bootstrap.css")
link(rel:"stylesheet", href:"${url}/gitblit.css")
+ link(rel:"stylesheet", href:"${url}/bootstrap/css/bootstrap-responsive.css")
writeStyle()
}
body {
writeNavbar()
+
+ div('class':"container") {
for (command in commands) {
def ref = command.refName
@@ -485,12 +448,17 @@
switch (command.type) {
case ReceiveCommand.Type.CREATE:
- def commits = JGitUtils.getRevLog(repository, command.oldId.name, command.newId.name).reverse()
- commitCount += commits.size()
- // new branch
- // Write header
- writeBranchTitle(refType, ref, "created", commits.size())
- writeCommitTable(commits)
+ def commits = JGitUtils.getRevLog(repository, command.oldId.name, command.newId.name).reverse()
+ commitCount += commits.size()
+ if (refType == 'Branch') {
+ // new branch
+ writeBranchTitle(refType, ref, "created", commits.size())
+ writeCommitTable(commits, true)
+ } else {
+ // new tag
+ writeBranchTitle(refType, ref, "created", 0)
+ writeCommitTable(commits, false)
+ }
break
case ReceiveCommand.Type.UPDATE:
def commits = JGitUtils.getRevLog(repository, command.oldId.name, command.newId.name).reverse()
@@ -516,6 +484,7 @@
break
}
}
+ }
}
}
writer.toString()
@@ -528,9 +497,12 @@
mailWriter.baseCommitUrl = baseCommitUrl
mailWriter.baseBlobDiffUrl = baseBlobDiffUrl
mailWriter.baseCommitDiffUrl = baseCommitDiffUrl
+mailWriter.forwardSlashChar = forwardSlashChar
mailWriter.commands = commands
mailWriter.url = url
-mailWriter.mountParameters = gitblit.getBoolean(Keys.web.mountParameters, true)
+mailWriter.mountParameters = GitBlit.getBoolean(Keys.web.mountParameters, true)
+mailWriter.includeGravatar = GitBlit.getBoolean(Keys.web.allowGravatar, true)
+mailWriter.shortCommitIdLength = GitBlit.getInteger(Keys.web.shortCommitIdLength, 8)
def content = mailWriter.write()
@@ -539,6 +511,6 @@
// tell Gitblit to send the message (Gitblit filters duplicate addresses)
def repositoryName = repository.name.substring(0, repository.name.length() - 4)
-gitblit.sendHtmlMail("${emailprefix}[$repositoryName] ${userModel.displayName} pushed ${mailWriter.commitCount} commits",
+gitblit.sendHtmlMail("${emailprefix} ${userModel.displayName} pushed ${mailWriter.commitCount} commits => $repositoryName",
content,
toAddresses)
--
Gitblit v1.9.1