mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-25 03:57:13 +08:00 
			
		
		
		
	Add pages to view watched repos and subscribed issues/PRs (#17156)
Adds GitHub-like pages to view watched repos and subscribed issues/PRs This is my second try to fix this, but it is better than the first since it doesn't uses a filter option which could be slow when accessing `/issues` or `/pulls` and it shows both pulls and issues (the first try is #17053). Closes #16111 Replaces and closes #17053  Co-authored-by: Lauris BH <lauris@nix.lv> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @ -1186,6 +1186,7 @@ type IssuesOptions struct { //nolint | ||||
| 	PosterID           int64 | ||||
| 	MentionedID        int64 | ||||
| 	ReviewRequestedID  int64 | ||||
| 	SubscriberID       int64 | ||||
| 	MilestoneIDs       []int64 | ||||
| 	ProjectID          int64 | ||||
| 	ProjectBoardID     int64 | ||||
| @ -1299,6 +1300,10 @@ func (opts *IssuesOptions) setupSessionNoLimit(sess *xorm.Session) { | ||||
| 		applyReviewRequestedCondition(sess, opts.ReviewRequestedID) | ||||
| 	} | ||||
|  | ||||
| 	if opts.SubscriberID > 0 { | ||||
| 		applySubscribedCondition(sess, opts.SubscriberID) | ||||
| 	} | ||||
|  | ||||
| 	if len(opts.MilestoneIDs) > 0 { | ||||
| 		sess.In("issue.milestone_id", opts.MilestoneIDs) | ||||
| 	} | ||||
| @ -1463,6 +1468,36 @@ func applyReviewRequestedCondition(sess *xorm.Session, reviewRequestedID int64) | ||||
| 			reviewRequestedID, ReviewTypeApprove, ReviewTypeReject, ReviewTypeRequest, reviewRequestedID) | ||||
| } | ||||
|  | ||||
| func applySubscribedCondition(sess *xorm.Session, subscriberID int64) *xorm.Session { | ||||
| 	return sess.And( | ||||
| 		builder. | ||||
| 			NotIn("issue.id", | ||||
| 				builder.Select("issue_id"). | ||||
| 					From("issue_watch"). | ||||
| 					Where(builder.Eq{"is_watching": false, "user_id": subscriberID}), | ||||
| 			), | ||||
| 	).And( | ||||
| 		builder.Or( | ||||
| 			builder.In("issue.id", builder. | ||||
| 				Select("issue_id"). | ||||
| 				From("issue_watch"). | ||||
| 				Where(builder.Eq{"is_watching": true, "user_id": subscriberID}), | ||||
| 			), | ||||
| 			builder.In("issue.id", builder. | ||||
| 				Select("issue_id"). | ||||
| 				From("comment"). | ||||
| 				Where(builder.Eq{"poster_id": subscriberID}), | ||||
| 			), | ||||
| 			builder.Eq{"issue.poster_id": subscriberID}, | ||||
| 			builder.In("issue.repo_id", builder. | ||||
| 				Select("id"). | ||||
| 				From("watch"). | ||||
| 				Where(builder.Eq{"user_id": subscriberID, "mode": true}), | ||||
| 			), | ||||
| 		), | ||||
| 	) | ||||
| } | ||||
|  | ||||
| // CountIssuesByRepo map from repoID to number of issues matching the options | ||||
| func CountIssuesByRepo(opts *IssuesOptions) (map[int64]int64, error) { | ||||
| 	e := db.GetEngine(db.DefaultContext) | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 qwerty287
					qwerty287