]> git.openstreetmap.org Git - rails.git/blobdiff - lib/osm_community_index/local_chapter.rb
Switch to using FrozenRecord for loading communities
[rails.git] / lib / osm_community_index / local_chapter.rb
index f36a6441cd0748419c9bdefa82c98eab29d38e77..d83f134719f5ea692da80b23eeac056a1d96c5db 100644 (file)
@@ -1,40 +1,7 @@
 module OsmCommunityIndex
   class LocalChapter
-    attr_reader :id, :url
-
-    def initialize(id, url)
-      @id = id
-      @url = url
-    end
-
-    def self.local_chapters
-      @chapters = init_local_chapters
-    end
-
-    def self.init_local_chapters
-      raw_local_chapters = load_raw_local_chapters
-      raw_local_chapters.map do |chapter|
-        id = chapter[:id]
-        url = chapter[:resource]["strings"]["url"]
-        LocalChapter.new(id, url)
-      end
-    end
-
-    def self.load_raw_local_chapters
-      community_index = OsmCommunityIndex.community_index
-      raw_local_chapters = []
-      community_index["resources"].each do |id, resource|
-        resource.each do |key, value|
-          next unless key == "type" && value == "osm-lc" && id != "OSMF"
-
-          raw_local_chapters.push({ :id => id, :resource => resource })
-        end
-      end
-      raw_local_chapters
-    end
-
     def self.add_to_i18n
-      raw_local_chapters = load_raw_local_chapters
+      local_chapters = Community.where(:type => "osm-lc").where.not(:id => "OSMF")
       files = Dir.glob(Rails.root.join("node_modules/osm-community-index/i18n/*"))
       files.each do |file|
         locale = File.basename(file, ".yaml")
@@ -43,14 +10,13 @@ module OsmCommunityIndex
         locale_rails = locale.tr("_", "-")
         data = {}
 
-        raw_local_chapters.each do |chapter|
+        local_chapters.each do |chapter|
           id = chapter[:id]
-          resource = chapter[:resource]
 
           strings = community_index_yaml[id] || {}
           # if the name isn't defined then fall back on community,
           # as per discussion here: https://github.com/osmlab/osm-community-index/issues/483
-          strings["name"] = strings["name"] || resource["strings"]["name"] || resource["strings"]["community"]
+          strings["name"] = strings["name"] || chapter["strings"]["name"] || chapter["strings"]["community"]
 
           data.deep_merge!({ "osm_community_index" => { "local_chapter" => { id => strings } } })
         end