|
|
@ -113,8 +113,34 @@ func ViewIssue(ctx *middleware.Context, params martini.Params) { |
|
|
|
return |
|
|
|
return |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Get posters.
|
|
|
|
|
|
|
|
u, err := models.GetUserById(issue.PosterId) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
ctx.Handle(200, "issue.ViewIssue(get poster): %v", err) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
issue.Poster = u |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Get comments.
|
|
|
|
|
|
|
|
comments, err := models.GetIssueComments(issue.Id) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
ctx.Handle(200, "issue.ViewIssue(get comments): %v", err) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Get posters.
|
|
|
|
|
|
|
|
for i := range comments { |
|
|
|
|
|
|
|
u, err := models.GetUserById(comments[i].PosterId) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
ctx.Handle(200, "issue.ViewIssue(get poster): %v", err) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
comments[i].Poster = u |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
ctx.Data["Title"] = issue.Name |
|
|
|
ctx.Data["Title"] = issue.Name |
|
|
|
ctx.Data["Issue"] = issue |
|
|
|
ctx.Data["Issue"] = issue |
|
|
|
|
|
|
|
ctx.Data["Comments"] = comments |
|
|
|
ctx.Data["IsRepoToolbarIssues"] = true |
|
|
|
ctx.Data["IsRepoToolbarIssues"] = true |
|
|
|
ctx.Data["IsRepoToolbarIssuesList"] = false |
|
|
|
ctx.Data["IsRepoToolbarIssuesList"] = false |
|
|
|
ctx.HTML(200, "issue/view") |
|
|
|
ctx.HTML(200, "issue/view") |
|
|
@ -132,7 +158,7 @@ func UpdateIssue(ctx *middleware.Context, params martini.Params, form auth.Creat |
|
|
|
if err == models.ErrIssueNotExist { |
|
|
|
if err == models.ErrIssueNotExist { |
|
|
|
ctx.Handle(404, "issue.UpdateIssue", err) |
|
|
|
ctx.Handle(404, "issue.UpdateIssue", err) |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
ctx.Handle(200, "issue.UpdateIssue", err) |
|
|
|
ctx.Handle(200, "issue.UpdateIssue(get issue)", err) |
|
|
|
} |
|
|
|
} |
|
|
|
return |
|
|
|
return |
|
|
|
} |
|
|
|
} |
|
|
@ -148,10 +174,48 @@ func UpdateIssue(ctx *middleware.Context, params martini.Params, form auth.Creat |
|
|
|
issue.Labels = form.Labels |
|
|
|
issue.Labels = form.Labels |
|
|
|
issue.Content = form.Content |
|
|
|
issue.Content = form.Content |
|
|
|
if err = models.UpdateIssue(issue); err != nil { |
|
|
|
if err = models.UpdateIssue(issue); err != nil { |
|
|
|
ctx.Handle(200, "issue.UpdateIssue", err) |
|
|
|
ctx.Handle(200, "issue.UpdateIssue(update issue)", err) |
|
|
|
return |
|
|
|
return |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
ctx.Data["Title"] = issue.Name |
|
|
|
ctx.Data["Title"] = issue.Name |
|
|
|
ctx.Data["Issue"] = issue |
|
|
|
ctx.Data["Issue"] = issue |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func Comment(ctx *middleware.Context, params martini.Params) { |
|
|
|
|
|
|
|
index, err := base.StrTo(ctx.Query("issueIndex")).Int() |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
ctx.Handle(404, "issue.Comment", err) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
issue, err := models.GetIssueByIndex(ctx.Repo.Repository.Id, int64(index)) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
if err == models.ErrIssueNotExist { |
|
|
|
|
|
|
|
ctx.Handle(404, "issue.Comment", err) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
ctx.Handle(200, "issue.Comment(get issue)", err) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
content := ctx.Query("content") |
|
|
|
|
|
|
|
if len(content) == 0 { |
|
|
|
|
|
|
|
ctx.Handle(404, "issue.Comment", err) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
switch params["action"] { |
|
|
|
|
|
|
|
case "new": |
|
|
|
|
|
|
|
if err = models.CreateComment(ctx.User.Id, issue.Id, 0, 0, content); err != nil { |
|
|
|
|
|
|
|
ctx.Handle(500, "issue.Comment(create comment)", err) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
log.Trace("%s Comment created: %d", ctx.Req.RequestURI, issue.Id) |
|
|
|
|
|
|
|
default: |
|
|
|
|
|
|
|
ctx.Handle(404, "issue.Comment", err) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ctx.Redirect(fmt.Sprintf("/%s/%s/issues/%d", ctx.User.Name, ctx.Repo.Repository.Name, index)) |
|
|
|
|
|
|
|
} |
|
|
|