module Api
module V0
class ThemesController < Api::V0::BaseController
before_action :authenticate
def extract
# check if the user has permissions to use the themes API
@theme = Theme.find(params[:id])
raise Pundit::NotAuthorizedError unless Api::V0::ThemePolicy.new(@user, @theme).extract?
@answers = @theme.answers.where(plan_id: @user.plans.pluck(:id))
admin_answers = []
org_answers = []
if params[:admin_visible].present? && params[:admin_visible]
admin_answers = @theme.answers.where(plan_id: @user.org.plans.privately_visible)
end
if params[:org_visible].present? && params[:org_visible]
org_answers = @theme.answers.where(plan_id: @user.org.plans.organisationally_visible)
end
if params[:template_id].present? && params[:template_id]
@answers = @answers.where(plan_id: @user.plans.where(template_id: params[:template_id]).pluck(:id))
end
if params[:question_id].present? && params[:question_id]
@answers = @answers.where(question_id: params[:question_id])
end
if params[:start_date].present? && params[:start_date]
@answers = @answers.where('answers.created_at >=?', params[:start_date])
end
if params[:end_date].present? && params[:end_date]
@answers = @answers.where('answers.created_at <=?', params[:end_date])
end
end
def extract_params
params.permit(:id, :template_id, :question_id, :start_date, :end_date, :admin_visible, :org_visible)
end
def extract_filtering_params
extract_params.slice(:template_id, :question_id, :start_date, :end_date, :admin_visible, :org_visible)
end
end
end
end