From e412ac319cb54df831ff2e277b90d51d57364de5 Mon Sep 17 00:00:00 2001 From: Adam Hoyle Date: Tue, 14 Dec 2021 10:37:35 +0000 Subject: [PATCH] Fix: local chapter filtering is duplicating the logic elsewhere in the file. --- lib/osm_community_index/local_chapter.rb | 53 ++++++++++++++---------- 1 file changed, 30 insertions(+), 23 deletions(-) diff --git a/lib/osm_community_index/local_chapter.rb b/lib/osm_community_index/local_chapter.rb index c92561487..866346570 100644 --- a/lib/osm_community_index/local_chapter.rb +++ b/lib/osm_community_index/local_chapter.rb @@ -8,49 +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") 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("-") - 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 + 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 end end end -- 2.39.5