commit: 1caf11ddcc029d9e7735ab3b90607ab2d6973034
parent: 95f018a3d4f02ff4ce77d7b1cfa9a79fce3ce99a
Author: Eugen Rochko <eugen@zeonfederated.com>
Date: Fri, 8 Sep 2017 12:32:22 +0200
Fix language filter codes (#4841)
* Fix language filter codes
CLD3 returns BCP-47 language identifier, filter settings expect
identifiers in the ISO 639-1 format. Convert between formats,
and exclude duplicate languages from filter choices (zh-CN->zh)
* Fix zh name
Diffstat:
6 files changed, 21 insertions(+), 4 deletions(-)
diff --git a/Gemfile b/Gemfile
@@ -24,6 +24,7 @@ gem 'addressable', '~> 2.5'
gem 'bootsnap'
gem 'browser'
gem 'charlock_holmes', '~> 0.7.5'
+gem 'iso-639'
gem 'cld3', '~> 3.1'
gem 'devise', '~> 4.2'
gem 'devise-two-factor', '~> 3.0'
diff --git a/Gemfile.lock b/Gemfile.lock
@@ -225,6 +225,7 @@ GEM
terminal-table (>= 1.5.1)
idn-ruby (0.1.0)
ipaddress (0.8.3)
+ iso-639 (0.2.8)
jmespath (1.3.1)
json (2.1.0)
json-ld (2.1.5)
@@ -560,6 +561,7 @@ DEPENDENCIES
httplog (~> 0.99)
i18n-tasks (~> 0.9)
idn-ruby
+ iso-639
json-ld-preloaded (~> 2.2.1)
kaminari (~> 1.0)
letter_opener (~> 1.4)
diff --git a/app/helpers/settings_helper.rb b/app/helpers/settings_helper.rb
@@ -30,6 +30,7 @@ module SettingsHelper
th: 'ภาษาไทย',
tr: 'Türkçe',
uk: 'Українська',
+ zh: '中文',
'zh-CN': '简体中文',
'zh-HK': '繁體中文(香港)',
'zh-TW': '繁體中文(臺灣)',
@@ -39,6 +40,10 @@ module SettingsHelper
HUMAN_LOCALES[locale]
end
+ def filterable_languages
+ I18n.available_locales.map { |locale| locale.to_s.split('-').first.to_sym }.uniq
+ end
+
def hash_to_object(hash)
HashObject.new(hash)
end
diff --git a/app/lib/language_detector.rb b/app/lib/language_detector.rb
@@ -20,7 +20,16 @@ class LanguageDetector
private
def detected_language_code
- result.language.to_sym if detected_language_reliable?
+ iso6391(result.language).to_sym if detected_language_reliable?
+ end
+
+ def iso6391(bcp47)
+ iso639 = bcp47.split('-').first
+
+ # CLD3 returns grandfathered language code for Hebrew
+ return 'he' if iso639 == 'iw'
+
+ ISO_639.find(iso639).alpha2
end
def result
diff --git a/app/views/settings/preferences/show.html.haml b/app/views/settings/preferences/show.html.haml
@@ -13,7 +13,7 @@
selected: I18n.locale
= f.input :filtered_languages,
- collection: I18n.available_locales,
+ collection: filterable_languages,
wrapper: :with_block_label,
include_blank: false,
label_method: lambda { |locale| human_locale(locale) },
diff --git a/spec/helpers/settings_helper_spec.rb b/spec/helpers/settings_helper_spec.rb
@@ -4,10 +4,10 @@ require 'rails_helper'
describe SettingsHelper do
describe 'the HUMAN_LOCALES constant' do
- it 'has the same number of keys as I18n locales exist' do
+ it 'includes all I18n locales' do
options = I18n.available_locales
- expect(described_class::HUMAN_LOCALES.keys).to eq(options)
+ expect(described_class::HUMAN_LOCALES.keys).to include(*options)
end
end