Эх сурвалжийг харах

finish all new template for current ones

Unknwon 9 жил өмнө
parent
commit
562e47f31c

+ 1 - 1
README.md

@@ -5,7 +5,7 @@ Gogs - Go Git Service [![Build Status](https://travis-ci.org/gogits/gogs.svg?bra
 
 ![](public/img/gogs-large-resize.png)
 
-##### Current version: 0.6.12 Beta
+##### Current version: 0.6.13 Beta
 
 <table>
     <tr>

+ 1 - 1
gogs.go

@@ -17,7 +17,7 @@ import (
 	"github.com/gogits/gogs/modules/setting"
 )
 
-const APP_VER = "0.6.12.0916 Beta"
+const APP_VER = "0.6.13.0917 Beta"
 
 func init() {
 	runtime.GOMAXPROCS(runtime.NumCPU())

+ 35 - 36
modules/mailer/mail.go

@@ -5,7 +5,6 @@
 package mailer
 
 import (
-	"errors"
 	"fmt"
 	"path"
 
@@ -34,27 +33,37 @@ func ComposeTplData(u *models.User) map[interface{}]interface{} {
 	data["AppUrl"] = setting.AppUrl
 	data["ActiveCodeLives"] = setting.Service.ActiveCodeLives / 60
 	data["ResetPwdCodeLives"] = setting.Service.ResetPwdCodeLives / 60
+
 	if u != nil {
 		data["User"] = u
 	}
 	return data
 }
 
-func SendActivateAccountMail(c *macaron.Context, u *models.User) {
+func SendUserMail(c *macaron.Context, u *models.User, tpl base.TplName, code, subject, info string) {
 	data := ComposeTplData(u)
-	data["Code"] = u.GenerateActivateCode()
-	body, err := c.HTMLString(string(AUTH_ACTIVATE), data)
+	data["Code"] = code
+	body, err := c.HTMLString(string(tpl), data)
 	if err != nil {
 		log.Error(4, "HTMLString: %v", err)
 		return
 	}
 
-	msg := NewMessage([]string{u.Email}, c.Tr("mail.activate_account"), body)
-	msg.Info = fmt.Sprintf("UID: %d, activate account", u.Id)
+	msg := NewMessage([]string{u.Email}, subject, body)
+	msg.Info = fmt.Sprintf("UID: %d, %s", u.Id, info)
 
 	SendAsync(msg)
 }
 
+func SendActivateAccountMail(c *macaron.Context, u *models.User) {
+	SendUserMail(c, u, AUTH_ACTIVATE, u.GenerateActivateCode(), c.Tr("mail.activate_account"), "activate account")
+}
+
+// SendResetPasswordMail sends reset password e-mail.
+func SendResetPasswordMail(c *macaron.Context, u *models.User) {
+	SendUserMail(c, u, AUTH_RESET_PASSWORD, u.GenerateActivateCode(), c.Tr("mail.reset_password"), "reset password")
+}
+
 // SendActivateAccountMail sends confirmation e-mail.
 func SendActivateEmailMail(c *macaron.Context, u *models.User, email *models.EmailAddress) {
 	data := ComposeTplData(u)
@@ -72,27 +81,11 @@ func SendActivateEmailMail(c *macaron.Context, u *models.User, email *models.Ema
 	SendAsync(msg)
 }
 
-// SendResetPasswordMail sends reset password e-mail.
-func SendResetPasswordMail(c *macaron.Context, u *models.User) {
-	data := ComposeTplData(u)
-	data["Code"] = u.GenerateActivateCode()
-	body, err := c.HTMLString(string(AUTH_RESET_PASSWORD), data)
-	if err != nil {
-		log.Error(4, "HTMLString: %v", err)
-		return
-	}
-
-	msg := NewMessage([]string{u.Email}, c.Tr("mail.reset_password"), body)
-	msg.Info = fmt.Sprintf("UID: %d, reset password", u.Id)
-
-	SendAsync(msg)
-}
-
 // SendIssueNotifyMail sends mail notification of all watchers of repository.
 func SendIssueNotifyMail(u, owner *models.User, repo *models.Repository, issue *models.Issue) ([]string, error) {
 	ws, err := models.GetWatchers(repo.ID)
 	if err != nil {
-		return nil, errors.New("mail.NotifyWatchers(GetWatchers): " + err.Error())
+		return nil, fmt.Errorf("GetWatchers[%d]: %v", repo.ID, err)
 	}
 
 	tos := make([]string, 0, len(ws))
@@ -101,11 +94,15 @@ func SendIssueNotifyMail(u, owner *models.User, repo *models.Repository, issue *
 		if u.Id == uid {
 			continue
 		}
-		u, err := models.GetUserByID(uid)
+		to, err := models.GetUserByID(uid)
 		if err != nil {
-			return nil, errors.New("mail.NotifyWatchers(GetUserById): " + err.Error())
+			return nil, fmt.Errorf("GetUserByID: %v", err)
+		}
+		if to.IsOrganization() {
+			continue
 		}
-		tos = append(tos, u.Email)
+
+		tos = append(tos, to.Email)
 	}
 
 	if len(tos) == 0 {
@@ -117,7 +114,8 @@ func SendIssueNotifyMail(u, owner *models.User, repo *models.Repository, issue *
 		base.RenderSpecialLink([]byte(issue.Content), owner.Name+"/"+repo.Name),
 		setting.AppUrl, owner.Name, repo.Name, issue.Index)
 	msg := NewMessage(tos, subject, content)
-	msg.Info = fmt.Sprintf("Subject: %s, send issue notify emails", subject)
+	msg.Info = fmt.Sprintf("Subject: %s, issue notify", subject)
+
 	SendAsync(msg)
 	return tos, nil
 }
@@ -135,35 +133,36 @@ func SendIssueMentionMail(r macaron.Render, u, owner *models.User,
 	data := ComposeTplData(nil)
 	data["IssueLink"] = fmt.Sprintf("%s/%s/issues/%d", owner.Name, repo.Name, issue.Index)
 	data["Subject"] = subject
+	data["ActUserName"] = u.DisplayName()
+	data["Content"] = string(base.RenderSpecialLink([]byte(issue.Content), owner.Name+"/"+repo.Name))
 
 	body, err := r.HTMLString(string(NOTIFY_MENTION), data)
 	if err != nil {
-		return fmt.Errorf("mail.SendIssueMentionMail(fail to render): %v", err)
+		return fmt.Errorf("HTMLString: %v", err)
 	}
 
 	msg := NewMessage(tos, subject, body)
-	msg.Info = fmt.Sprintf("Subject: %s, send issue mention emails", subject)
+	msg.Info = fmt.Sprintf("Subject: %s, issue mention", subject)
+
 	SendAsync(msg)
 	return nil
 }
 
 // SendCollaboratorMail sends mail notification to new collaborator.
-func SendCollaboratorMail(r macaron.Render, u, owner *models.User,
-	repo *models.Repository) error {
-
-	subject := fmt.Sprintf("%s added you to %s", owner.Name, repo.Name)
+func SendCollaboratorMail(r macaron.Render, u, doer *models.User, repo *models.Repository) error {
+	subject := fmt.Sprintf("%s added you to %s/%s", doer.Name, repo.Owner.Name, repo.Name)
 
 	data := ComposeTplData(nil)
-	data["RepoLink"] = path.Join(owner.Name, repo.Name)
+	data["RepoLink"] = path.Join(repo.Owner.Name, repo.Name)
 	data["Subject"] = subject
 
 	body, err := r.HTMLString(string(NOTIFY_COLLABORATOR), data)
 	if err != nil {
-		return fmt.Errorf("mail.SendCollaboratorMail(fail to render): %v", err)
+		return fmt.Errorf("HTMLString: %v", err)
 	}
 
 	msg := NewMessage([]string{u.Email}, subject, body)
-	msg.Info = fmt.Sprintf("UID: %d, send register mail", u.Id)
+	msg.Info = fmt.Sprintf("UID: %d, add collaborator", u.Id)
 
 	SendAsync(msg)
 	return nil

+ 1 - 1
routers/repo/issue.go

@@ -367,7 +367,7 @@ func NewIssuePost(ctx *middleware.Context, form auth.CreateIssueForm) {
 	mentions := base.MentionPattern.FindAllString(issue.Content, -1)
 	if len(mentions) > 0 {
 		for i := range mentions {
-			mentions[i] = mentions[i][1:]
+			mentions[i] = strings.TrimSpace(mentions[i])[1:]
 		}
 
 		if err := models.UpdateMentions(mentions, issue.ID); err != nil {

+ 1 - 1
templates/.VERSION

@@ -1 +1 @@
-0.6.12.0916 Beta
+0.6.13.0917 Beta

+ 8 - 10
templates/mail/notify/collaborator.tmpl

@@ -1,18 +1,16 @@
 <!DOCTYPE html>
 <html>
 <head>
-    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
-    <title>{{.Subject}}</title>
+  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+  <title>{{.Subject}}</title>
 </head>
 
 <body>
-    <p>You can now push to this repository.</p>
-    <p>
-        ---
-        <br>
-        View it on Gogs:
-        <br>
-        <a href="{{.AppUrl}}{{.RepoLink}}">{{.AppUrl}}{{.RepoLink}}</a>
-    </p>
+  <p>You are now a collaborator of this repository.</p>
+  <p>
+    ---
+    <br>
+    View it on Gogs: <a href="{{.AppUrl}}{{.RepoLink}}">{{.RepoLink}}</a>
+  </p>
 </body>
 </html>

+ 9 - 8
templates/mail/notify/mention.tmpl

@@ -1,16 +1,17 @@
 <!DOCTYPE html>
 <html>
 <head>
-    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
-    <title>{{.Subject}}</title>
+  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+  <title>{{.Subject}}</title>
 </head>
 
 <body>
-    <p>{{.ActUserName}} mentioned you.</p>
-    <p>
-        ---
-        <br>
-        <a href="{{.AppUrl}}{{.IssueLink}}">View it on Gogs</a>.
-    </p>
+  <p>@{{.ActUserName}} mentioned you:</p>
+  <p>{{.Content | Str2html}}</p>
+  <p>
+    ---
+    <br>
+    <a href="{{.AppUrl}}{{.IssueLink}}">View it on Gogs</a>.
+  </p>
 </body>
 </html>