Merge pull request #4948 from tgxworld/fix_translation_fallback_not_using_overrides
FIX: Translation fallback was not using fallback's translation override.
This commit is contained in:
commit
a7a8ccb100
|
@ -137,21 +137,29 @@ module I18n
|
||||||
load_locale(locale) unless @loaded_locales.include?(locale)
|
load_locale(locale) unless @loaded_locales.include?(locale)
|
||||||
|
|
||||||
if @overrides_enabled
|
if @overrides_enabled
|
||||||
if by_locale = overrides_by_locale(locale)
|
overrides = {}
|
||||||
|
|
||||||
|
backend.fallbacks(locale).each do |l|
|
||||||
|
overrides[l] = overrides_by_locale(l)
|
||||||
|
end
|
||||||
|
|
||||||
|
if overrides.present?
|
||||||
if options.present?
|
if options.present?
|
||||||
options[:overrides] = by_locale
|
options[:overrides] = overrides
|
||||||
|
|
||||||
# I18n likes to use throw...
|
# I18n likes to use throw...
|
||||||
catch(:exception) do
|
catch(:exception) do
|
||||||
return backend.translate(locale, key, options)
|
return backend.translate(locale, key, options)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if result = by_locale[key]
|
overrides.each do |_k, v|
|
||||||
|
if result = v[key]
|
||||||
return result
|
return result
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
translate_no_override(key, options)
|
translate_no_override(key, options)
|
||||||
end
|
end
|
||||||
|
|
|
@ -72,8 +72,9 @@ module I18n
|
||||||
# the original translations before applying our overrides.
|
# the original translations before applying our overrides.
|
||||||
def lookup(locale, key, scope = [], options = {})
|
def lookup(locale, key, scope = [], options = {})
|
||||||
existing_translations = super(locale, key, scope, options)
|
existing_translations = super(locale, key, scope, options)
|
||||||
|
overrides = options.dig(:overrides, locale)
|
||||||
|
|
||||||
if options[:overrides] && existing_translations
|
if overrides && existing_translations
|
||||||
if options[:count]
|
if options[:count]
|
||||||
|
|
||||||
remapped_translations =
|
remapped_translations =
|
||||||
|
@ -85,13 +86,13 @@ module I18n
|
||||||
|
|
||||||
result = {}
|
result = {}
|
||||||
|
|
||||||
remapped_translations.merge(options[:overrides]).each do |k, v|
|
remapped_translations.merge(overrides).each do |k, v|
|
||||||
result[k.split('.').last.to_sym] = v if k != key && k.start_with?(key.to_s)
|
result[k.split('.').last.to_sym] = v if k != key && k.start_with?(key.to_s)
|
||||||
end
|
end
|
||||||
return result if result.size > 0
|
return result if result.size > 0
|
||||||
end
|
end
|
||||||
|
|
||||||
return options[:overrides][key] if options[:overrides][key]
|
return overrides[key] if overrides[key]
|
||||||
end
|
end
|
||||||
|
|
||||||
existing_translations
|
existing_translations
|
||||||
|
|
|
@ -147,6 +147,22 @@ describe I18n::Backend::DiscourseI18n do
|
||||||
expect(I18n.translate('keys.magic', count: 2)).to eq("no magic keys")
|
expect(I18n.translate('keys.magic', count: 2)).to eq("no magic keys")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "returns the overriden text when falling back" do
|
||||||
|
TranslationOverride.upsert!('en', 'got', "summer")
|
||||||
|
I18n.backend.store_translations(:en, got: 'winter')
|
||||||
|
|
||||||
|
expect(I18n.translate('got')).to eq('summer')
|
||||||
|
expect(I18n.with_locale(:zh_TW) { I18n.translate('got') }).to eq('summer')
|
||||||
|
|
||||||
|
TranslationOverride.upsert!('en', 'throne', "%{title} is the new queen")
|
||||||
|
I18n.backend.store_translations(:en, throne: "%{title} is the new king")
|
||||||
|
|
||||||
|
expect(I18n.t('throne', title: 'snow')).to eq('snow is the new queen')
|
||||||
|
|
||||||
|
expect(I18n.with_locale(:en) { I18n.t('throne', title: 'snow') })
|
||||||
|
.to eq('snow is the new queen')
|
||||||
|
end
|
||||||
|
|
||||||
it 'supports ActiveModel::Naming#human' do
|
it 'supports ActiveModel::Naming#human' do
|
||||||
Fish = Class.new(ActiveRecord::Base)
|
Fish = Class.new(ActiveRecord::Base)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue