require 'surveyor/helpers/asset_pipeline' module Surveyor module Helpers module SurveyorHelperMethods include AssetPipeline # Layout: stylsheets and javascripts def surveyor_includes if asset_pipeline_enabled? stylesheet_link_tag('surveyor_all') + javascript_include_tag('surveyor_all') else stylesheet_link_tag('surveyor/reset', 'surveyor/jquery-ui-1.10.0.custom', 'surveyor/jquery-ui-timepicker-addon', 'surveyor/ui.slider.extras', 'surveyor/results', 'surveyor', 'custom') + javascript_include_tag('surveyor/jquery-1.9.0', 'surveyor/jquery-ui-1.10.0.custom', 'surveyor/jquery-ui-timepicker-addon', 'surveyor/jquery.selectToUISlider', 'surveyor/jquery.surveyor', 'surveyor/jquery.maskedinput') end end # Helper for displaying warning/notice/error flash messages def flash_messages(types) types.map{|type| content_tag(:div, "#{flash[type]}".html_safe, :class => type.to_s)}.join.html_safe end # Section: dependencies, menu, previous and next def dependency_explanation_helper(question,response_set) # Attempts to explain why this dependent question needs to be answered by referenced the dependent question and users response trigger_responses = [] dependent_questions = Question.find_all_by_id(question.dependency.dependency_conditions.map(&:question_id)).uniq response_set.responses.find_all_by_question_id(dependent_questions.map(&:id)).uniq.each do |resp| trigger_responses << resp.to_s end "  You answered "#{trigger_responses.join("" and "")}" to the question "#{dependent_questions.map(&:text).join("","")}"" end def menu_button_for(section) submit_tag(section.translation(I18n.locale)[:title], :name => "section[#{section.id}]") end def previous_section # use copy in memory instead of making extra db calls submit_tag(t('surveyor.previous_section').html_safe, :name => "section[#{@sections[@sections.index(@section)-1].id}]") unless @sections.first == @section end def next_section # use copy in memory instead of making extra db calls @sections.last == @section ? submit_tag(t('surveyor.click_here_to_finish').html_safe, :name => "finish") : submit_tag(t('surveyor.next_section').html_safe, :name => "section[#{@sections[@sections.index(@section)+1].id}]") end # Questions def q_text(q, context=nil, locale=nil) "#{next_question_number(q) unless (q.dependent? or q.display_type == "label" or q.display_type == "image" or q.part_of_group?)}#{q.text_for(nil, context, locale)}" end def next_question_number(question) @n ||= 0 "#{@n += 1}) " end # Responses def rc_to_attr(type_sym) case type_sym.to_s when /^answer$/ then :answer_id else "#{type_sym.to_s}_value".to_sym end end def rc_to_as(type_sym) case type_sym.to_s when /(integer|float|date|time|datetime)/ then :string else type_sym end end def generate_pick_none_input_html(value, default_value, css_class, response_class, disabled, input_mask, input_mask_placeholder) html = {} html[:class] = [response_class,css_class].reject{ |c| c.blank? } html[:value] = value.blank? ? default_value : value html[:disabled] = disabled unless disabled.blank? if input_mask html[:'data-input-mask'] = input_mask html[:'data-input-mask-placeholder'] = input_mask_placeholder unless input_mask_placeholder.blank? end html end # Responses def response_for(response_set, question, answer = nil, response_group = nil) return nil unless response_set && question && question.id result = response_set.responses.detect{|r| (r.question_id == question.id) && (answer.blank? ? true : r.answer_id == answer.id) && (r.response_group.blank? ? true : r.response_group.to_i == response_group.to_i)} result.blank? ? response_set.responses.build(:question_id => question.id, :response_group => response_group) : result end def response_idx(increment = true) @rc ||= 0 (increment ? @rc += 1 : @rc).to_s end end end end