|
- class Users::OrganizationsController < Users::BaseController
-
- def index
- if current_user.logged?
- logged_organizations_sql = observed_user.organizations.with_visibility(%w(common limited)).to_sql
- privacy_organizations_sql = observed_user.organizations.with_visibility("privacy").joins(:organization_users).where(organization_users: {user_id: current_user.id}).to_sql
- @organizations = Organization.from("( #{ logged_organizations_sql } UNION #{ privacy_organizations_sql } ) AS users")
- else
- @organizations = observed_user.organizations.with_visibility("common")
- end
-
- @organizations = @organizations.ransack(login_cont: params[:search]).result if params[:search].present?
-
- @home_top_ids = @organizations.joins(:home_top_settings).where(home_top_settings: {user_id: observed_user.id}).order("home_top_settings.created_at asc").pluck(:id)
-
- if @home_top_ids.present?
- @organizations = @organizations.joins(:organization_extension).order("FIELD(users.id, #{@home_top_ids.join(",")}) desc, organization_extensions.#{sort_by} #{sort_direction}")
- else
- @organizations = @organizations.joins(:organization_extension).order("organization_extensions.#{sort_by} #{sort_direction}")
- end
-
- @organizations = kaminari_paginate(@organizations)
- end
-
- private
- def sort_by
- OrganizationExtension.column_names.include?(params[:sort_by]) ? params[:sort_by] : 'created_at'
- end
-
- def sort_direction
- %w(desc asc).include?(params[:sort_direction]) ? params[:sort_direction] : 'desc'
- end
- end
|