diff options
author | Robert Speicher <robert@gitlab.com> | 2015-10-16 21:29:47 +0000 |
---|---|---|
committer | Robert Speicher <robert@gitlab.com> | 2015-10-16 21:29:47 +0000 |
commit | c856a7a5934fba13598be09507c2090888f57a39 (patch) | |
tree | 5c9721a78f912a15242ee5df3cf1e4393cc6c323 /app/services | |
parent | 292b9da54acd96b19979e36a3f82462a37460416 (diff) | |
parent | d10e3c4498e11e97548b0212887a146d19d19ffd (diff) | |
download | gitlab-ce-c856a7a5934fba13598be09507c2090888f57a39.tar.gz |
Merge branch 'filter-label' into 'master'
Allow dashboard and group issues/MRs to be filtered by label
See merge request !1591
Diffstat (limited to 'app/services')
-rw-r--r-- | app/services/labels/group_service.rb | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/app/services/labels/group_service.rb b/app/services/labels/group_service.rb new file mode 100644 index 00000000000..b26cee24d56 --- /dev/null +++ b/app/services/labels/group_service.rb @@ -0,0 +1,26 @@ +module Labels + class GroupService < ::BaseService + def initialize(project_labels) + @project_labels = project_labels.group_by(&:title) + end + + def execute + build(@project_labels) + end + + def label(title) + if title + group_label = @project_labels[title].group_by(&:title) + build(group_label).first + else + nil + end + end + + private + + def build(label) + label.map { |title, labels| GroupLabel.new(title, labels) } + end + end +end |