Module: AbstractController::Translation
| Relationships & Source Files | |
| Extension / Inclusion / Inheritance Descendants | |
| Included In: ::ActionController::Base,::ActionMailer::Base,::ActionView::TestCase::TestController,
          Rails::ApplicationController,
          Rails::InfoController,
          Rails::MailersController,
          Rails::WelcomeController | |
| Defined in: | actionpack/lib/abstract_controller/translation.rb | 
Class Attribute Summary
- .raise_on_missing_translations (also: #raise_on_missing_translations) rw
Instance Attribute Summary
Instance Method Summary
- 
    
      #l(object, **options)  
    
    Alias for #localize. 
- 
    
      #localize(object, **options)  
      (also: #l)
    
    Delegates to I18n.localize.
- 
    
      #t(key, **options)  
    
    Alias for #translate. 
- 
    
      #translate(key, **options)  
      (also: #t)
    
    Delegates to I18n.translate.
Class Attribute Details
.raise_on_missing_translations (rw) Also known as: #raise_on_missing_translations
[ GitHub ]# File 'actionpack/lib/abstract_controller/translation.rb', line 7
mattr_accessor :raise_on_missing_translations, default: false
Instance Attribute Details
#raise_on_missing_translations (rw)
[ GitHub ]# File 'actionpack/lib/abstract_controller/translation.rb', line 7
mattr_accessor :raise_on_missing_translations, default: false
Instance Method Details
#l(object, **options)
Alias for #localize.
# File 'actionpack/lib/abstract_controller/translation.rb', line 35
alias :l :localize
#localize(object, **options) Also known as: #l
Delegates to I18n.localize. Also aliased as l.
# File 'actionpack/lib/abstract_controller/translation.rb', line 32
def localize(object, **) I18n.localize(object, **) end
#t(key, **options)
Alias for #translate.
# File 'actionpack/lib/abstract_controller/translation.rb', line 29
alias :t :translate
#translate(key, **options) Also known as: #t
Delegates to I18n.translate. Also aliased as t.
When the given key starts with a period, it will be scoped by the current controller and action. So if you call translate(".foo") from PeopleController#index, it will convert the call to I18n.translate("people.index.foo"). This makes it less repetitive to translate many keys within the same controller / action and gives you a simple framework for scoping them consistently.
# File 'actionpack/lib/abstract_controller/translation.rb', line 17
def translate(key, **) if key&.start_with?(".") path = controller_path.tr("/", ".") defaults = [:"#{path}#{key}"] defaults << [:default] if [:default] [:default] = defaults.flatten key = "#{path}.#{action_name}#{key}" end i18n_raise = .fetch(:raise, self.raise_on_missing_translations) I18n.translate(key, **, raise: i18n_raise) end