|
|
@ -17,13 +17,13 @@ class AccountFilter |
|
|
|
attr_reader :params |
|
|
|
|
|
|
|
def initialize(params) |
|
|
|
@params = params |
|
|
|
@params = params.to_h.symbolize_keys |
|
|
|
end |
|
|
|
|
|
|
|
def results |
|
|
|
scope = Account.includes(:account_stat, user: [:ips, :invite_request]).without_instance_actor.reorder(nil) |
|
|
|
|
|
|
|
params.each do |key, value| |
|
|
|
relevant_params.each do |key, value| |
|
|
|
next if key.to_s == 'page' |
|
|
|
|
|
|
|
scope.merge!(scope_for(key, value)) if value.present? |
|
|
@ -34,6 +34,16 @@ class AccountFilter |
|
|
|
|
|
|
|
private |
|
|
|
|
|
|
|
def relevant_params |
|
|
|
params.tap do |args| |
|
|
|
args.delete(:origin) if origin_is_remote_and_domain_present? |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
def origin_is_remote_and_domain_present? |
|
|
|
params[:origin] == 'remote' && params[:by_domain].present? |
|
|
|
end |
|
|
|
|
|
|
|
def scope_for(key, value) |
|
|
|
case key.to_s |
|
|
|
when 'origin' |
|
|
@ -94,7 +104,15 @@ class AccountFilter |
|
|
|
def order_scope(value) |
|
|
|
case value.to_s |
|
|
|
when 'active' |
|
|
|
accounts_with_users.left_joins(:account_stat).order(Arel.sql('coalesce(users.current_sign_in_at, account_stats.last_status_at, to_timestamp(0)) desc, accounts.id desc')) |
|
|
|
accounts_with_users |
|
|
|
.left_joins(:account_stat) |
|
|
|
.order( |
|
|
|
Arel.sql( |
|
|
|
<<~SQL.squish |
|
|
|
COALESCE(users.current_sign_in_at, account_stats.last_status_at, to_timestamp(0)) DESC, accounts.id DESC |
|
|
|
SQL |
|
|
|
) |
|
|
|
) |
|
|
|
when 'recent' |
|
|
|
Account.recent |
|
|
|
else |
|
|
|