X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/6b8c58d2eb7d26d2cae23c1f30390f0321d558a2..44286b46b1962c3bf1d1568faf0a7f38a2a634c2:/lib/osm_community_index/local_chapter.rb diff --git a/lib/osm_community_index/local_chapter.rb b/lib/osm_community_index/local_chapter.rb index c92561487..6df3c1bc9 100644 --- a/lib/osm_community_index/local_chapter.rb +++ b/lib/osm_community_index/local_chapter.rb @@ -8,50 +8,56 @@ 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| - locale = File.basename(file,".yaml") + locale = File.basename(file, ".yaml") 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("-") + locale_rails = locale.tr("_", "-") + data = {} - community_index["resources"].each do |id, resource| - resource.each do |key, value| - next unless key == "type" && value == "osm-lc" && id != "OSMF" + raw_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 = 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"] - 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 - - end + data.deep_merge!({ "osm_community_index" => { "local_chapter" => { id => strings } } }) end + + I18n.backend.store_translations locale_rails, data end end end