Class: Decidim::Forms::QuestionnaireParticipants
- Inherits:
-
Query
- Object
- Query
- Decidim::Forms::QuestionnaireParticipants
- Defined in:
- app/queries/decidim/forms/questionnaire_participants.rb
Overview
A class used to collect user answers for a questionnaire
Class Method Summary collapse
-
.for(questionnaire) ⇒ Object
Syntactic sugar to initialize the class and return the queried objects.
Instance Method Summary collapse
- #count_participants ⇒ Object
-
#initialize(questionnaire) ⇒ QuestionnaireParticipants
constructor
Initializes the class.
- #participant(session_token) ⇒ Object
- #participants ⇒ Object
-
#query ⇒ Object
Finds all Answers for the questionnaire (unique session_tokens).
Constructor Details
#initialize(questionnaire) ⇒ QuestionnaireParticipants
Initializes the class.
questionnaire = a Questionnaire object
17 18 19 |
# File 'app/queries/decidim/forms/questionnaire_participants.rb', line 17 def initialize(questionnaire) @questionnaire = questionnaire end |
Class Method Details
.for(questionnaire) ⇒ Object
Syntactic sugar to initialize the class and return the queried objects.
questionnaire - a Questionnaire object
10 11 12 |
# File 'app/queries/decidim/forms/questionnaire_participants.rb', line 10 def self.for(questionnaire) new(questionnaire).query end |
Instance Method Details
#count_participants ⇒ Object
38 39 40 |
# File 'app/queries/decidim/forms/questionnaire_participants.rb', line 38 def count_participants query.select(:session_token).distinct.count end |
#participant(session_token) ⇒ Object
29 30 31 |
# File 'app/queries/decidim/forms/questionnaire_participants.rb', line 29 def participant(session_token) query.find_by(session_token:) end |
#participants ⇒ Object
33 34 35 36 |
# File 'app/queries/decidim/forms/questionnaire_participants.rb', line 33 def participants subquery = query.select("DISTINCT ON (decidim_forms_answers.session_token) decidim_forms_answers.*") Answer.select("*").from(subquery).order(:created_at) end |
#query ⇒ Object
Finds all Answers for the questionnaire (unique session_tokens). Because exporters only have access to the Answers this is used as an indirect way to access the participants (see #participants and #participant)
25 26 27 |
# File 'app/queries/decidim/forms/questionnaire_participants.rb', line 25 def query Answer.where(questionnaire: @questionnaire) end |