FIX: Pluralized translation overrides didn't work for en_US
"en_US" doesn't contain most of the translations, so it falls back to "en". But that behavior stopped translation overrides to work for pluralized strings in "en_US", because it relies on existing translations. This fixes it by looking up the existing translation in all fallback locales.
This commit is contained in:
parent
7353a4c64a
commit
ce1620f2ad
|
@ -82,7 +82,15 @@ module I18n
|
||||||
overrides = options.dig(:overrides, locale)
|
overrides = options.dig(:overrides, locale)
|
||||||
|
|
||||||
if overrides
|
if overrides
|
||||||
if existing_translations && options[:count]
|
if options[:count]
|
||||||
|
if !existing_translations
|
||||||
|
I18n.fallbacks[locale].drop(1).each do |fallback|
|
||||||
|
existing_translations = super(fallback, key, scope, options)
|
||||||
|
break if existing_translations.present?
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if existing_translations
|
||||||
remapped_translations =
|
remapped_translations =
|
||||||
if existing_translations.is_a?(Hash)
|
if existing_translations.is_a?(Hash)
|
||||||
Hash[existing_translations.map { |k, v| ["#{key}.#{k}", v] }]
|
Hash[existing_translations.map { |k, v| ["#{key}.#{k}", v] }]
|
||||||
|
@ -97,13 +105,13 @@ module I18n
|
||||||
end
|
end
|
||||||
return result if result.size > 0
|
return result if result.size > 0
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
return overrides[key] if overrides[key]
|
return overrides[key] if overrides[key]
|
||||||
end
|
end
|
||||||
|
|
||||||
existing_translations
|
existing_translations
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -172,6 +172,16 @@ describe "translate accelerator" do
|
||||||
expect(I18n.t('items', count: 1)).to eq('one fish')
|
expect(I18n.t('items', count: 1)).to eq('one fish')
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "supports one and other with fallback locale" do
|
||||||
|
override_translation('en_US', 'items.one', 'one fish')
|
||||||
|
override_translation('en_US', 'items.other', '%{count} fishies')
|
||||||
|
|
||||||
|
I18n.with_locale(:en_US) do
|
||||||
|
expect(I18n.t('items', count: 13)).to eq('13 fishies')
|
||||||
|
expect(I18n.t('items', count: 1)).to eq('one fish')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
it "supports one and other when only a single pluralization key is overridden" do
|
it "supports one and other when only a single pluralization key is overridden" do
|
||||||
override_translation('en', 'keys.magic.other', 'no magic keys')
|
override_translation('en', 'keys.magic.other', 'no magic keys')
|
||||||
expect(I18n.t('keys.magic', count: 1)).to eq('one magic key')
|
expect(I18n.t('keys.magic', count: 1)).to eq('one magic key')
|
||||||
|
|
|
@ -94,14 +94,14 @@ describe EmailStyle do
|
||||||
context 'translation override' do
|
context 'translation override' do
|
||||||
before do
|
before do
|
||||||
TranslationOverride.upsert!(
|
TranslationOverride.upsert!(
|
||||||
'en',
|
SiteSetting.default_locale,
|
||||||
'user_notifications.signup.text_body_template',
|
'user_notifications.signup.text_body_template',
|
||||||
"CLICK THAT LINK: %{base_url}/u/activate-account/%{email_token}"
|
"CLICK THAT LINK: %{base_url}/u/activate-account/%{email_token}"
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
after do
|
after do
|
||||||
TranslationOverride.revert!('en', ['user_notifications.signup.text_body_template'])
|
TranslationOverride.revert!(SiteSetting.default_locale, ['user_notifications.signup.text_body_template'])
|
||||||
end
|
end
|
||||||
|
|
||||||
it "applies customizations when translation override exists" do
|
it "applies customizations when translation override exists" do
|
||||||
|
|
Loading…
Reference in New Issue