1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-17 06:52:27 +01:00

refactored project search using service

This commit is contained in:
Sylvain 2020-06-23 15:45:38 +02:00
parent d419241323
commit 23338eb36d
2 changed files with 35 additions and 13 deletions

View File

@ -52,20 +52,12 @@ class API::ProjectsController < API::ApiController
end
def search
query_params = JSON.parse(params[:search])
service = ProjectService.new
res = service.search(params, current_user)
render json: res, status: :unprocessable_entity and return if res.error
records = Project.published_or_drafts(current_user&.statistic_profile&.id)
records = Project.user_projects(current_user&.statistic_profile&.id) if query_params['from'] == 'mine'
records = Project.collaborations(current_user&.id) if query_params['from'] == 'collaboration'
records = records.with_machine(query_params['machine_id']) if query_params['machine_id'].present?
records = records.with_component(query_params['component_id']) if query_params['component_id'].present?
records = records.with_theme(query_params['theme_id']) if query_params['theme_id'].present?
records = records.with_space(query_params['space_id']) if query_params['space_id'].present?
records = records.search(query_params['q']) if query_params['q'].present?
@total = records.count
@projects = records.includes(:users, :project_image).page(params[:page])
@total = res.total
@projects = res.projects
render :index
end

View File

@ -0,0 +1,30 @@
# frozen_string_literal: true
# Provides methods for Project
class ProjectService
def search(params, current_user)
connection = ActiveRecord::Base.connection
return { error: 'invalid adapter' } unless connection.instance_values['config'][:adapter] == 'postgresql'
search_from_postgre(params, current_user)
end
private
def search_from_postgre(params, current_user)
query_params = JSON.parse(params[:search])
records = Project.published_or_drafts(current_user&.statistic_profile&.id)
records = Project.user_projects(current_user&.statistic_profile&.id) if query_params['from'] == 'mine'
records = Project.collaborations(current_user&.id) if query_params['from'] == 'collaboration'
records = records.with_machine(query_params['machine_id']) if query_params['machine_id'].present?
records = records.with_component(query_params['component_id']) if query_params['component_id'].present?
records = records.with_theme(query_params['theme_id']) if query_params['theme_id'].present?
records = records.with_space(query_params['space_id']) if query_params['space_id'].present?
records = records.search(query_params['q']) if query_params['q'].present?
{ total: records.count, projects: records.includes(:users, :project_image).page(params[:page]) }
end
end