Class: Ransack::Predicate

Inherits:
Object
  • Object
show all
Defined in:
lib/ransack/predicate.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(opts = {}) ⇒ Predicate

Returns a new instance of Predicate.



37
38
39
40
41
42
43
44
# File 'lib/ransack/predicate.rb', line 37

def initialize(opts = {})
  @name = opts[:name]
  @arel_predicate = opts[:arel_predicate]
  @type = opts[:type]
  @formatter = opts[:formatter]
  @validator = opts[:validator]
  @compound = opts[:compound]
end

Instance Attribute Details

#arel_predicateObject (readonly)

Returns the value of attribute arel_predicate.



3
4
5
# File 'lib/ransack/predicate.rb', line 3

def arel_predicate
  @arel_predicate
end

#compoundObject (readonly)

Returns the value of attribute compound.



3
4
5
# File 'lib/ransack/predicate.rb', line 3

def compound
  @compound
end

#formatterObject (readonly)

Returns the value of attribute formatter.



3
4
5
# File 'lib/ransack/predicate.rb', line 3

def formatter
  @formatter
end

#nameObject (readonly)

Returns the value of attribute name.



3
4
5
# File 'lib/ransack/predicate.rb', line 3

def name
  @name
end

#typeObject (readonly)

Returns the value of attribute type.



3
4
5
# File 'lib/ransack/predicate.rb', line 3

def type
  @type
end

#validatorObject (readonly)

Returns the value of attribute validator.



3
4
5
# File 'lib/ransack/predicate.rb', line 3

def validator
  @validator
end

Class Method Details

.detect_and_strip_from_string!(str) ⇒ Object



19
20
21
# File 'lib/ransack/predicate.rb', line 19

def detect_and_strip_from_string!(str)
  names_by_decreasing_length.detect {|p| str.sub!(/_#{p}$/, '')}
end

.detect_from_string(str) ⇒ Object



23
24
25
# File 'lib/ransack/predicate.rb', line 23

def detect_from_string(str)
  names_by_decreasing_length.detect {|p| str.match(/_#{p}$/)}
end

.for_attribute_name(attribute_name) ⇒ Object



31
32
33
# File 'lib/ransack/predicate.rb', line 31

def for_attribute_name(attribute_name)
  self.named(detect_from_string(attribute_name.to_s))
end

.name_from_attribute_name(attribute_name) ⇒ Object



27
28
29
# File 'lib/ransack/predicate.rb', line 27

def name_from_attribute_name(attribute_name)
  names_by_decreasing_length.detect {|p| attribute_name.to_s.match(/_#{p}$/)}
end

.named(name) ⇒ Object



15
16
17
# File 'lib/ransack/predicate.rb', line 15

def named(name)
  Ransack.predicates[name.to_s]
end

.namesObject



7
8
9
# File 'lib/ransack/predicate.rb', line 7

def names
  Ransack.predicates.keys
end

.names_by_decreasing_lengthObject



11
12
13
# File 'lib/ransack/predicate.rb', line 11

def names_by_decreasing_length
  names.sort {|a,b| b.length <=> a.length}
end

Instance Method Details

#eql?(other) ⇒ Boolean Also known as: ==

Returns:

  • (Boolean)


46
47
48
49
# File 'lib/ransack/predicate.rb', line 46

def eql?(other)
  self.class == other.class &&
  self.name == other.name
end

#format(val) ⇒ Object



56
57
58
59
60
61
62
# File 'lib/ransack/predicate.rb', line 56

def format(val)
  if formatter
    formatter.call(val)
  else
    val
  end
end

#hashObject



52
53
54
# File 'lib/ransack/predicate.rb', line 52

def hash
  name.hash
end

#validate(vals) ⇒ Object



64
65
66
67
68
69
70
# File 'lib/ransack/predicate.rb', line 64

def validate(vals)
  if validator
    vals.select {|v| validator.call(v.value)}.any?
  else
    vals.select {|v| v.present?}.any?
  end
end