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:
authorDouglas Barbosa Alexandre <dbalexandre@gmail.com>2016-09-29 21:50:14 +0300
committerDouglas Barbosa Alexandre <dbalexandre@gmail.com>2016-10-19 19:58:25 +0300
commit3db2261005c438faad8bf4a339d46eb7798f05b5 (patch)
treeb09acae73956cf67ed160a3ae2c4139a9140921a /app/finders
parent723e576782aefa339a4db8916908c7ebe5a92f48 (diff)
Reuse LabelsFinder on Banzai::Filter::LabelReferenceFilter
Diffstat (limited to 'app/finders')
-rw-r--r--app/finders/issuable_finder.rb5
-rw-r--r--app/finders/labels_finder.rb38
2 files changed, 35 insertions, 8 deletions
diff --git a/app/finders/issuable_finder.rb b/app/finders/issuable_finder.rb
index 6f2adf47c3a..41ea8f801c1 100644
--- a/app/finders/issuable_finder.rb
+++ b/app/finders/issuable_finder.rb
@@ -128,8 +128,7 @@ class IssuableFinder
@labels = Label.where(title: label_names)
if projects
- label_ids = LabelsFinder.new(current_user, project_id: projects).execute.select(:id)
- @labels = @labels.where(labels: { id: label_ids })
+ @labels = LabelsFinder.new(current_user, project_ids: projects, title: label_names).execute
end
else
@labels = Label.none
@@ -277,7 +276,7 @@ class IssuableFinder
items = items.with_label(label_names, params[:sort])
if projects
- label_ids = LabelsFinder.new(current_user, project_id: projects).execute.select(:id)
+ label_ids = LabelsFinder.new(current_user, project_ids: projects).execute.select(:id)
items = items.where(labels: { id: label_ids })
end
end
diff --git a/app/finders/labels_finder.rb b/app/finders/labels_finder.rb
index b8828bcdd32..28110be7097 100644
--- a/app/finders/labels_finder.rb
+++ b/app/finders/labels_finder.rb
@@ -16,8 +16,16 @@ class LabelsFinder < UnionFinder
def label_ids
label_ids = []
- label_ids << Label.where(group_id: projects.joins(:namespace).where(namespaces: { type: 'Group' }).select(:namespace_id)).select(:id)
- label_ids << Label.where(project_id: projects.select(:id)).select(:id)
+
+ if project
+ label_ids << project.group.labels if project.group.present?
+ label_ids << project.labels
+ else
+ label_ids << Label.where(group_id: projects.group_ids)
+ label_ids << Label.where(project_id: projects.select(:id))
+ end
+
+ label_ids
end
def sort(items)
@@ -37,18 +45,38 @@ class LabelsFinder < UnionFinder
params[:project_id].presence
end
+ def project_ids
+ params[:project_ids].presence
+ end
+
def title
params[:title].presence
end
+ def project
+ return @project if defined?(@project)
+
+ if project_id
+ @project = available_projects.find(project_id) rescue nil
+ else
+ @project = nil
+ end
+
+ @project
+ end
+
def projects
return @projects if defined?(@projects)
- @projects = ProjectsFinder.new.execute(current_user)
- @projects = @projects.joins(:namespace).where(namespaces: { id: group_id, type: 'Group' }) if group_id
- @projects = @projects.where(id: project_id) if project_id
+ @projects = available_projects
+ @projects = @projects.in_namespace(group_id) if group_id
+ @projects = @projects.where(id: project_ids) if project_ids
@projects = @projects.reorder(nil)
@projects
end
+
+ def available_projects
+ @available_projects ||= ProjectsFinder.new.execute(current_user)
+ end
end