mirror of https://github.com/docusealco/docuseal
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
48 lines
1.2 KiB
48 lines
1.2 KiB
# frozen_string_literal: true
|
|
|
|
class SubmittersAutocompleteController < ApplicationController
|
|
load_and_authorize_resource :submitter, parent: false
|
|
|
|
SELECT_COLUMNS = %w[email phone name].freeze
|
|
LIMIT = 100
|
|
|
|
def index
|
|
field = SELECT_COLUMNS.find { |c| c == params[:field] }
|
|
|
|
submitters = search_submitters(@submitters, field)
|
|
|
|
arel_columns = SELECT_COLUMNS.map { |col| Submitter.arel_table[col] }
|
|
|
|
values =
|
|
if field
|
|
max_ids = submitters.group(field).limit(LIMIT).select(Submitter.arel_table[:id].maximum)
|
|
|
|
submitters.where(id: max_ids).order(id: :desc).pluck(arel_columns)
|
|
else
|
|
submitters.limit(LIMIT).group(arel_columns).pluck(arel_columns)
|
|
end
|
|
|
|
attrs = values.map { |row| SELECT_COLUMNS.zip(row).to_h }
|
|
|
|
render json: attrs
|
|
end
|
|
|
|
private
|
|
|
|
def search_submitters(submitters, field)
|
|
if field
|
|
if Docuseal.fulltext_search?
|
|
Submitters.fulltext_search_field(current_user, submitters, params[:q], field)
|
|
else
|
|
column = Submitter.arel_table[field.to_sym]
|
|
|
|
term = "#{params[:q].downcase}%"
|
|
|
|
submitters.where(column.matches(term))
|
|
end
|
|
else
|
|
Submitters.search(current_user, submitters, params[:q])
|
|
end
|
|
end
|
|
end
|