Module: ExtendedHasEnumeration::ClassMethods
- Defined in:
- lib/extended_has_enumeration/class_methods.rb
Instance Method Summary collapse
-
#has_enumeration(enumeration, mapping, options = {}) ⇒ Object
Declares an enumerated attribute called
enumeration
consisting of the symbols defined inmapping
.
Instance Method Details
#has_enumeration(enumeration, mapping, options = {}) ⇒ Object
Declares an enumerated attribute called enumeration
consisting of the symbols defined in mapping
.
When the database representation of the attribute is a string, mapping
can be an array of symbols. The string representation of the symbol will be stored in the databased. E.g.:
has_enumeration :color, [:red, :green, :blue]
When the database representation of the attribute is not a string, or if its values do not match up with the string versions of its symbols, an hash mapping symbols to their underlying values may be used:
has_enumeration :color, :red => 1, :green => 2, :blue => 3
By default, has_enumeration assumes that the column in the database has the same name as the enumeration. If this is not the case, the column can be specified with the :attribute option:
has_enumeration :color, [:red, :green, :blue], :attribute => :hue
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/extended_has_enumeration/class_methods.rb', line 24 def has_enumeration(enumeration, mapping, = {}) unless mapping.is_a?(Hash) # Recast the mapping as a symbol -> string hash mapping_hash = {} mapping.each {|m| mapping_hash[m] = m.to_s} mapping = mapping_hash end if [:initial].present? class_eval do after_initialize :"initialize_#{enumeration}" define_method :"initialize_#{enumeration}" do self.send("#{enumeration}=", self.send(enumeration).blank? ? [:initial] : self.send(enumeration)) end end end # The underlying attribute attribute = [:attribute] || enumeration # ActiveRecord's composed_of method will do most of the work for us. # All we have to do is cons up a class that implements the bidirectional # mapping described by the provided hash. klass = create_enumeration_mapping_class(mapping, ) attr_enumeration_mapping_classes[enumeration] = klass # Bind the class to a name within the scope of this class mapping_class_name = enumeration.to_s.camelize const_set(mapping_class_name, klass) scoped_class_name = [self.name, mapping_class_name].join('::') composed_of(enumeration, :class_name => scoped_class_name, :mapping => [attribute.to_s, 'raw_value'], :constructor => :constructor, :converter => :from_sym ) if ActiveRecord::VERSION::MAJOR >= 3 && ActiveRecord::VERSION::MINOR == 0 # Install this attributes mapping for use later when extending # Arel attributes on the fly. ::Arel::Table.has_enumeration_mappings[table_name][attribute] = mapping else # Install our aggregate condition handling override, but only once unless @aggregate_conditions_override_installed extend ExtendedHasEnumeration::AggregateConditionsOverride @aggregate_conditions_override_installed = true end end end |