X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/764f808d5a5faebc835ed0f588bae4a306ad687d..a1db3f9ae45c1be24a18a11e9713692bb30f61c4:/lib/osm_community_index/local_chapter.rb?ds=sidebyside diff --git a/lib/osm_community_index/local_chapter.rb b/lib/osm_community_index/local_chapter.rb index ca63d3782..10029a77e 100644 --- a/lib/osm_community_index/local_chapter.rb +++ b/lib/osm_community_index/local_chapter.rb @@ -8,50 +8,52 @@ module OsmCommunityIndex end def self.local_chapters - @chapters = load_local_chapters + @chapters = init_local_chapters end - def self.load_local_chapters - community_index = OsmCommunityIndex.community_index + def self.init_local_chapters + raw_local_chapters = load_raw_local_chapters local_chapters = [] + raw_local_chapters.each do |chapter| + id = chapter[:id] + url = chapter[:resource]["strings"]["url"] + local_chapters.push(LocalChapter.new(id, url)) + end + local_chapters + 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" - - # name comes via I18n - url = resource["strings"]["url"] - local_chapters.push(LocalChapter.new(id, url)) + raw_local_chapters.push({ :id => id, :resource => resource }) end end - local_chapters + raw_local_chapters end def self.add_to_i18n - community_index = OsmCommunityIndex.community_index - files = Dir.children(Rails.root.join("node_modules/osm-community-index/i18n/")) + raw_local_chapters = load_raw_local_chapters + files = Dir.glob(Rails.root.join("node_modules/osm-community-index/i18n/*")) files.each do |file| - path = Rails.root.join("node_modules/osm-community-index/i18n/#{file}") locale = File.basename(file,".yaml") - community_index_yaml = YAML.safe_load(File.read(path))[locale] + community_index_yaml = YAML.safe_load(File.read(file))[locale] # rails wants en-GB but osm-community-index has en_GB locale_rails = locale.split("_").join("-") + data = {} - community_index["resources"].each do |id, resource| - resource.each do |key, value| - next unless key == "type" && value == "osm-lc" && id != "OSMF" - - 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"] + raw_local_chapters.each do |chapter| + id = chapter[:id] + resource = chapter[:resource] - data = {} - data["osm_community_index"] = {} - data["osm_community_index"]["local_chapter"] = {} - data["osm_community_index"]["local_chapter"][id] = strings - I18n.backend.store_translations locale_rails, data + 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"] - end + data.deep_merge!({"osm_community_index" => {"local_chapter" => {id => strings}}}) end end end