Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-02-15 03:08:48 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-02-15 03:08:48 +0300
commitb69f406585ff64b1c5140ebba775cc754fabb358 (patch)
tree9af7dfeb0c3f0f8db189a6e18c6be398a7729e2d /app/models
parent866ca4e49ff74ffadf8e6f6ff663a168489c2aba (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'app/models')
-rw-r--r--app/models/label.rb16
-rw-r--r--app/models/user.rb3
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