diff options
author | Louise Crow <louise.crow@gmail.com> | 2012-08-28 13:43:56 +0100 |
---|---|---|
committer | Louise Crow <louise.crow@gmail.com> | 2012-08-28 13:43:56 +0100 |
commit | f1797b4868a01a27cefef53416da0acca47cac7f (patch) | |
tree | 9fbed1e506ef1232650eb8f79cc5d7d4ef5d2478 /lib | |
parent | 127db1e4bb4fee2d480855b30a330baca459404a (diff) |
Add headings and by_heading accessors to PublicBodyCategories to allow easier access to headings and to tags associated with a particular heading.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/public_body_categories.rb | 29 |
1 files changed, 24 insertions, 5 deletions
diff --git a/lib/public_body_categories.rb b/lib/public_body_categories.rb index b8058bf9e..b4aa71a40 100644 --- a/lib/public_body_categories.rb +++ b/lib/public_body_categories.rb @@ -7,9 +7,15 @@ # $Id: public_body_categories.rb,v 1.1 2009-09-14 14:45:48 francis Exp $ class PublicBodyCategories - - attr_reader :with_description, :with_headings, :tags, :by_tag, :singular_by_tag - + + attr_reader :with_description, + :with_headings, + :tags, + :by_tag, + :singular_by_tag, + :by_heading, + :headings + def initialize(categories) @with_headings = categories # Arranged in different ways for different sorts of displaying @@ -17,8 +23,21 @@ class PublicBodyCategories @tags = @with_description.map() { |a| a[0] } @by_tag = Hash[*@with_description.map() { |a| a[0..1] }.flatten] @singular_by_tag = Hash[*@with_description.map() { |a| [a[0],a[2]] }.flatten] + @by_heading = {} + heading = nil + @headings = [] + @with_headings.each do |row| + if ! row.instance_of?(Array) + heading = row + @headings << row + @by_heading[row] = [] + else + @by_heading[heading] << row[0] + end + end end + def PublicBodyCategories.get load_categories if @@CATEGORIES.empty? @@CATEGORIES[I18n.locale.to_s] || @@CATEGORIES[I18n.default_locale.to_s] || PublicBodyCategories.new([]) @@ -28,10 +47,10 @@ class PublicBodyCategories def PublicBodyCategories.add(locale, categories) @@CATEGORIES[locale.to_s] = PublicBodyCategories.new(categories) end - + private @@CATEGORIES = {} - + def PublicBodyCategories.load_categories() I18n.available_locales.each do |locale| begin |