2019-07-30 21:29:24 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-06-12 20:03:43 +00:00
|
|
|
# License: AGPL-3.0-or-later WITH WTO-AP-3.0-or-later
|
|
|
|
# Full license explanation at https://github.com/houdiniproject/houdini/blob/master/LICENSE
|
2018-03-25 17:30:42 +00:00
|
|
|
require 'qexpr'
|
|
|
|
|
|
|
|
module QueryProfiles
|
|
|
|
def self.for_admin(params)
|
2019-07-30 21:29:24 +00:00
|
|
|
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)
|
2018-03-25 17:30:42 +00:00
|
|
|
|
2019-07-30 21:29:24 +00:00
|
|
|
if params[:search].present?
|
|
|
|
expr = expr.where(%(
|
|
|
|
profiles.name LIKE $search
|
|
|
|
OR users.email LIKE $search
|
|
|
|
OR users.name LIKE $search
|
|
|
|
), search: '%' + params[:search].downcase + '%')
|
|
|
|
end
|
2018-03-25 17:30:42 +00:00
|
|
|
|
2019-07-30 21:29:24 +00:00
|
|
|
expr.execute
|
2018-03-25 17:30:42 +00:00
|
|
|
end
|
|
|
|
end
|