1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 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
|
# frozen_string_literal: true
module Enumerize
module Scope
module ActiveRecord
def enumerize(name, options={})
super
_enumerize_module.dependent_eval do
if self < ::ActiveRecord::Base
if options[:scope]
_define_activerecord_scope_methods!(name, options)
end
end
end
end
private
def _define_activerecord_scope_methods!(name, options)
return _define_activerecord_shallow_scopes!(name) if options[:scope] == :shallow
scope_name = options[:scope] == true ? "with_#{name}" : options[:scope]
define_singleton_method scope_name do |*values|
values = enumerized_attributes[name].find_values(*values).map(&:value)
values = values.first if values.size == 1
where(name => values)
end
if options[:scope] == true
define_singleton_method "without_#{name}" do |*values|
values = enumerized_attributes[name].find_values(*values).map(&:value)
where(arel_table[name].not_in(values))
end
end
end
def _define_activerecord_shallow_scopes!(attribute_name)
enumerized_attributes[attribute_name].each_value do |value_obj|
define_singleton_method(value_obj) do
where(attribute_name => value_obj.value)
end
define_singleton_method("not_#{value_obj}") do
where.not(attribute_name => value_obj.value)
end
end
end
end
end
end
|