]> git.openstreetmap.org Git - rails.git/commitdiff
Improve method privacy
authorAdam Hoyle <atomoil@gmail.com>
Tue, 24 Aug 2021 20:27:43 +0000 (21:27 +0100)
committerAdam Hoyle <atomoil@gmail.com>
Tue, 24 Aug 2021 20:38:05 +0000 (21:38 +0100)
app/models/communities.rb

index 05e330b265383c6cc0d90f56c0042a2f0f7fbf31..fc2f95800987d773c7592a633d7ecb8a159daa68 100644 (file)
@@ -7,49 +7,53 @@ class Communities
     @local_chapters[locale] = local_chapter_for(locale)
   end
 
-  def self.local_chapter_for(locale)
-    @local_chapters_index = load_local_chapters
-    locale_dict = locale_dict_for(locale)
-    localised_chapters = []
-    @local_chapters_index.each do |chapter|
-      id = chapter[:id]
-      name = locale_dict.dig(id, "name") || chapter[:name]
-      url = chapter[:url]
-      localised_chapters.push({ :id => id, :name => name, :url => url })
+  class << self
+    protected
+
+    def local_chapter_for(locale)
+      @local_chapters_index = load_local_chapters
+      locale_dict = locale_dict_for(locale)
+      localised_chapters = []
+      @local_chapters_index.each do |chapter|
+        id = chapter[:id]
+        name = locale_dict.dig(id, "name") || chapter[:name]
+        url = chapter[:url]
+        localised_chapters.push({ :id => id, :name => name, :url => url })
+      end
+      localised_chapters
     end
-    localised_chapters
-  end
 
-  def self.load_local_chapters
-    json_file = File.expand_path("node_modules/osm-community-index/dist/resources.json", Dir.pwd)
-    community_index = JSON.parse(File.read(json_file))
-    local_chapters = []
-    community_index["resources"].each do |id, resource|
-      resource.each do |key, value|
-        next unless key == "type" && value == "osm-lc" && id != "OSMF"
+    def load_local_chapters
+      json_file = File.expand_path("node_modules/osm-community-index/dist/resources.json", Dir.pwd)
+      community_index = JSON.parse(File.read(json_file))
+      local_chapters = []
+      community_index["resources"].each do |id, resource|
+        resource.each do |key, value|
+          next unless key == "type" && value == "osm-lc" && id != "OSMF"
 
-        strings = resource["strings"]
-        chapter_name = strings["community"] || strings["name"]
-        url = strings["url"]
-        local_chapters.push({ :id => id, :name => chapter_name, :url => url })
+          strings = resource["strings"]
+          chapter_name = strings["community"] || strings["name"]
+          url = strings["url"]
+          local_chapters.push({ :id => id, :name => chapter_name, :url => url })
+        end
       end
+      local_chapters
     end
-    local_chapters
-  end
 
-  def self.locale_dict_for(locale_in)
-    locale = locale_in.to_s.tr("-", "_")
-    full_local_path = File.expand_path("node_modules/osm-community-index/i18n/#{locale}.yaml", Dir.pwd)
-    locale_dict = {}
-    if File.exist?(full_local_path)
-      locale_dict = YAML.safe_load(File.read(full_local_path))[locale]
-    else
-      shortened_locale = locale.split("_").first
-      if shortened_locale != locale
-        shortened_local_path = File.expand_path("node_modules/osm-community-index/i18n/#{shortened_locale}.yaml", Dir.pwd)
-        locale_dict = YAML.safe_load(File.read(shortened_local_path))[shortened_locale] if File.exist?(shortened_local_path)
+    def locale_dict_for(locale_in)
+      locale = locale_in.to_s.tr("-", "_")
+      full_local_path = File.expand_path("node_modules/osm-community-index/i18n/#{locale}.yaml", Dir.pwd)
+      locale_dict = {}
+      if File.exist?(full_local_path)
+        locale_dict = YAML.safe_load(File.read(full_local_path))[locale]
+      else
+        shortened_locale = locale.split("_").first
+        if shortened_locale != locale
+          shortened_local_path = File.expand_path("node_modules/osm-community-index/i18n/#{shortened_locale}.yaml", Dir.pwd)
+          locale_dict = YAML.safe_load(File.read(shortened_local_path))[shortened_locale] if File.exist?(shortened_local_path)
+        end
       end
+      locale_dict
     end
-    locale_dict
   end
 end