Module: PgSearchable::ActiveRecord::Relation

Defined in:
lib/pg_searchable/active_record/relation.rb

Instance Method Summary collapse

Instance Method Details

#near(latitude, longitude) ⇒ Object



24
25
26
27
# File 'lib/pg_searchable/active_record/relation.rb', line 24

def near(latitude, longitude)
  puts "searching near #{latitude},#{longitude}"
  self
end

#rank_by(rank) ⇒ Object



29
30
31
32
33
# File 'lib/pg_searchable/active_record/relation.rb', line 29

def rank_by(rank)
  # TODO: add ranks to projections
  puts "ranking by #{rank}"
  self
end

#search_for(term, options = {}) ⇒ Object



6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# File 'lib/pg_searchable/active_record/relation.rb', line 6

def search_for(term, options = {})
  using       = Array(options.delete(:using) || :default)
  models      = Array(options[:in]).map {|association| klass.reflect_on_association(association).klass }
  conditions  = [self.klass, models].flatten.inject([]) do |conditions, klass|
    name    = using.find {|name| klass.pg_searchable_configs.key?(name.to_sym) }
    config  = klass.pg_searchable_configs[name]

    Array(config[:tgrm][:columns]).each       {|name| conditions << klass.arel_table[name].tgrm(term).to_sql }
    Array(config[:tsearch][:columns]).each    {|name| conditions << klass.arel_table[name].tsearch(term, config[:tsearch][:dictionary]).to_sql }
    Array(config[:dmetaphone][:columns]).each {|name| conditions << klass.arel_table[name].dmetaphone(term, config[:dmetaphone][:dictionary]).to_sql }
    conditions
  end

  p conditions

  joins(options[:in]).where("#{conditions.join(' OR ')}")
end