Class: Rapidfire::SurveyResults
- Inherits:
-
BaseService
- Object
- BaseService
- Rapidfire::SurveyResults
- Defined in:
- app/services/rapidfire/survey_results.rb
Instance Attribute Summary collapse
-
#survey ⇒ Object
Returns the value of attribute survey.
Class Method Summary collapse
Instance Method Summary collapse
-
#extract(filter_params = {}) ⇒ Object
extracts question along with results each entry will have the following: 1.
- #filter(filter_params, column = 'attempt_id') ⇒ Object
Instance Attribute Details
#survey ⇒ Object
Returns the value of attribute survey.
3 4 5 |
# File 'app/services/rapidfire/survey_results.rb', line 3 def survey @survey end |
Class Method Details
.filter(filter_params, column) ⇒ Object
61 62 63 |
# File 'app/services/rapidfire/survey_results.rb', line 61 def self.filter(filter_params, column) self.new.filter(filter_params, column) end |
Instance Method Details
#extract(filter_params = {}) ⇒ Object
extracts question along with results each entry will have the following:
-
question type and question id
-
question text
-
if aggregatable, return each option with value
-
else return an array of all the answers given
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
# File 'app/services/rapidfire/survey_results.rb', line 11 def extract(filter_params = {}) @survey.questions.collect do |question| results = case question when Rapidfire::Questions::Select, Rapidfire::Questions::Radio, Rapidfire::Questions::Checkbox answers = question.answers.where(*filter(filter_params)).map(&:answer_text).map do |text| text.to_s.split(Rapidfire.answers_delimiter) end.flatten count_hash = Hash.new(0) question..map{|o| count_hash[o] = 0 } answers.inject(count_hash) { |total, e| total[e] += 1; total } when Rapidfire::Questions::Short, Rapidfire::Questions::Date, Rapidfire::Questions::Long, Rapidfire::Questions::Numeric question.answers.where(*filter(filter_params)).pluck(:answer_text) end QuestionResult.new(question: question, results: results) end end |
#filter(filter_params, column = 'attempt_id') ⇒ Object
34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'app/services/rapidfire/survey_results.rb', line 34 def filter(filter_params, column = 'attempt_id') @filter_result ||= begin return ["0=0"] unless Array(filter_params[:question_ids]).compact.count == Array(filter_params[:options]).compact.count return ["0=0"] unless %w(id attempt_id).include?(column) return ["0=0"] if Array(filter_params[:question_ids]).compact.count == 0 collected_filters = {} Array(filter_params[:question_ids]).each_with_index do |question_id, i| collected_filters[question_id] ||= [] collected_filters[question_id] << filter_params[:options][i] end attempt_ids = nil collected_filters.each do |question_id, | these_matches = Answer.where("question_id = ? and answer_text in (?)", question_id, ).pluck(:attempt_id) if attempt_ids.nil? attempt_ids = these_matches else attempt_ids = attempt_ids & these_matches end end ["#{column} in (?)", attempt_ids] end end |