forked from Gitlink/forgeplus
23 lines
592 B
Ruby
23 lines
592 B
Ruby
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 |