diff options
author | Sean McGivern <sean@mcgivern.me.uk> | 2017-02-22 16:01:10 +0000 |
---|---|---|
committer | Sean McGivern <sean@mcgivern.me.uk> | 2017-02-22 16:01:10 +0000 |
commit | 4753368d2f1bb62eab76bb3276f0859f8eec140d (patch) | |
tree | 73f20e0153913d51d5ba273a960b136c28ce6ee1 /app/models | |
parent | 91335c59fd3a0a1dc5cd83835d086ac1699316b9 (diff) | |
parent | 0494930d7a939297a071bb817ad0227da17dda1b (diff) | |
download | gitlab-ce-4753368d2f1bb62eab76bb3276f0859f8eec140d.tar.gz |
Merge branch 'add_mr_info_to_issues_list' into 'master'
Add merge request count to each issue on issues list
Closes #19786 and #23208
See merge request !9252
Diffstat (limited to 'app/models')
-rw-r--r-- | app/models/concerns/issuable.rb | 4 | ||||
-rw-r--r-- | app/models/merge_requests_closing_issues.rb | 8 |
2 files changed, 10 insertions, 2 deletions
diff --git a/app/models/concerns/issuable.rb b/app/models/concerns/issuable.rb index 5f53c48fc88..c9c6bd24d75 100644 --- a/app/models/concerns/issuable.rb +++ b/app/models/concerns/issuable.rb @@ -16,9 +16,9 @@ module Issuable include TimeTrackable # This object is used to gather issuable meta data for displaying - # upvotes, downvotes and notes count for issues and merge requests + # upvotes, downvotes, notes and closing merge requests count for issues and merge requests # lists avoiding n+1 queries and improving performance. - IssuableMeta = Struct.new(:upvotes, :downvotes, :notes_count) + IssuableMeta = Struct.new(:upvotes, :downvotes, :notes_count, :merge_requests_count) included do cache_markdown_field :title, pipeline: :single_line diff --git a/app/models/merge_requests_closing_issues.rb b/app/models/merge_requests_closing_issues.rb index ab597c37947..daafb137be4 100644 --- a/app/models/merge_requests_closing_issues.rb +++ b/app/models/merge_requests_closing_issues.rb @@ -4,4 +4,12 @@ class MergeRequestsClosingIssues < ActiveRecord::Base validates :merge_request_id, uniqueness: { scope: :issue_id }, presence: true validates :issue_id, presence: true + + class << self + def count_for_collection(ids) + group(:issue_id). + where(issue_id: ids). + pluck('issue_id', 'COUNT(*) as count') + end + end end |