]> git.openstreetmap.org Git - rails.git/commitdiff
Fix: only call store_translations once per locale
authorAdam Hoyle <atomoil@gmail.com>
Tue, 14 Dec 2021 10:39:25 +0000 (10:39 +0000)
committerAdam Hoyle <atomoil@gmail.com>
Tue, 14 Dec 2021 10:39:25 +0000 (10:39 +0000)
lib/osm_community_index/local_chapter.rb

index 866346570c459fbacc341d9a58adabe77dad0d2f..10029a77e1312121d0dacf060f86113dcc26db8b 100644 (file)
@@ -42,6 +42,7 @@ module OsmCommunityIndex
         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_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 = {}
 
         raw_local_chapters.each do |chapter|
           id = chapter[:id]
 
         raw_local_chapters.each do |chapter|
           id = chapter[:id]
@@ -52,12 +53,7 @@ module OsmCommunityIndex
           # as per discussion here: https://github.com/osmlab/osm-community-index/issues/483
           strings['name'] = strings['name'] || resource["strings"]["name"] || resource["strings"]["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.deep_merge!({"osm_community_index" => {"local_chapter" => {id => strings}}})
         end
       end
     end
         end
       end
     end