Skip to content
Extraits de code Groupes Projets
Valider 2b550906 rédigé par danielgrippi's avatar danielgrippi
Parcourir les fichiers

downcase query string for search

parent 16bd3e4c
Aucune branche associée trouvée
Aucune étiquette associée trouvée
Aucune requête de fusion associée trouvée
......@@ -45,6 +45,8 @@ class Person < ActiveRecord::Base
scope :searchable, joins(:profile).where(:profiles => {:searchable => true})
def self.search_query_string(query)
query = query.downcase
if postgres?
where_clause = <<-SQL
profiles.full_name ILIKE ? OR
......@@ -57,7 +59,7 @@ class Person < ActiveRecord::Base
SQL
end
q_tokens = query.to_s.strip.gsub(/(\s|$|^)/) { "%#{$1}" }
q_tokens = query.to_s.strip.gsub(/(\s|$)/) { "%#{$1}" }
[where_clause, [q_tokens, q_tokens]]
end
......@@ -66,6 +68,8 @@ class Person < ActiveRecord::Base
sql, tokens = self.search_query_string(query)
pp tokens
Person.searchable.where(sql, *tokens).joins(
"LEFT OUTER JOIN contacts ON contacts.user_id = #{user.id} AND contacts.person_id = people.id"
).includes(:profile
......
0% Chargement en cours ou .
You are about to add 0 people to the discussion. Proceed with caution.
Terminez d'abord l'édition de ce message.
Veuillez vous inscrire ou vous pour commenter