Class: I18n::Backend::ActiveRecord::Translation
- Inherits:
-
ActiveRecord::Base
- Object
- ActiveRecord::Base
- I18n::Backend::ActiveRecord::Translation
- Defined in:
- lib/i18n/backend/active_record/translation.rb
Constant Summary collapse
- TRUTHY_CHAR =
"\001"
- FALSY_CHAR =
"\002"
Class Method Summary collapse
Instance Method Summary collapse
Class Method Details
.available_locales ⇒ Object
75 76 77 |
# File 'lib/i18n/backend/active_record/translation.rb', line 75 def available_locales Translation.distinct.pluck(:locale).map(&:to_sym) end |
.locale(locale) ⇒ Object
58 59 60 |
# File 'lib/i18n/backend/active_record/translation.rb', line 58 def locale(locale) where(:locale => locale.to_s) end |
.lookup(keys, *separator) ⇒ Object
62 63 64 65 66 67 68 69 70 71 72 73 |
# File 'lib/i18n/backend/active_record/translation.rb', line 62 def lookup(keys, *separator) column_name = connection.quote_column_name('key') keys = Array(keys).map! { |key| key.to_s } unless separator.empty? warn "[DEPRECATION] Giving a separator to Translation.lookup is deprecated. " << "You can change the internal separator by overwriting FLATTEN_SEPARATOR." end namespace = "#{keys.last}#{I18n::Backend::Flatten::FLATTEN_SEPARATOR}%" where("#{column_name} IN (?) OR #{column_name} LIKE ?", keys, namespace) end |
Instance Method Details
#interpolates?(key) ⇒ Boolean
80 81 82 |
# File 'lib/i18n/backend/active_record/translation.rb', line 80 def interpolates?(key) self.interpolations.include?(key) if self.interpolations end |
#value ⇒ Object
84 85 86 87 88 89 90 91 92 93 94 95 |
# File 'lib/i18n/backend/active_record/translation.rb', line 84 def value value = read_attribute(:value) if is_proc Kernel.eval(value) elsif value == FALSY_CHAR false elsif value == TRUTHY_CHAR true else value end end |
#value=(value) ⇒ Object
97 98 99 100 101 102 103 104 105 |
# File 'lib/i18n/backend/active_record/translation.rb', line 97 def value=(value) if value === false value = FALSY_CHAR elsif value === true value = TRUTHY_CHAR end write_attribute(:value, value) end |