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.
		
		
		
		
		
			
		
			
				
					
					
						
							34 lines
						
					
					
						
							874 B
						
					
					
				
			
		
		
	
	
							34 lines
						
					
					
						
							874 B
						
					
					
				| # 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
 | |
|     submitters = search_submitters(@submitters)
 | |
| 
 | |
|     values = submitters.limit(LIMIT).group(SELECT_COLUMNS.join(', ')).pluck(SELECT_COLUMNS.join(', '))
 | |
| 
 | |
|     attrs = values.map { |row| SELECT_COLUMNS.zip(row).to_h }
 | |
|     attrs = attrs.uniq { |e| e[params[:field]] } if params[:field].present?
 | |
| 
 | |
|     render json: attrs
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def search_submitters(submitters)
 | |
|     if SELECT_COLUMNS.include?(params[:field])
 | |
|       column = Submitter.arel_table[params[:field].to_sym]
 | |
| 
 | |
|       term = "#{params[:q].downcase}%"
 | |
| 
 | |
|       submitters.where(column.matches(term, false, true))
 | |
|     else
 | |
|       Submitters.search(submitters, params[:q])
 | |
|     end
 | |
|   end
 | |
| end
 |