houdini/lib/query/query_profiles.rb

29 lines
825 B
Ruby
Raw Normal View History

# License: AGPL-3.0-or-later WITH Web-Template-Output-Additional-Permission-3.0-or-later
require 'qexpr'
module QueryProfiles
def self.for_admin(params)
expr = Qx.select(
'profiles.name',
'profiles.id',
'profiles.created_at::date::text AS created_at',
'users.confirmed_at AS is_confirmed',
'users.email')
.from(:profiles)
.add_left_join("users", "profiles.user_id=users.id")
.order_by("profiles.created_at DESC")
.paginate(params[:page].to_i, params[:page_length].to_i)
if params[:search].present?
expr = expr.where(%Q(
profiles.name LIKE $search
OR users.email LIKE $search
OR users.name LIKE $search
), search: '%' + params[:search].downcase + '%')
end
return expr.execute
end
end