mirror of
https://gitlink.org.cn/Gitlink/forgeplus.git
synced 2026-05-02 19:30:48 +08:00
orgs search
This commit is contained in:
21
app/queries/admins/organization_query.rb
Normal file
21
app/queries/admins/organization_query.rb
Normal file
@@ -0,0 +1,21 @@
|
||||
class Admins::OrganizationQuery < ApplicationQuery
|
||||
include CustomSortable
|
||||
attr_reader :params
|
||||
sort_columns :created_on, :last_login_on, :experience, :grade, default_by: :created_on, default_direction: :desc
|
||||
|
||||
def initialize(params)
|
||||
@params = params
|
||||
end
|
||||
|
||||
def call
|
||||
orgs = Organization.all
|
||||
# 关键字检索
|
||||
keyword = params[:keyword].to_s.strip.presence
|
||||
if keyword
|
||||
sql = 'nickname LIKE :keyword OR login LIKE :keyword'
|
||||
orgs = orgs.where(sql, keyword: "%#{keyword}%")
|
||||
end
|
||||
|
||||
custom_sort(orgs, params[:sort_by], params[:sort_direction])
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user