diff options
author | Ethan Koenig <etk39@cornell.edu> | 2016-12-24 05:33:21 -0500 |
---|---|---|
committer | Lunny Xiao <xiaolunwen@gmail.com> | 2016-12-24 18:33:21 +0800 |
commit | d0932ef1473b9ce27474ccf24acfca106dd93fec (patch) | |
tree | 3dd05ef666f43ad9e32e6305793b18c3cbfbd0ca /routers/repo | |
parent | 8a4161c72335900407b8f111027ad9ed53c0b631 (diff) | |
download | gitea-d0932ef1473b9ce27474ccf24acfca106dd93fec.tar.gz gitea-d0932ef1473b9ce27474ccf24acfca106dd93fec.zip |
Bug fixes for Issues filters (#413)
Correctly handle simultaneous assignee/poster filters, and conflicting assignee filters
Diffstat (limited to 'routers/repo')
-rw-r--r-- | routers/repo/issue.go | 84 |
1 files changed, 47 insertions, 37 deletions
diff --git a/routers/repo/issue.go b/routers/repo/issue.go index 343b93e273..14c1ea1aa7 100644 --- a/routers/repo/issue.go +++ b/routers/repo/issue.go @@ -130,38 +130,42 @@ func Issues(ctx *context.Context) { var ( assigneeID = ctx.QueryInt64("assignee") - posterID int64 + posterID int64 + mentionedID int64 + forceEmpty bool ) - filterMode := models.FilterModeAll switch viewType { case "assigned": - filterMode = models.FilterModeAssign - assigneeID = ctx.User.ID + if assigneeID > 0 && ctx.User.ID != assigneeID { + // two different assignees, must be empty + forceEmpty = true + } else { + assigneeID = ctx.User.ID + } case "created_by": - filterMode = models.FilterModeCreate posterID = ctx.User.ID case "mentioned": - filterMode = models.FilterModeMention - } - - var uid int64 = -1 - if ctx.IsSigned { - uid = ctx.User.ID + mentionedID = ctx.User.ID } repo := ctx.Repo.Repository selectLabels := ctx.Query("labels") milestoneID := ctx.QueryInt64("milestone") isShowClosed := ctx.Query("state") == "closed" - issueStats := models.GetIssueStats(&models.IssueStatsOptions{ - RepoID: repo.ID, - UserID: uid, - Labels: selectLabels, - MilestoneID: milestoneID, - AssigneeID: assigneeID, - FilterMode: filterMode, - IsPull: isPullList, - }) + + var issueStats *models.IssueStats + if forceEmpty { + issueStats = &models.IssueStats{} + } else { + issueStats = models.GetIssueStats(&models.IssueStatsOptions{ + RepoID: repo.ID, + Labels: selectLabels, + MilestoneID: milestoneID, + AssigneeID: assigneeID, + MentionedID: mentionedID, + IsPull: isPullList, + }) + } page := ctx.QueryInt("page") if page <= 1 { @@ -177,22 +181,28 @@ func Issues(ctx *context.Context) { pager := paginater.New(total, setting.UI.IssuePagingNum, page, 5) ctx.Data["Page"] = pager - issues, err := models.Issues(&models.IssuesOptions{ - UserID: uid, - AssigneeID: assigneeID, - RepoID: repo.ID, - PosterID: posterID, - MilestoneID: milestoneID, - Page: pager.Current(), - IsClosed: isShowClosed, - IsMention: filterMode == models.FilterModeMention, - IsPull: isPullList, - Labels: selectLabels, - SortType: sortType, - }) - if err != nil { - ctx.Handle(500, "Issues", err) - return + + var issues []*models.Issue + if forceEmpty { + issues = []*models.Issue{} + } else { + var err error + issues, err = models.Issues(&models.IssuesOptions{ + AssigneeID: assigneeID, + RepoID: repo.ID, + PosterID: posterID, + MentionedID: mentionedID, + MilestoneID: milestoneID, + Page: pager.Current(), + IsClosed: isShowClosed, + IsPull: isPullList, + Labels: selectLabels, + SortType: sortType, + }) + if err != nil { + ctx.Handle(500, "Issues", err) + return + } } // Get issue-user relations. @@ -233,7 +243,7 @@ func Issues(ctx *context.Context) { return } - if viewType == "assigned" { + if ctx.QueryInt64("assignee") == 0 { assigneeID = 0 // Reset ID to prevent unexpected selection of assignee. } |