diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-02-15 03:08:48 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-02-15 03:08:48 +0300 |
commit | b69f406585ff64b1c5140ebba775cc754fabb358 (patch) | |
tree | 9af7dfeb0c3f0f8db189a6e18c6be398a7729e2d /app/models | |
parent | 866ca4e49ff74ffadf8e6f6ff663a168489c2aba (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'app/models')
-rw-r--r-- | app/models/label.rb | 16 | ||||
-rw-r--r-- | app/models/user.rb | 3 |
2 files changed, 18 insertions, 1 deletions
diff --git a/app/models/label.rb b/app/models/label.rb index 938ecb323e2..632207701d8 100644 --- a/app/models/label.rb +++ b/app/models/label.rb @@ -42,6 +42,22 @@ class Label < ApplicationRecord scope :order_name_desc, -> { reorder(title: :desc) } scope :subscribed_by, ->(user_id) { joins(:subscriptions).where(subscriptions: { user_id: user_id, subscribed: true }) } + scope :top_labels_by_target, -> (target_relation) { + label_id_column = arel_table[:id] + + # Window aggregation to count labels + count_by_id = Arel::Nodes::Over.new( + Arel::Nodes::NamedFunction.new('count', [label_id_column]), + Arel::Nodes::Window.new.partition(label_id_column) + ).as('count_by_id') + + select(arel_table[Arel.star], count_by_id) + .joins(:label_links) + .merge(LabelLink.where(target: target_relation)) + .reorder(count_by_id: :desc) + .distinct + } + def self.prioritized(project) joins(:priorities) .where(label_priorities: { project_id: project }) diff --git a/app/models/user.rb b/app/models/user.rb index 11bfa485ae9..ec9bc7ae01e 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -1226,7 +1226,8 @@ class User < ApplicationRecord { name: name, username: username, - avatar_url: avatar_url(only_path: false) + avatar_url: avatar_url(only_path: false), + email: email } end |