5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
# File 'app/controllers/concerns/collavre/users_controller/contact_management.rb', line 5
def search
term = params[:q].to_s.strip.downcase
if term.blank? && params[:scope] != "contacts"
return render json: []
end
creative = Collavre::Creative.find_by(id: params[:creative_id])
if creative.present? && !creative.has_permission?(Current.user, :read)
head :forbidden and return
end
scope = if params[:scope] == "contacts" && Current.user
contact_ids = Current.user.contact_users.select(:id)
searchable_ids = Collavre::User.where(searchable: true).select(:id)
Collavre::User.where(id: contact_ids).or(Collavre::User.where(id: searchable_ids))
else
Collavre::User.mentionable_for(creative)
end
users = scope
if term.present?
users = users.where("LOWER(users.email) LIKE :term OR LOWER(users.name) LIKE :term", term: "#{term}%")
end
limit = params[:limit].to_i
limit = 20 if limit <= 0
limit = 50 if limit > 50
user_ids = users.select(:id).distinct.limit(limit).pluck(:id)
users = Collavre::User.where(id: user_ids)
render json: users.map { |u| { id: u.id, name: u.display_name, email: u.email, avatar_url: view_context.user_avatar_url(u, size: 20) } }
end
|