mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Merge pull request #5843 from kuroda/translation_of_deeply_nested_model_attributes
Fix human attribute_name to handle deeply nested attributes
This commit is contained in:
commit
555d8152c7
2 changed files with 7 additions and 2 deletions
|
@ -42,9 +42,9 @@ module ActiveModel
|
|||
# Specify +options+ with additional translating options.
|
||||
def human_attribute_name(attribute, options = {})
|
||||
options = { :count => 1 }.merge!(options)
|
||||
parts = attribute.to_s.split(".", 2)
|
||||
parts = attribute.to_s.split(".")
|
||||
attribute = parts.pop
|
||||
namespace = parts.pop
|
||||
namespace = parts.join("/") unless parts.empty?
|
||||
attributes_scope = "#{self.i18n_scope}.attributes"
|
||||
|
||||
if namespace
|
||||
|
|
|
@ -56,6 +56,11 @@ class ActiveModelI18nTests < ActiveModel::TestCase
|
|||
assert_equal 'person gender attribute', Person::Gender.human_attribute_name('attribute')
|
||||
end
|
||||
|
||||
def test_translated_deeply_nested_model_attributes
|
||||
I18n.backend.store_translations 'en', :activemodel => {:attributes => {:"person/contacts/addresses" => {:street => 'Deeply Nested Address Street'}}}
|
||||
assert_equal 'Deeply Nested Address Street', Person.human_attribute_name('contacts.addresses.street')
|
||||
end
|
||||
|
||||
def test_translated_nested_model_attributes
|
||||
I18n.backend.store_translations 'en', :activemodel => {:attributes => {:"person/addresses" => {:street => 'Person Address Street'}}}
|
||||
assert_equal 'Person Address Street', Person.human_attribute_name('addresses.street')
|
||||
|
|
Loading…
Reference in a new issue