class Admins::LaboratoryQuery < ApplicationQuery include CustomSortable attr_reader :params sort_columns :id, default_by: :id, default_direction: :desc def initialize(params) @params = params end def call laboratories = Laboratory.all keyword = strip_param(:keyword) if keyword.present? like_sql = 'schools.name LIKE :keyword OR laboratories.identifier LIKE :keyword' laboratories = laboratories.left_joins(:school).where(like_sql, keyword: "%#{keyword}%") end custom_sort laboratories, params[:sort_by], params[:sort_direction] end end