2022-12-11 09:47:01 +00:00
|
|
|
class TextSearch
|
|
|
|
attr_reader :current_user, :current_account, :params
|
|
|
|
|
|
|
|
DEFAULT_STATUS = 'open'.freeze
|
|
|
|
|
|
|
|
def initialize(current_user, params)
|
2022-12-12 07:46:27 +00:00
|
|
|
@current_account = current_user.account || Current.account
|
2022-12-11 09:47:01 +00:00
|
|
|
@params = params
|
|
|
|
end
|
|
|
|
|
|
|
|
def perform
|
|
|
|
{
|
|
|
|
messages: filter_messages,
|
|
|
|
conversations: filter_conversations,
|
|
|
|
contacts: filter_contacts
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def filter_conversations
|
2022-12-21 13:37:05 +00:00
|
|
|
@conversations = PgSearch.multisearch((@params[:q]).to_s).where(account_id: @current_account, searchable_type: 'Conversation').joins(
|
2022-12-21 17:23:25 +00:00
|
|
|
'INNER JOIN conversations ON pg_search_documents.searchable_id = conversations.id'
|
|
|
|
).includes(:searchable).limit(20).collect(&:searchable)
|
2022-12-11 09:47:01 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def filter_messages
|
2022-12-21 13:37:05 +00:00
|
|
|
@messages = PgSearch.multisearch((@params[:q]).to_s).where(account_id: @current_account, searchable_type: 'Message').joins(
|
2022-12-21 17:23:25 +00:00
|
|
|
'INNER JOIN messages ON pg_search_documents.searchable_id = messages.id'
|
|
|
|
).includes(:searchable).limit(20).collect(&:searchable)
|
2022-12-11 09:47:01 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def filter_contacts
|
2022-12-21 13:37:05 +00:00
|
|
|
@contacts = PgSearch.multisearch((@params[:q]).to_s).where(account_id: @current_account, searchable_type: 'Contact').joins(
|
2022-12-21 17:23:25 +00:00
|
|
|
'INNER JOIN contacts ON pg_search_documents.searchable_id = contacts.id'
|
|
|
|
).includes(:searchable).limit(20).collect(&:searchable)
|
2022-12-11 09:47:01 +00:00
|
|
|
end
|
|
|
|
end
|