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