fe 1.0.0 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/README.md +4 -4
- data/app/assets/config/fe/manifest.js +3 -0
- data/app/assets/config/manifest.js +3 -0
- data/app/assets/javascripts/application.js.erb +1 -1
- data/app/assets/javascripts/fe/admin.js +0 -1
- data/app/assets/javascripts/fe/fe.admin.js +2 -6
- data/app/assets/javascripts/fe/{fe.common.js → fe.common.js.erb} +14 -7
- data/app/assets/javascripts/fe/fe.public.js +1 -2
- data/app/assets/javascripts/fe/{fe.public.nojquery.js → fe.public.nojquery.js.erb} +152 -76
- data/app/assets/javascripts/fe/jquery.html5_upload.js +258 -0
- data/app/assets/stylesheets/fe/fe.screen.css.scss.erb +22 -1
- data/app/assets/stylesheets/fe/validation.css +5 -1
- data/app/controllers/{fe/concerns → concerns/fe}/admin/question_sheets_controller_concern.rb +15 -16
- data/app/controllers/concerns/fe/answer_pages_controller_concern.rb +131 -0
- data/app/controllers/{fe/concerns → concerns/fe}/answer_sheets_controller_concern.rb +14 -6
- data/app/controllers/{fe/concerns → concerns/fe}/application_controller_concern.rb +3 -3
- data/app/controllers/fe/admin/elements_controller.rb +46 -24
- data/app/controllers/fe/admin/email_templates_controller.rb +5 -5
- data/app/controllers/fe/admin/question_pages_controller.rb +8 -8
- data/app/controllers/fe/reference_pages_controller.rb +11 -11
- data/app/controllers/fe/reference_sheets_controller.rb +4 -4
- data/app/controllers/fe/references_controller.rb +19 -19
- data/app/controllers/fe/submit_pages_controller.rb +5 -5
- data/app/helpers/fe/answer_pages_helper.rb +1 -1
- data/app/helpers/fe/application_helper.rb +3 -3
- data/app/jobs/fe/update_reference_sheet_visibility_job.rb +11 -0
- data/app/mailers/fe/notifier.rb +4 -4
- data/app/models/answer_sheet.rb +1 -1
- data/app/models/application_record.rb +3 -0
- data/app/models/{fe/concerns → concerns/fe}/answer_concern.rb +2 -2
- data/app/models/{fe/concerns → concerns/fe}/answer_pages_presenter_concern.rb +6 -5
- data/app/models/concerns/fe/answer_sheet_concern.rb +125 -0
- data/app/models/{fe/concerns → concerns/fe}/choice_field_concern.rb +41 -23
- data/app/models/fe/address.rb +2 -2
- data/app/models/fe/answer.rb +1 -1
- data/app/models/fe/answer_sheet.rb +1 -1
- data/app/models/fe/answer_sheet_question_sheet.rb +2 -2
- data/app/models/fe/application.rb +14 -10
- data/app/models/fe/condition.rb +4 -4
- data/app/models/fe/date_field.rb +1 -1
- data/app/models/fe/element.rb +126 -44
- data/app/models/fe/email_address.rb +2 -2
- data/app/models/fe/email_template.rb +1 -1
- data/app/models/fe/page.rb +94 -19
- data/app/models/fe/page_element.rb +2 -2
- data/app/models/fe/paragraph.rb +1 -1
- data/app/models/fe/person.rb +5 -5
- data/app/models/fe/phone_number.rb +1 -1
- data/app/models/fe/question.rb +62 -38
- data/app/models/fe/question_grid.rb +15 -3
- data/app/models/fe/question_set.rb +53 -13
- data/app/models/fe/question_sheet.rb +49 -16
- data/app/models/fe/reference_question.rb +9 -3
- data/app/models/fe/reference_sheet.rb +102 -47
- data/app/models/fe/state_chooser.rb +2 -2
- data/app/models/fe/text_field.rb +2 -2
- data/app/models/fe/user.rb +1 -1
- data/app/models/staff.rb +6 -6
- data/app/views/fe/admin/elements/create.js.erb +3 -3
- data/app/views/fe/admin/elements/destroy.js.erb +1 -1
- data/app/views/fe/admin/elements/drop.js.erb +1 -1
- data/app/views/fe/admin/elements/duplicate.js.erb +1 -1
- data/app/views/fe/admin/elements/edit.js.erb +1 -1
- data/app/views/fe/admin/elements/error.js.erb +1 -1
- data/app/views/fe/admin/elements/new.js.erb +13 -6
- data/app/views/fe/admin/elements/update.js.erb +1 -1
- data/app/views/fe/admin/email_templates/_form.html.erb +3 -3
- data/app/views/fe/admin/email_templates/edit.html.erb +3 -3
- data/app/views/fe/admin/email_templates/index.html.erb +3 -3
- data/app/views/fe/admin/email_templates/new.html.erb +3 -3
- data/app/views/fe/admin/panels/_advanced_options.html.erb +8 -8
- data/app/views/fe/admin/panels/_common_boolean_fields.html.erb +1 -0
- data/app/views/fe/admin/panels/_common_boolean_fields_default.html.erb +11 -0
- data/app/views/fe/admin/panels/_common_fields.html.erb +2 -17
- data/app/views/fe/admin/panels/_condition.html.erb +1 -1
- data/app/views/fe/admin/panels/_insert.html.erb +25 -25
- data/app/views/fe/admin/panels/_nav_controls.html.erb +4 -4
- data/app/views/fe/admin/panels/_page.html.erb +1 -1
- data/app/views/fe/admin/panels/_pages_list.html.erb +3 -3
- data/app/views/fe/admin/panels/_prop_attachment_field.html.erb +2 -2
- data/app/views/fe/admin/panels/_prop_choice_field.html.erb +36 -17
- data/app/views/fe/admin/panels/_prop_date_field.html.erb +1 -1
- data/app/views/fe/admin/panels/_prop_element.html.erb +5 -5
- data/app/views/fe/admin/panels/_prop_page.html.erb +3 -3
- data/app/views/fe/admin/panels/_prop_paragraph.html.erb +8 -8
- data/app/views/fe/admin/panels/_prop_question_grid.html.erb +7 -2
- data/app/views/fe/admin/panels/_prop_question_grid_with_total.html.erb +2 -2
- data/app/views/fe/admin/panels/_prop_reference_question.html.erb +3 -3
- data/app/views/fe/admin/panels/_prop_section.html.erb +1 -1
- data/app/views/fe/admin/panels/_prop_sheet.html.erb +3 -3
- data/app/views/fe/admin/panels/_prop_text_field.html.erb +12 -12
- data/app/views/fe/admin/question_pages/_element.html.erb +7 -7
- data/app/views/fe/admin/question_pages/_element_show.html.erb +2 -2
- data/app/views/fe/admin/question_pages/_question_page.html.erb +4 -4
- data/app/views/fe/admin/question_pages/create.js.erb +3 -3
- data/app/views/fe/admin/question_pages/destroy.js.erb +3 -3
- data/app/views/fe/admin/question_pages/edit.js.erb +1 -1
- data/app/views/fe/admin/question_pages/error.js.erb +1 -1
- data/app/views/fe/admin/question_pages/show.js.erb +2 -2
- data/app/views/fe/admin/question_pages/show_panel.js.erb +1 -1
- data/app/views/fe/admin/question_pages/update.js.erb +1 -1
- data/app/views/fe/admin/question_sheets/edit.js.erb +1 -1
- data/app/views/fe/admin/question_sheets/error.js.erb +1 -1
- data/app/views/fe/admin/question_sheets/index.html.erb +8 -8
- data/app/views/fe/admin/question_sheets/new.html.erb +3 -3
- data/app/views/fe/admin/question_sheets/show.html.erb +5 -5
- data/app/views/fe/admin/question_sheets/update.js.erb +1 -1
- data/app/views/fe/answer_pages/_answer_page.html.erb +13 -14
- data/app/views/fe/answer_pages/_element.html.erb +22 -2
- data/app/views/fe/answer_pages/_page_name.html.erb +1 -1
- data/app/views/fe/answer_pages/show.html.erb +39 -0
- data/app/views/fe/answer_pages/update.js.erb +10 -2
- data/app/views/fe/answer_sheets/_answer_sheet.html.erb +4 -4
- data/app/views/fe/answer_sheets/_element.html.erb +9 -7
- data/app/views/fe/answer_sheets/_incomplete.html.erb +1 -1
- data/app/views/fe/answer_sheets/_page_link.html.erb +9 -7
- data/app/views/fe/answer_sheets/_pages_list.html.erb +3 -3
- data/app/views/fe/answer_sheets/_submit_to.html.erb +1 -1
- data/app/views/fe/answer_sheets/_title.html.erb +1 -1
- data/app/views/fe/answer_sheets/edit.html.erb +18 -18
- data/app/views/fe/answer_sheets/incomplete.js.erb +7 -4
- data/app/views/fe/answer_sheets/index.html.erb +1 -1
- data/app/views/fe/answer_sheets/show.html.erb +1 -1
- data/app/views/fe/applications/_logout.html.erb +1 -1
- data/app/views/fe/questions/fe/_acceptance.html.erb +10 -9
- data/app/views/fe/questions/fe/_attachment_field.html.erb +129 -10
- data/app/views/fe/questions/fe/_checkbox_field.html.erb +18 -16
- data/app/views/fe/questions/fe/_country.html.erb +6 -6
- data/app/views/fe/questions/fe/_date_field.html.erb +5 -4
- data/app/views/fe/questions/fe/_date_field_mmyy.html.erb +8 -8
- data/app/views/fe/questions/fe/_drop_down_field.html.erb +5 -5
- data/app/views/fe/questions/fe/_question_grid.html.erb +10 -10
- data/app/views/fe/questions/fe/_question_grid_with_total.html.erb +8 -8
- data/app/views/fe/questions/fe/_questions.html.erb +11 -5
- data/app/views/fe/questions/fe/_radio_button_field.html.erb +35 -19
- data/app/views/fe/questions/fe/_rating.html.erb +56 -18
- data/app/views/fe/questions/fe/_reference_discipler.html.erb +1 -1
- data/app/views/fe/questions/fe/_reference_friend.html.erb +1 -1
- data/app/views/fe/questions/fe/_reference_parent.html.erb +1 -1
- data/app/views/fe/questions/fe/_reference_peer.html.erb +1 -1
- data/app/views/fe/questions/fe/_reference_question.html.erb +40 -24
- data/app/views/fe/questions/fe/_reference_roommate.html.erb +1 -1
- data/app/views/fe/questions/fe/_reference_spiritual.html.erb +1 -1
- data/app/views/fe/questions/fe/_reference_staff.html.erb +1 -1
- data/app/views/fe/questions/fe/_state_chooser.html.erb +6 -6
- data/app/views/fe/questions/fe/_text_area_field.html.erb +14 -10
- data/app/views/fe/questions/fe/_text_field.html.erb +7 -6
- data/app/views/fe/questions/fe/_yes_no.html.erb +8 -8
- data/app/views/fe/questions/fe/_yes_no_field.erb +11 -8
- data/app/views/fe/reference_pages/_reference.html.erb +12 -12
- data/app/views/fe/reference_pages/edit.html.erb +4 -4
- data/app/views/fe/reference_sheets/done.html.erb +2 -2
- data/app/views/fe/reference_sheets/not_found.html.erb +3 -3
- data/app/views/fe/references/edit.html.erb +5 -5
- data/app/views/fe/references/show.html.erb +3 -3
- data/app/views/fe/references/submit.js.erb +3 -3
- data/app/views/fe/submit_pages/_thankyou.html.erb +1 -1
- data/app/views/fe/submit_pages/edit.html.erb +9 -9
- data/app/views/fe/submit_pages/error.js.erb +1 -1
- data/app/views/fe/submit_pages/submit.js.erb +2 -2
- data/app/views/layouts/fe/_error_messages_for.html.erb +1 -1
- data/app/views/layouts/fe/application.html.erb +3 -4
- data/app/views/layouts/fe/fe_admin.html.erb +30 -0
- data/app/views.current/fe/admin/elements/_errors.html.erb +11 -0
- data/app/views.current/fe/admin/elements/create.js.erb +12 -0
- data/app/views.current/fe/admin/elements/destroy.js.erb +4 -0
- data/app/views.current/fe/admin/elements/drop.js.erb +3 -0
- data/app/views.current/fe/admin/elements/duplicate.js.erb +3 -0
- data/app/views.current/fe/admin/elements/edit.js.erb +4 -0
- data/app/views.current/fe/admin/elements/error.js.erb +4 -0
- data/app/views.current/fe/admin/elements/new.js.erb +17 -0
- data/app/views.current/fe/admin/elements/update.js.erb +9 -0
- data/app/views.current/fe/admin/email_templates/_form.html.erb +8 -0
- data/app/views.current/fe/admin/email_templates/edit.html.erb +13 -0
- data/app/views.current/fe/admin/email_templates/index.html.erb +20 -0
- data/app/views.current/fe/admin/email_templates/new.html.erb +11 -0
- data/app/views.current/fe/admin/panels/_advanced_options.html.erb +49 -0
- data/app/views.current/fe/admin/panels/_common_boolean_fields.html.erb +1 -0
- data/app/views.current/fe/admin/panels/_common_boolean_fields_default.html.erb +11 -0
- data/app/views.current/fe/admin/panels/_common_fields.html.erb +23 -0
- data/app/views.current/fe/admin/panels/_condition.html.erb +6 -0
- data/app/views.current/fe/admin/panels/_insert.html.erb +39 -0
- data/app/views.current/fe/admin/panels/_nav_controls.html.erb +6 -0
- data/app/views.current/fe/admin/panels/_page.html.erb +3 -0
- data/app/views.current/fe/admin/panels/_pages_list.html.erb +16 -0
- data/app/views.current/fe/admin/panels/_prop_attachment_field.html.erb +2 -0
- data/app/views.current/fe/admin/panels/_prop_choice_field.html.erb +74 -0
- data/app/views.current/fe/admin/panels/_prop_date_field.html.erb +7 -0
- data/app/views.current/fe/admin/panels/_prop_element.html.erb +23 -0
- data/app/views.current/fe/admin/panels/_prop_page.html.erb +26 -0
- data/app/views.current/fe/admin/panels/_prop_paragraph.html.erb +46 -0
- data/app/views.current/fe/admin/panels/_prop_question_grid.html.erb +28 -0
- data/app/views.current/fe/admin/panels/_prop_question_grid_with_total.html.erb +14 -0
- data/app/views.current/fe/admin/panels/_prop_reference_question.html.erb +12 -0
- data/app/views.current/fe/admin/panels/_prop_section.html.erb +8 -0
- data/app/views.current/fe/admin/panels/_prop_sheet.html.erb +20 -0
- data/app/views.current/fe/admin/panels/_prop_text_field.html.erb +20 -0
- data/app/views.current/fe/admin/question_pages/_element.html.erb +28 -0
- data/app/views.current/fe/admin/question_pages/_element_show.html.erb +10 -0
- data/app/views.current/fe/admin/question_pages/_errors.html.erb +10 -0
- data/app/views.current/fe/admin/question_pages/_question_page.html.erb +13 -0
- data/app/views.current/fe/admin/question_pages/create.js.erb +11 -0
- data/app/views.current/fe/admin/question_pages/destroy.js.erb +5 -0
- data/app/views.current/fe/admin/question_pages/edit.js.erb +3 -0
- data/app/views.current/fe/admin/question_pages/error.js.erb +4 -0
- data/app/views.current/fe/admin/question_pages/show.js.erb +9 -0
- data/app/views.current/fe/admin/question_pages/show_panel.js.erb +3 -0
- data/app/views.current/fe/admin/question_pages/update.js.erb +2 -0
- data/app/views.current/fe/admin/question_sheets/_errors.html.erb +11 -0
- data/app/views.current/fe/admin/question_sheets/edit.js.erb +3 -0
- data/app/views.current/fe/admin/question_sheets/error.js.erb +5 -0
- data/app/views.current/fe/admin/question_sheets/index.html.erb +41 -0
- data/app/views.current/fe/admin/question_sheets/new.html.erb +15 -0
- data/app/views.current/fe/admin/question_sheets/show.html.erb +27 -0
- data/app/views.current/fe/admin/question_sheets/update.js.erb +2 -0
- data/app/views.current/fe/answer_pages/_answer_page.html.erb +53 -0
- data/app/views.current/fe/answer_pages/_element.html.erb +32 -0
- data/app/views.current/fe/answer_pages/_page_name.html.erb +1 -0
- data/app/views.current/fe/answer_pages/show.html.erb +39 -0
- data/app/views.current/fe/answer_pages/update.js.erb +13 -0
- data/app/views.current/fe/answer_sheets/_answer_sheet.html.erb +26 -0
- data/app/views.current/fe/answer_sheets/_element.html.erb +74 -0
- data/app/views.current/fe/answer_sheets/_incomplete.html.erb +10 -0
- data/app/views.current/fe/answer_sheets/_page_link.html.erb +9 -0
- data/app/views.current/fe/answer_sheets/_pages_list.html.erb +11 -0
- data/app/views.current/fe/answer_sheets/_submit_to.html.erb +1 -0
- data/app/views.current/fe/answer_sheets/_title.html.erb +1 -0
- data/app/views.current/fe/answer_sheets/edit.html.erb +66 -0
- data/app/views.current/fe/answer_sheets/incomplete.js.erb +11 -0
- data/app/views.current/fe/answer_sheets/index.html.erb +18 -0
- data/app/views.current/fe/answer_sheets/send_reference_invite.js.erb +8 -0
- data/app/views.current/fe/answer_sheets/show.html.erb +13 -0
- data/app/views.current/fe/applications/_logout.html.erb +1 -0
- data/app/views.current/fe/applications/show.html.erb +1 -0
- data/app/views.current/fe/help/builder.html +33 -0
- data/app/views.current/fe/help/question_grid.html +18 -0
- data/app/views.current/fe/questions/fe/_acceptance.html.erb +14 -0
- data/app/views.current/fe/questions/fe/_attachment_field.html.erb +165 -0
- data/app/views.current/fe/questions/fe/_checkbox_field.html.erb +53 -0
- data/app/views.current/fe/questions/fe/_country.html.erb +7 -0
- data/app/views.current/fe/questions/fe/_date_field.html.erb +7 -0
- data/app/views.current/fe/questions/fe/_date_field_mmyy.html.erb +9 -0
- data/app/views.current/fe/questions/fe/_drop_down_field.html.erb +8 -0
- data/app/views.current/fe/questions/fe/_paragraph.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_question_grid.html.erb +70 -0
- data/app/views.current/fe/questions/fe/_question_grid_with_total.html.erb +64 -0
- data/app/views.current/fe/questions/fe/_questions.html.erb +15 -0
- data/app/views.current/fe/questions/fe/_radio_button_field.html.erb +60 -0
- data/app/views.current/fe/questions/fe/_rating.html.erb +64 -0
- data/app/views.current/fe/questions/fe/_reference_discipler.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_reference_friend.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_reference_parent.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_reference_peer.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_reference_question.html.erb +61 -0
- data/app/views.current/fe/questions/fe/_reference_roommate.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_reference_spiritual.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_reference_staff.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_section.html.erb +1 -0
- data/app/views.current/fe/questions/fe/_state_chooser.html.erb +7 -0
- data/app/views.current/fe/questions/fe/_text_area_field.html.erb +17 -0
- data/app/views.current/fe/questions/fe/_text_field.html.erb +9 -0
- data/app/views.current/fe/questions/fe/_yes_no.html.erb +17 -0
- data/app/views.current/fe/questions/fe/_yes_no_field.erb +20 -0
- data/app/views.current/fe/reference_pages/_reference.html.erb +31 -0
- data/app/views.current/fe/reference_pages/edit.html.erb +24 -0
- data/app/views.current/fe/reference_sheets/done.html.erb +2 -0
- data/app/views.current/fe/reference_sheets/not_found.html.erb +5 -0
- data/app/views.current/fe/reference_sheets/submitted.js.erb +1 -0
- data/app/views.current/fe/references/edit.html.erb +8 -0
- data/app/views.current/fe/references/send_invite.js.erb +7 -0
- data/app/views.current/fe/references/show.html.erb +18 -0
- data/app/views.current/fe/references/submit.js.erb +3 -0
- data/app/views.current/fe/submit_pages/_errors.html.erb +1 -0
- data/app/views.current/fe/submit_pages/_thankyou.html.erb +2 -0
- data/app/views.current/fe/submit_pages/edit.html.erb +36 -0
- data/app/views.current/fe/submit_pages/error.js.erb +1 -0
- data/app/views.current/fe/submit_pages/submit.js.erb +3 -0
- data/app/views.current/layouts/fe/_error_messages_for.html.erb +7 -0
- data/app/views.current/layouts/fe/application.html.erb +47 -0
- data/app/{views/layouts/fe/fe.admin.html.erb → views.current/layouts/fe/fe_admin.html.erb} +4 -4
- data/config/initializers/paper_trail.rb +3 -0
- data/config/routes.rb +3 -1
- data/db/migrate/20131003041856_core.rb +23 -23
- data/db/migrate/20131003044250_create_reference_sheets.rb +1 -1
- data/db/migrate/20131003044436_add_element_and_answer_fields.rb +3 -3
- data/db/migrate/20131003044518_create_email_templates.rb +2 -2
- data/db/migrate/20131003044621_add_max_lengths.rb +1 -1
- data/db/migrate/20131003044714_create_join_table.rb +1 -1
- data/db/migrate/20131016162128_remove_question_id_from_element.rb +1 -1
- data/db/migrate/20140623153424_create_fe_people.rb +1 -1
- data/db/migrate/20140624180246_create_fe_addresses.rb +1 -1
- data/db/migrate/20140624182216_create_fe_phone_numbers.rb +1 -1
- data/db/migrate/20140625160545_create_fe_users.rb +1 -1
- data/db/migrate/20140808202507_add_conditional_type_to_elements.rb +1 -1
- data/db/migrate/20140808203609_add_conditional_answer_to_elements.rb +1 -1
- data/db/migrate/20141103204704_remove_short_value_column.rb +1 -1
- data/db/migrate/20141109154522_move_conditional_ids_used_for_choice_field_to_their_own_column.rb +1 -1
- data/db/migrate/20150504221439_add_all_element_ids_to_pages.rb +1 -1
- data/db/migrate/20150713022326_add_locale_columns.rb +1 -1
- data/db/migrate/20150714220730_add_locale_to_answer_sheet.rb +1 -1
- data/db/migrate/20150925181652_add_share_to_elements.rb +5 -0
- data/db/migrate/20150928085325_change_pages_all_element_ids_to_text.rb +1 -1
- data/db/migrate/20150930191538_add_locale_to_reference_sheets.rb +1 -1
- data/db/migrate/20151021181928_switch_conditional_answer_separator_to_semicolon.rb +7 -0
- data/db/migrate/20151021184250_add_question_sheet_id_in_refs.rb +12 -0
- data/db/migrate/20160201185838_add_visible_and_visibility_cache_key_to_reference_sheets.rb +6 -0
- data/db/migrate/20160805221415_add_rating_extra_labels.rb +10 -0
- data/db/migrate/20181108201746_create_versions.rb +80 -0
- data/db/migrate/20181218201130_increase_slug_length.rb +5 -0
- data/lib/fe/engine.rb +10 -10
- data/lib/fe/version.rb +1 -1
- data/lib/fe.rb +7 -1
- data/spec/controllers/fe/admin/elements_controller_spec.rb +30 -20
- data/spec/controllers/fe/admin/email_templates_controller_spec.rb +2 -2
- data/spec/controllers/fe/admin/question_pages_controller_spec.rb +1 -1
- data/spec/controllers/fe/admin/question_sheets_controller_spec.rb +4 -4
- data/spec/controllers/fe/answer_pages_controller_spec.rb +86 -30
- data/spec/controllers/fe/answer_sheets_controller_spec.rb +65 -9
- data/spec/dummy/app/assets/config/manifest.js +0 -0
- data/spec/dummy/app/models/user.rb +1 -1
- data/spec/dummy/app/views/layouts/application.html.erb +2 -2
- data/spec/dummy/config/application.rb +1 -0
- data/spec/dummy/config/environments/test.rb +3 -3
- data/spec/dummy/config/initializers/assets.rb +5 -2
- data/spec/dummy/config/initializers/fast_gettext.rb +1 -1
- data/spec/dummy/config/initializers/to_unsafe_h.rb +5 -0
- data/spec/dummy/config/initializers/to_unsafe_h.rb.new +5 -0
- data/spec/dummy/db/migrate/20141203214017_core.fe_engine.rb +23 -23
- data/spec/dummy/db/migrate/20141203214018_create_reference_sheets.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214019_add_element_and_answer_fields.fe_engine.rb +3 -3
- data/spec/dummy/db/migrate/20141203214020_create_email_templates.fe_engine.rb +2 -2
- data/spec/dummy/db/migrate/20141203214021_add_max_lengths.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214022_create_join_table.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214023_remove_question_id_from_element.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214024_create_fe_people.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214025_create_fe_addresses.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214027_create_fe_users.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214028_add_conditional_type_to_elements.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214029_add_conditional_answer_to_elements.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214030_remove_short_value_column.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20141203214031_move_conditional_ids_used_for_choice_field_to_their_own_column.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20150123215803_create_users.rb +1 -1
- data/spec/dummy/db/migrate/20150504222619_add_all_element_ids_to_pages.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20150925192557_add_share_to_elements.fe_engine.rb +6 -0
- data/spec/dummy/db/migrate/20150930190001_create_fe_phone_numbers.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20150930190002_add_locale_columns.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20150930190003_add_locale_to_answer_sheet.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20150930190004_change_pages_all_element_ids_to_text.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20150930191756_add_locale_to_reference_sheets.fe_engine.rb +1 -1
- data/spec/dummy/db/migrate/20151021190027_add_question_sheet_id_in_refs.fe_engine.rb +13 -0
- data/spec/dummy/db/migrate/20160204164612_switch_conditional_answer_separator_to_semicolon.fe_engine.rb +8 -0
- data/spec/dummy/db/migrate/20160204164613_add_visible_and_visibility_cache_key_to_reference_sheets.fe_engine.rb +7 -0
- data/spec/dummy/db/migrate/20181108201746_create_versions.rb +80 -0
- data/spec/dummy/db/schema.rb +71 -79
- data/spec/dummy/log/test.log +101278 -419
- data/spec/factories/answer_sheet_question_sheets.rb +1 -1
- data/spec/factories/answer_sheets.rb +2 -2
- data/spec/factories/answers.rb +1 -1
- data/spec/factories/applications.rb +3 -3
- data/spec/factories/dummy_applications.rb +3 -3
- data/spec/factories/dummy_people.rb +3 -3
- data/spec/factories/dummy_users.rb +3 -3
- data/spec/factories/elements.rb +21 -21
- data/spec/factories/email_templates.rb +3 -3
- data/spec/factories/fe_addresses.rb +10 -10
- data/spec/factories/fe_email_addresses.rb +3 -3
- data/spec/factories/fe_email_templates.rb +4 -4
- data/spec/factories/fe_people.rb +5 -5
- data/spec/factories/fe_phone_numbers.rb +3 -3
- data/spec/factories/fe_user.rb +3 -3
- data/spec/factories/page.rb +1 -1
- data/spec/factories/page_elements.rb +1 -1
- data/spec/factories/paragraphs.rb +1 -1
- data/spec/factories/question_sheet.rb +2 -2
- data/spec/factories/reference_questions.rb +1 -1
- data/spec/factories/reference_sheets.rb +1 -1
- data/spec/jobs/fe/update_reference_sheet_visibility_job_spec.rb +40 -0
- data/spec/models/fe/answer_sheet_question_sheet_spec.rb +1 -1
- data/spec/models/fe/answer_spec.rb +2 -2
- data/spec/models/fe/application_spec.rb +94 -1
- data/spec/models/fe/choice_field_spec.rb +47 -1
- data/spec/models/fe/condition_spec.rb +2 -2
- data/spec/models/fe/element_spec.rb +252 -60
- data/spec/models/fe/email_template_spec.rb +1 -1
- data/spec/models/fe/page_element_spec.rb +1 -1
- data/spec/models/fe/page_spec.rb +57 -12
- data/spec/models/fe/person_spec.rb +1 -1
- data/spec/models/fe/question_set_spec.rb +91 -0
- data/spec/models/fe/question_sheet_spec.rb +11 -15
- data/spec/models/fe/question_spec.rb +73 -6
- data/spec/models/fe/reference_question_spec.rb +20 -0
- data/spec/models/fe/reference_sheet_spec.rb +287 -4
- data/spec/models/fe/text_field_spec.rb +22 -0
- data/spec/rails_helper.rb +79 -76
- metadata +195 -57
- data/app/assets/javascripts/fe/jquery.scrollTo-min.js +0 -7
- data/app/controllers/fe/concerns/answer_pages_controller_concern.rb +0 -84
- data/app/models/fe/concerns/answer_sheet_concern.rb +0 -85
- data/spec/dummy/db/migrate/20141203214026_create_create_fe_phone_numbers.fe_engine.rb +0 -17
- data/spec/dummy/log/development.log +0 -5
- /data/app/{assets/stylesheets/360front.css → views.current/fe/admin/elements/reorder.js.erb} +0 -0
@@ -0,0 +1,165 @@
|
|
1
|
+
<% element_id = attachment_field.id; base_element = "#element_#{element_id}" %>
|
2
|
+
|
3
|
+
<% if @presenter %>
|
4
|
+
<% answer = attachment_field.responses(@answer_sheet).first %>
|
5
|
+
<% if @answer_sheet&.frozen? && !@answer_sheet&.reference? %>
|
6
|
+
<% if answer %>
|
7
|
+
Current File: <%= link_to(answer.attachment.filename, url_for(answer.attachment)) %>
|
8
|
+
<%= link_to(image_tag("fe/icons/minus-button.png"),
|
9
|
+
delete_file_fe_answer_sheet_page_path(@presenter.active_answer_sheet, @page, question_id: element_id, answer_sheet_type: @answer_sheet.class.name),
|
10
|
+
method: :delete, remote: true) %>
|
11
|
+
<% end %>
|
12
|
+
<% else %>
|
13
|
+
<div class="legacy_uploader" style="display: none">
|
14
|
+
<div class="uploader">
|
15
|
+
<input <% if Fe.bootstrap %>class="form-control"<% end %> id="<%= dom_id(attachment_field) %>_file_uploader" name="image_uploader" type="file" />
|
16
|
+
|
17
|
+
<span id="<%= dom_id(attachment_field) %>_filename">
|
18
|
+
<% answer = attachment_field.sheet_answers.where(answer_sheet: @answer_sheet).first # using responses method doesn't work because it filters out value nil, but on attachments value will be nil
|
19
|
+
if answer&.attachment&.attached? %>
|
20
|
+
Current File: <%= link_to(answer.attachment.filename, url_for(answer.attachment)) %>
|
21
|
+
<%= link_to(image_tag('fe/icons/minus-button.png'),
|
22
|
+
delete_file_fe_answer_sheet_page_path(@presenter.active_answer_sheet, @page, question_id: element_id, answer_sheet_type: @answer_sheet.class.name),
|
23
|
+
method: :delete, remote: true) %>
|
24
|
+
<% end %>
|
25
|
+
</span>
|
26
|
+
</div>
|
27
|
+
|
28
|
+
<script type="text/javascript" charset="utf-8">
|
29
|
+
<% session_key_name = Rails.application.config.session_options[:key] %>
|
30
|
+
$('#<%= dom_id(attachment_field) %>_file_uploader').uploadify({
|
31
|
+
uploader : '<%= asset_path "fe/uploadify/uploadify.swf" %>',
|
32
|
+
script : '<%= save_file_fe_answer_sheet_page_path(@presenter.active_answer_sheet, @page, question_id: element_id, answer_sheet_type: @answer_sheet.class.name) %>',
|
33
|
+
fileDesc : 'Pick a file',
|
34
|
+
fileExt : '<%= attachment_field.content || "*.*" %>',
|
35
|
+
auto : true,
|
36
|
+
sizeLimit : <%= 100.megabytes %>,
|
37
|
+
width : 350,
|
38
|
+
height : 30,
|
39
|
+
multi : true,
|
40
|
+
simUploadLimit : 2,
|
41
|
+
method : 'POST',
|
42
|
+
cancelImg : '<%= asset_path "fe/uploadify/cancel.png" %>',
|
43
|
+
onComplete : function(a, b, c, response){ eval(response); },
|
44
|
+
buttonText : 'Attach a file',
|
45
|
+
scriptData : {
|
46
|
+
'_http_accept': 'application/javascript',
|
47
|
+
'_method': 'post',
|
48
|
+
'<%= session_key_name %>' : encodeURIComponent('<%= u cookies[session_key_name] %>'),
|
49
|
+
'authenticity_token': encodeURIComponent('<%= u form_authenticity_token %>'),
|
50
|
+
'answer_sheet_type': answer_sheet_type
|
51
|
+
}
|
52
|
+
});
|
53
|
+
</script>
|
54
|
+
</div>
|
55
|
+
|
56
|
+
<div class="new_uploader">
|
57
|
+
|
58
|
+
<% if answer&.attachment&.attached? %>
|
59
|
+
Current File: <%= link_to(answer.attachment.filename, url_for(answer.attachment)) %>
|
60
|
+
<%= link_to(image_tag("fe/icons/minus-button.png"),
|
61
|
+
delete_file_fe_answer_sheet_page_path(@presenter.active_answer_sheet, @page, question_id: element_id, answer_sheet_type: @answer_sheet.class.name),
|
62
|
+
method: :delete, remote: true, class: 'remove_current') %>
|
63
|
+
<script>
|
64
|
+
$('<%= base_element %> .remove_current').click(function() {
|
65
|
+
$.ajax({
|
66
|
+
type: 'DELETE',
|
67
|
+
url: '<%= delete_file_fe_answer_sheet_page_path(@presenter.active_answer_sheet, @page, question_id: element_id, answer_sheet_type: @answer_sheet.class.name) %>',
|
68
|
+
success: function(result) {
|
69
|
+
$.get("/fe/answer_sheets/<%= @answer_sheet.id %>/page/<%= @page.id %>/edit?answer_sheet_type=<%= @answer_sheet.class.name %>", function(data) {
|
70
|
+
$('<%= base_element %>').replaceWith($(data).find('<%= base_element %>'))
|
71
|
+
});
|
72
|
+
}
|
73
|
+
});
|
74
|
+
return false;
|
75
|
+
});
|
76
|
+
</script>
|
77
|
+
<% else %>
|
78
|
+
|
79
|
+
<style>
|
80
|
+
.drop_area.file_hover {
|
81
|
+
background:red;
|
82
|
+
}
|
83
|
+
|
84
|
+
</style>
|
85
|
+
|
86
|
+
<input type="file" class="upload_field" <% if attachment_field.content %>accept="<%= attachment_field.content %>"<% end %>/>
|
87
|
+
<div class="drop_area" style="margin:20px 0; width:300px; padding:20px; border:1px dashed black;">or drop a file here</div>
|
88
|
+
<div class="progress_report">
|
89
|
+
<div class="progress_report_name"></div>
|
90
|
+
<div class="progress_report_status" style="font-style: italic;"></div>
|
91
|
+
<div class="progress_report_bar_container" style="width: 90%; height: 5px;">
|
92
|
+
<div class="progress_report_bar" style="background-color: blue; width: 0; height: 100%;"></div>
|
93
|
+
</div>
|
94
|
+
<br/>
|
95
|
+
</div>
|
96
|
+
<script type="text/javascript">
|
97
|
+
$(function() {
|
98
|
+
|
99
|
+
var $input = $("<%= base_element %> .upload_field").html5_upload({
|
100
|
+
url: function(number) {
|
101
|
+
return "<%= save_file_fe_answer_sheet_page_path(@presenter.active_answer_sheet, @page, question_id: element_id, answer_sheet_type: @answer_sheet.class.name) %>";
|
102
|
+
},
|
103
|
+
sendBoundary: window.FormData || $.browser.mozilla,
|
104
|
+
onStart: function(event, total) {
|
105
|
+
return true;
|
106
|
+
return confirm("You are trying to upload " + total + " files. Are you sure?");
|
107
|
+
},
|
108
|
+
onProgress: function(event, progress, name, number, total) {
|
109
|
+
console.log(progress, number);
|
110
|
+
},
|
111
|
+
setName: function(text) {
|
112
|
+
$("#element_<%= attachment_field.id %> .progress_report_name").text(text);
|
113
|
+
},
|
114
|
+
setStatus: function(text) {
|
115
|
+
if (!$("<%= base_element %> .upload_field").data('error', true)) {
|
116
|
+
$("<%= base_element %> .progress_report_status").text(text);
|
117
|
+
}
|
118
|
+
},
|
119
|
+
setProgress: function(val) {
|
120
|
+
$("<%= base_element %> .progress_report_bar").css('width', Math.ceil(val*100)+"%");
|
121
|
+
},
|
122
|
+
onFinishOne: function(event, response, name, number, total) {
|
123
|
+
// Re-render the attachment file to show the current file; use the page view, which is not the
|
124
|
+
// most efficient way, but lets us avoid making an action just for this. And the amount of data
|
125
|
+
// on a page is not that much
|
126
|
+
$.get("/fe/answer_sheets/<%= @answer_sheet.id %>/page/<%= @page.id %>/edit?answer_sheet_type=<%= @answer_sheet.class.name %>", function(data) {
|
127
|
+
$('<%= base_element %>').replaceWith($(data).find('<%= base_element %>'))
|
128
|
+
});
|
129
|
+
},
|
130
|
+
onError: function(event, name, error) {
|
131
|
+
$("<%= base_element %> .upload_field").data('error', true)
|
132
|
+
$('<%= base_element %> .progress_report_status').text('Error while uploading file ' + name)
|
133
|
+
}, onBrowserIncompatible: function() {
|
134
|
+
$("<%= base_element %> .legacy_uploader").show();
|
135
|
+
$("<%= base_element %> .new_uploader").hide();
|
136
|
+
},
|
137
|
+
});
|
138
|
+
|
139
|
+
// this is absolutely necessary -- see http://weblog.bocoup.com/using-datatransfer-with-jquery-events/
|
140
|
+
if ($.fn.jquery.substring(0, 2) == "3.") {
|
141
|
+
$.event.addProp('dataTransfer');
|
142
|
+
} else {
|
143
|
+
$.event.props.push('dataTransfer');
|
144
|
+
}
|
145
|
+
|
146
|
+
var $drop = $('<%= base_element %> .drop_area');
|
147
|
+
$drop.on('dragover dragenter', function(e) {
|
148
|
+
$drop.addClass('file_hover');
|
149
|
+
return false;
|
150
|
+
}).on('dragleave dragexit', function(e) {
|
151
|
+
$drop.removeClass('file_hover');
|
152
|
+
return false;
|
153
|
+
}).on( 'drop', function(e) {
|
154
|
+
if(e.originalEvent.dataTransfer && e.originalEvent.dataTransfer.files.length) {
|
155
|
+
$input.trigger('html5_upload.startFromDrop', e );
|
156
|
+
}
|
157
|
+
return false;
|
158
|
+
})
|
159
|
+
|
160
|
+
});
|
161
|
+
</script>
|
162
|
+
</div>
|
163
|
+
<% end %>
|
164
|
+
<% end %>
|
165
|
+
<% end %>
|
@@ -0,0 +1,53 @@
|
|
1
|
+
<% if checkbox_field.hide_option_labels? && !["question_pages", "question_sheets", "elements"].include?(controller.controller_name) %>
|
2
|
+
<tr id="<%= dom_id(checkbox_field) %>">
|
3
|
+
<td>
|
4
|
+
<label for="<%= dom_id(checkbox_field) %>" class="desc">
|
5
|
+
<%= raw checkbox_field.label(session[:locale]) %>
|
6
|
+
<% if checkbox_field.required?(@answer_sheet, @page) -%><span class="required">required</span><% end -%>
|
7
|
+
<%= tip(checkbox_field.tooltip) if checkbox_field.tooltip.present? %>
|
8
|
+
</label>
|
9
|
+
</td>
|
10
|
+
<% choices = checkbox_field.choices(session[:locale]) %>
|
11
|
+
<% choices.each_with_index do |choice, num| -%>
|
12
|
+
<td>
|
13
|
+
<% css_class = checkbox_field.css_class.to_s + " checkbox " -%>
|
14
|
+
<% dom_id = dom_id(checkbox_field) + "_" + pretty_tag(choice[1])
|
15
|
+
last_choice = (num == choices.length - 1)
|
16
|
+
css_class += checkbox_field.validation_class(@answer_sheet, @page) if last_choice
|
17
|
+
locked = checkbox_field.locked?(params, @answer_sheet, @presenter, current_person)
|
18
|
+
%>
|
19
|
+
<%= hidden_field_tag "answers[#{checkbox_field.id}][#{num}]", "", id: "" %>
|
20
|
+
<div class="field field_check">
|
21
|
+
<%= check_box_tag "answers[#{checkbox_field.id}][#{num}]", choice[1],
|
22
|
+
checkbox_field.has_answer?(choice[1], @answer_sheet),
|
23
|
+
id: dom_id,
|
24
|
+
class: css_class,
|
25
|
+
disabled: locked,
|
26
|
+
readonly: locked %>
|
27
|
+
</div>
|
28
|
+
</td>
|
29
|
+
<% end -%>
|
30
|
+
</tr>
|
31
|
+
<% else %>
|
32
|
+
<div id="<%= dom_id(checkbox_field) %>">
|
33
|
+
<% css_class = checkbox_field.css_class.to_s + " checkbox " -%>
|
34
|
+
<% choices = checkbox_field.choices(session[:locale]) %>
|
35
|
+
<% choices.each_with_index do |choice, num| -%>
|
36
|
+
<% dom_id = dom_id(checkbox_field) + "_" + pretty_tag(choice[1])
|
37
|
+
last_choice = (num == choices.length - 1)
|
38
|
+
css_class += checkbox_field.validation_class(@answer_sheet, @page) if last_choice
|
39
|
+
locked = checkbox_field.locked?(params, @answer_sheet, @presenter, current_person)
|
40
|
+
%>
|
41
|
+
<%= hidden_field_tag "answers[#{checkbox_field.id}][#{num}]", "", id: "" %>
|
42
|
+
<div class="field field_check">
|
43
|
+
<%= check_box_tag "answers[#{checkbox_field.id}][#{num}]", choice[1],
|
44
|
+
checkbox_field.has_answer?(choice[1], @answer_sheet),
|
45
|
+
id: dom_id,
|
46
|
+
class: css_class,
|
47
|
+
disabled: locked,
|
48
|
+
readonly: locked %>
|
49
|
+
<label class="choice" for="<%= dom_id %>"><%= choice[0] %></label>
|
50
|
+
</div>
|
51
|
+
<% end -%>
|
52
|
+
</div>
|
53
|
+
<% end %>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<% locked = country.locked?(params, @answer_sheet, @presenter, current_person) %>
|
2
|
+
<%= select_tag "answers[#{country.id}]",
|
3
|
+
options_for_select([""] + Carmen.countries, country.response(@answer_sheet).to_s),
|
4
|
+
class: "#{"form-control" if Fe.bootstrap} select " + country.validation_class(@answer_sheet, @page),
|
5
|
+
id: dom_id(country),
|
6
|
+
disabled: locked,
|
7
|
+
readonly: locked %>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<% locked = date_field.locked?(params, @answer_sheet, @presenter, current_person) %>
|
2
|
+
<%= calendar_date_select_tag "answers[#{date_field.id}]", date_field.format_date_response(@answer_sheet),
|
3
|
+
class: "#{"form-control" if Fe.bootstrap} text " + date_field.validation_class(@answer_sheet, @page),
|
4
|
+
id: dom_id(date_field),
|
5
|
+
disabled: locked,
|
6
|
+
readonly: true %>
|
7
|
+
<div id="advice-required-<%= dom_id(date_field) %>" class="validation-advice" style="display: none;">This is a required field.</div>
|
@@ -0,0 +1,9 @@
|
|
1
|
+
<%= select_month(date_field_mmyy.response(@answer_sheet), include_blank: true,
|
2
|
+
prefix: "answers[#{date_field_mmyy.id}]",
|
3
|
+
class: "#{"form-control" if Fe.bootstrap} select " + date_field_mmyy.validation_class(@answer_sheet, @page)) %>
|
4
|
+
<%= select_year(date_field_mmyy.response(@answer_sheet), include_blank: true,
|
5
|
+
start_year: Time.now.year - 50, end_year: Time.now.year + 7,
|
6
|
+
prefix: "answers[#{date_field_mmyy.id}]",
|
7
|
+
class: "select " + date_field_mmyy.validation_class(@answer_sheet, @page)) %>
|
8
|
+
|
9
|
+
<% # not validated because class doesn"t pass, see ticket #6000 -%>
|
@@ -0,0 +1,8 @@
|
|
1
|
+
<% choices = drop_down_field.choices(session[:locale]) %>
|
2
|
+
<% locked = drop_down_field.locked?(params, @answer_sheet, @presenter, current_person) %>
|
3
|
+
<%= select_tag "answers[#{drop_down_field.id}]",
|
4
|
+
options_for_select([""] + choices, drop_down_field.response(@answer_sheet).to_s),
|
5
|
+
class: "form-control select " + drop_down_field.validation_class(@answer_sheet, @page) + " #{drop_down_field.css_class}",
|
6
|
+
id: dom_id(drop_down_field),
|
7
|
+
disabled: locked,
|
8
|
+
readonly: locked %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<div class="p_content <%= paragraph.css_class %>"><%= raw paragraph.content(session[:locale]) %></div>
|
@@ -0,0 +1,70 @@
|
|
1
|
+
<%- if ["question_pages", "question_sheets", "elements"].include?(controller.controller_name) -%>
|
2
|
+
<div class="droppable" data-url="<%= drop_fe_admin_question_sheet_page_element_path(@page.question_sheet_id, @page.id, question_grid.id) %>">
|
3
|
+
<% if question_grid.label.present? && !question_grid.hide_label? -%>
|
4
|
+
<label class="desc gridname">
|
5
|
+
<%= raw question_grid.label(session[:locale]) %>
|
6
|
+
<% if question_grid.required?(@answer_sheet, @page) -%><span class="required">required</span><% end -%>
|
7
|
+
</label>
|
8
|
+
<% end %>
|
9
|
+
<div class="sub_q">
|
10
|
+
<!-- Create a sortable list for each grid on the page -->
|
11
|
+
<ul class="questions" id="questions_list_<%= question_grid.id %>" data-sortable="true" data-sortable-url="<%= reorder_fe_admin_question_sheet_page_elements_path(@page.question_sheet_id, @page.id) %>" data-sortable-handle=".handle">
|
12
|
+
<%- if question_grid.elements.length > 0 -%>
|
13
|
+
<%= render partial: "fe/admin/question_pages/element", collection: question_grid.elements, locals: {in_grid: true} %>
|
14
|
+
<%- else -%>
|
15
|
+
Grid
|
16
|
+
<%- end -%>
|
17
|
+
</ul>
|
18
|
+
</div>
|
19
|
+
</div>
|
20
|
+
<%- else -%>
|
21
|
+
<% if question_grid.label.present? && !question_grid.hide_label? -%>
|
22
|
+
<label class="desc gridname"><%= raw question_grid.label(session[:locale]) %></label>
|
23
|
+
<% end %>
|
24
|
+
<% headers = question_grid.cols.to_s.split(";") %>
|
25
|
+
<% if headers.length > 1 %>
|
26
|
+
<table class="grid <%= question_grid.css_class %>" id="<%= question_grid.css_id %>">
|
27
|
+
<% if headers.detect {|h| h.strip.present?} %>
|
28
|
+
<tr>
|
29
|
+
<%- headers.each do |header| -%>
|
30
|
+
<th><%= raw header || " " %></th>
|
31
|
+
<%- end -%>
|
32
|
+
</tr>
|
33
|
+
<% end %>
|
34
|
+
<% if question_grid.style == "radio" %>
|
35
|
+
<% question_grid.elements.each do |element| -%>
|
36
|
+
<%= render partial: "fe/answer_pages/element", object: element %>
|
37
|
+
<% end %>
|
38
|
+
<% else %>
|
39
|
+
<tr >
|
40
|
+
<%- col_count = 0; previous_element = nil;
|
41
|
+
question_grid.elements.each do |element| -%>
|
42
|
+
<td style="<%= "display:none" if previous_element && previous_element.conditional == element && !previous_element.conditional_match(@answer_sheet) %>" class="hidecell <%= element.class.to_s.downcase.gsub("::","_") %> <%= element.style.to_s.downcase %> <%= "conditional" if element.conditional %>" id="element_<%= element.id %>" <% if element.conditional %>data-conditional_id="<%= element.conditional_id %>" data-conditional_type="<%= element.conditional_type %>" data-conditional_answer="<%= element.conditional_answer %>" data-application_id="<%= @answer_sheet.id %>" data-answer_sheet_id_prefix="<%= @answer_sheet.class.name.underscore.gsub("/","_") %>"<% end %>>
|
43
|
+
<%# grid_el = @elements.to_a.find {|el| el.id == element.id} %>
|
44
|
+
<%= render partial: "fe/answer_pages/element", object: element, locals: {col: col_count} %>
|
45
|
+
</td>
|
46
|
+
<%- previous_element = element;
|
47
|
+
col_count += 1
|
48
|
+
if col_count % question_grid.num_cols == 0 && element != question_grid.elements.last then col_count = 0 -%></tr><tr><%- end -%>
|
49
|
+
<%- end -%>
|
50
|
+
<%- while col_count < question_grid.num_cols do
|
51
|
+
col_count += 1-%>
|
52
|
+
<td> </td>
|
53
|
+
<%- end unless col_count == 0-%>
|
54
|
+
</tr>
|
55
|
+
<% end %>
|
56
|
+
</table>
|
57
|
+
<% else %>
|
58
|
+
<% if headers[0].to_s.strip.present? %>
|
59
|
+
<div class="header"><%= headers[0] %></div>
|
60
|
+
<% end %>
|
61
|
+
<% previous_element = nil %>
|
62
|
+
<% question_grid.elements.each do |element| -%>
|
63
|
+
<div style="<%= "display:none" if previous_element && previous_element.conditional == element && !previous_element.conditional_match(@answer_sheet) %>" class="<%= "row" unless Fe.bootstrap %> <%= element.class.to_s.downcase.gsub("::","_") %> <%= element.style.to_s.downcase %> <%= "conditional" if element.conditional %>" id="element_<%= element.id %>" <% if element.conditional %>data-conditional_id="<%= element.conditional_id %>" data-conditional_type="<%= element.conditional_type %>" data-conditional_answer="<%= element.conditional_answer %>" data-application_id="<%= @answer_sheet.id %>" data-answer_sheet_id_prefix="<%= @answer_sheet.class.name.underscore.gsub("/","_") %>"<% end %>>
|
64
|
+
<%= render partial: "fe/answer_pages/element", object: element, locals: {in_grid: true} %>
|
65
|
+
</div>
|
66
|
+
<% previous_element = element %>
|
67
|
+
<% end %>
|
68
|
+
<div class="clear"></div>
|
69
|
+
<% end %>
|
70
|
+
<%- end -%>
|
@@ -0,0 +1,64 @@
|
|
1
|
+
<%- if ["question_pages", "question_sheets", "elements"].include?(controller.controller_name) -%>
|
2
|
+
<div class="droppable" data-url="<%= drop_fe_admin_question_sheet_page_element_path(@page.question_sheet_id, @page.id, question_grid_with_total.id) %>">
|
3
|
+
<label class="desc"><%= raw question_grid_with_total.label(session[:locale]) %></label>
|
4
|
+
<div>
|
5
|
+
<ul class="questions" id="questions_list_<%= question_grid_with_total.id %>" data-sortable="true" data-sortable-url="<%= reorder_fe_admin_question_sheet_page_elements_path(@page.question_sheet_id, @page.id) %>" data-sortable-handle=".handle">
|
6
|
+
<%- if question_grid_with_total.elements.length > 0 -%>
|
7
|
+
<%= render partial: "fe/admin/question_pages/element", collection: question_grid_with_total.elements, locals: {in_grid: true} %>
|
8
|
+
<%- else -%>
|
9
|
+
Grid
|
10
|
+
<%- end -%>
|
11
|
+
</ul>
|
12
|
+
</div>
|
13
|
+
</div>
|
14
|
+
<%- else -%>
|
15
|
+
<label class="desc"><%= raw question_grid_with_total.label(session[:locale]) %></label>
|
16
|
+
<table class="grid with_total">
|
17
|
+
<% headers = question_grid_with_total.cols.to_s.split(";") %>
|
18
|
+
<% if headers.detect {|h| h.strip.present?} %>
|
19
|
+
<tr>
|
20
|
+
<%- headers.each do |header| -%>
|
21
|
+
<th><%= header || " " %></th>
|
22
|
+
<%- end -%>
|
23
|
+
</tr>
|
24
|
+
<% end %>
|
25
|
+
<tr>
|
26
|
+
<%- col_count = 0
|
27
|
+
question_grid_with_total.elements.each do |element| -%>
|
28
|
+
<td id="element_<%= element.id %>">
|
29
|
+
<%# grid_el = @elements.to_a.find {|el| el.id == element.id} %>
|
30
|
+
<% col_count = col_count % question_grid_with_total.num_cols unless Fe.bootstrap %>
|
31
|
+
<%= render partial: "fe/answer_pages/element", object: element, locals: {in_grid: true, col: col_count} %>
|
32
|
+
</td>
|
33
|
+
<%- col_count += 1
|
34
|
+
if col_count % question_grid_with_total.num_cols == 0 && element != question_grid_with_total.elements.last then col_count = 0 -%></tr><tr><%- end -%>
|
35
|
+
<%- end -%>
|
36
|
+
<%- while col_count < question_grid_with_total.num_cols do
|
37
|
+
col_count += 1-%>
|
38
|
+
<td> </td>
|
39
|
+
<%- end unless col_count == 0-%>
|
40
|
+
</tr>
|
41
|
+
<%- if question_grid_with_total.total_cols.present? -%>
|
42
|
+
<tr class="total">
|
43
|
+
<td>Total</td>
|
44
|
+
<%- total_cols = question_grid_with_total.total_cols.split(",").collect(&:to_i)
|
45
|
+
(question_grid_with_total.num_cols - 1).times do |i|
|
46
|
+
ci = i + 2
|
47
|
+
if total_cols.include?(ci) -%>
|
48
|
+
<td>
|
49
|
+
<%= text_field_tag "total_#{question_grid_with_total.id}_#{i + 1}", "", class: "text validate-number", readonly: true %>
|
50
|
+
<script>
|
51
|
+
$("#<%= "total_#{question_grid_with_total.id}_#{i + 1}" %>").closest("table").find("td:nth-child(<%= ci %>)").change(function() {
|
52
|
+
updateTotal("<%= question_grid_with_total.id %>_<%= i+1 %>");
|
53
|
+
});
|
54
|
+
</script>
|
55
|
+
</td>
|
56
|
+
<% else %>
|
57
|
+
<td> </td>
|
58
|
+
<% end %>
|
59
|
+
<%- end -%>
|
60
|
+
</tr>
|
61
|
+
<%- end -%>
|
62
|
+
</table>
|
63
|
+
<%- end -%>
|
64
|
+
|
@@ -0,0 +1,15 @@
|
|
1
|
+
<ul>
|
2
|
+
<% questions.each do |question| %>
|
3
|
+
<li class="new-dialog-<%= dom_id(question) %>">
|
4
|
+
<% unless Fe.never_reuse_elements %>
|
5
|
+
<%= link_to(use_existing_fe_admin_question_sheet_page_element_path(question_sheet_id: @page.question_sheet_id, page_id: @page.id, id: question.id), remote: true, method: :post, onClick: "$('li.new-dialog-#{dom_id(question)}').html('Inserting...')") do %>
|
6
|
+
<span>Insert</span><label>
|
7
|
+
<% end %>
|
8
|
+
<% end %>
|
9
|
+
<%= link_to(copy_existing_fe_admin_question_sheet_page_element_path(question_sheet_id: @page.question_sheet_id, page_id: @page.id, id: question.id), remote: true, method: :post, onClick: "$('li.new-dialog-#{dom_id(question)}').html('Copying... This can take a minute')") do %>
|
10
|
+
<span>Copy</span>
|
11
|
+
<% end %>
|
12
|
+
<label><%= raw question.label(session[:locale]) %></label>
|
13
|
+
</li>
|
14
|
+
<% end %>
|
15
|
+
</ul>
|
@@ -0,0 +1,60 @@
|
|
1
|
+
<% choices = radio_button_field.choices(session[:locale]) %>
|
2
|
+
<% css_class = "radio " -%>
|
3
|
+
<% css_class += "required" if radio_button_field.required?(@answer_sheet, @page) %>
|
4
|
+
<% if radio_button_field.hide_option_labels? && !["question_pages", "question_sheets", "elements"].include?(controller.controller_name) %>
|
5
|
+
<tr id="<%= dom_id(radio_button_field) %>">
|
6
|
+
<td class="col1">
|
7
|
+
<label for="<%= dom_id(radio_button_field) %>" class="desc">
|
8
|
+
<%= raw radio_button_field.label(session[:locale]) %>
|
9
|
+
<% if radio_button_field.required?(@answer_sheet, @page) -%><span class="required">required</span><% end -%>
|
10
|
+
<%= tip(radio_button_field.tooltip) if radio_button_field.tooltip.present? %>
|
11
|
+
</label>
|
12
|
+
</td>
|
13
|
+
<% choices.each_with_index do |choice, num| -%>
|
14
|
+
<td class="col">
|
15
|
+
<% dom_id = dom_id(radio_button_field) + "_" + pretty_tag(choice[1])
|
16
|
+
last_choice = (num == choices.length - 1)
|
17
|
+
css_class += radio_button_field.validation_class(@answer_sheet, @page) if last_choice
|
18
|
+
checked = radio_button_field.has_answer?(choice[1], @answer_sheet)
|
19
|
+
locked = radio_button_field.locked?(params, @answer_sheet, @presenter, current_person)
|
20
|
+
%>
|
21
|
+
<%= radio_button_tag "answers[#{radio_button_field.id}]", choice[1], checked,
|
22
|
+
id: dom_id,
|
23
|
+
class: css_class,
|
24
|
+
disabled: locked,
|
25
|
+
readonly: locked %>
|
26
|
+
</td>
|
27
|
+
<% end -%>
|
28
|
+
</tr>
|
29
|
+
<% else %>
|
30
|
+
<div id="<%= dom_id(radio_button_field) %>">
|
31
|
+
<% choices.each_with_index do |choice, num| -%>
|
32
|
+
<% dom_id = dom_id(radio_button_field) + "_" + pretty_tag(choice[1])
|
33
|
+
last_choice = (num == choices.length - 1)
|
34
|
+
css_class += radio_button_field.validation_class(@answer_sheet, @page) if last_choice
|
35
|
+
checked = radio_button_field.has_answer?(choice[1], @answer_sheet)
|
36
|
+
locked = radio_button_field.locked?(params, @answer_sheet, @presenter, current_person)
|
37
|
+
%>
|
38
|
+
<% if Fe.bootstrap %>
|
39
|
+
<div class="radio <%= "disabled" if locked %> radio-set">
|
40
|
+
<label class="choice" for="<%= dom_id %>">
|
41
|
+
<%= radio_button_tag "answers[#{radio_button_field.id}]", choice[1], checked,
|
42
|
+
id: dom_id,
|
43
|
+
class: css_class,
|
44
|
+
disabled: locked,
|
45
|
+
readonly: locked %>
|
46
|
+
<%= choice[0] %>
|
47
|
+
</label>
|
48
|
+
<% else %>
|
49
|
+
<div class="radio-set">
|
50
|
+
<%= radio_button_tag "answers[#{radio_button_field.id}]", choice[1], checked,
|
51
|
+
id: dom_id,
|
52
|
+
class: css_class,
|
53
|
+
disabled: locked,
|
54
|
+
readonly: locked %>
|
55
|
+
<label class="choice" for="<%= dom_id %>"><%= choice[0] %></label>
|
56
|
+
</div>
|
57
|
+
<% end %>
|
58
|
+
<% end -%>
|
59
|
+
</div>
|
60
|
+
<% end %>
|
@@ -0,0 +1,64 @@
|
|
1
|
+
<% choices = rating.choices(session[:locale]) %>
|
2
|
+
<% dom_id = "" %>
|
3
|
+
<% locked = rating.locked?(params, @answer_sheet, @presenter, current_person) %>
|
4
|
+
<div id="<%= dom_id(rating) %>">
|
5
|
+
<table cellspacing="0" class="rating">
|
6
|
+
<tr>
|
7
|
+
<% if rating.rating_before_label.present? %>
|
8
|
+
<td class="rating_before">
|
9
|
+
<% first_dom = dom_id(rating) + "_" + pretty_tag(choices.first[1]) %>
|
10
|
+
<label class="no_label_styles" for="<%= first_dom %>">
|
11
|
+
<%= rating.rating_before_label(session[:locale]) %>
|
12
|
+
</label>
|
13
|
+
</td>
|
14
|
+
<% end %>
|
15
|
+
<% css_class = " " %>
|
16
|
+
<% choices.each_with_index do |choice, num| %>
|
17
|
+
<% dom_id = dom_id(rating) + "_" + pretty_tag(choice[1])
|
18
|
+
last_choice = (num == choices.length - 1)
|
19
|
+
css_class += rating.validation_class(@answer_sheet, @page) if last_choice
|
20
|
+
checked = rating.has_answer?(choice[1],@answer_sheet) %>
|
21
|
+
<td class="rating_choice"><%= radio_button_tag "answers[#{rating.id}]", choice[1], checked,
|
22
|
+
id: dom_id,
|
23
|
+
class: css_class,
|
24
|
+
disabled: locked,
|
25
|
+
readonly: locked %></td>
|
26
|
+
<% end %>
|
27
|
+
<% if rating.rating_after_label.present? %>
|
28
|
+
<td class="rating_after">
|
29
|
+
<% last_dom = dom_id(rating) + "_" + pretty_tag(choices.last[1]) %>
|
30
|
+
<label class="no_label_styles" for="<%= last_dom %>">
|
31
|
+
<%= rating.rating_after_label(session[:locale]) %>
|
32
|
+
</label>
|
33
|
+
</td>
|
34
|
+
<% end %>
|
35
|
+
<% if rating.rating_na_label.present? %>
|
36
|
+
<% choice = "na"
|
37
|
+
dom_id = dom_id(rating) + "_" + pretty_tag(choice)
|
38
|
+
checked = rating.has_answer?(choice, @answer_sheet) %>
|
39
|
+
<td class="rating_na">
|
40
|
+
<%= radio_button_tag "answers[#{rating.id}]", "na", checked,
|
41
|
+
id: dom_id,
|
42
|
+
class: "",
|
43
|
+
disabled: locked,
|
44
|
+
readonly: locked %>
|
45
|
+
</td>
|
46
|
+
<td class="rating_na_label">
|
47
|
+
<label class="no_label_styles" for="<%= dom_id %>">
|
48
|
+
<%= rating.rating_na_label(session[:locale]) %>
|
49
|
+
</label>
|
50
|
+
</td>
|
51
|
+
<% end %>
|
52
|
+
</tr>
|
53
|
+
<% unless rating.hide_option_labels %>
|
54
|
+
<tr>
|
55
|
+
<% if rating.rating_before_label.present? %><td></td><% end %>
|
56
|
+
<% choices.each do |choice| %>
|
57
|
+
<td class="rating_choice"><%= choice[0].html_safe %></td>
|
58
|
+
<% end %>
|
59
|
+
<% if rating.rating_after_label.present? %><td></td><% end %>
|
60
|
+
</tr>
|
61
|
+
<% end %>
|
62
|
+
</table>
|
63
|
+
<div id="advice-validate-rating-<%= dom_id %>" class="validation-advice" style="display: none;"><%= _("Please select one of the above options.") %></div>
|
64
|
+
</div>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render "fe/questions/fe/reference_question", reference_question: reference_discipler, title: _("Discipler Reference") %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render "fe/questions/fe/reference_question", reference_question: reference_friend, title: _("Friend Reference") %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render "fe/questions/fe/reference_question", reference_question: reference_parent, title: _("Parent Reference") %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render "fe/questions/fe/reference_question", reference_question: reference_peer, title: _("Peer Reference") %>
|
@@ -0,0 +1,61 @@
|
|
1
|
+
<% reference = reference_question.response(@answer_sheet) %>
|
2
|
+
<% reference ||= Fe::ReferenceSheet.new %>
|
3
|
+
<% css_class = reference_question.required?(@answer_sheet, @page) ? "required" : "" %>
|
4
|
+
<% email_css_class = reference_question.required?(@answer_sheet, @page) ? "required email email" : "" %>
|
5
|
+
<% phone_css_class = reference_question.required?(@answer_sheet, @page) ? "required phone phone" : "" %>
|
6
|
+
<%#= hidden_field_tag "reference[#{reference.id}]", class: reference_question.required? && !reference.email_sent? ? "required" : "" %>
|
7
|
+
<div id="<%= dom_id(reference_question) %>" class="reference_question">
|
8
|
+
<ul class="questions level1">
|
9
|
+
<li>
|
10
|
+
<label for="<%= "name_#{reference.id}" %>" class="desc"><%= _("First Name") %></label>
|
11
|
+
<%= text_field_tag "reference[#{reference.id}][first_name]", reference.first_name, class: "#{"form-control" if Fe.bootstrap} text #{css_class}", id: "name_#{reference.id}", readonly: reference.completed? || !@answer_sheet.try(:can_change_references?), disabled: reference.completed? || !@answer_sheet.try(:can_change_references?) %>
|
12
|
+
</li>
|
13
|
+
<li>
|
14
|
+
<label for="<%= "name_#{reference.id}" %>" class="desc"><%= _("Last Name") %> </label>
|
15
|
+
<%= text_field_tag "reference[#{reference.id}][last_name]", reference.last_name, class: "#{"form-control" if Fe.bootstrap} text #{css_class}", id: "name_#{reference.id}", readonly: reference.completed? || !@answer_sheet.try(:can_change_references?), disabled: reference.completed? || !@answer_sheet.try(:can_change_references?) %>
|
16
|
+
</li>
|
17
|
+
<li>
|
18
|
+
<label for="<%= "name_#{reference.id}" %>" class="desc"><%= _("Relationship to You") %></label>
|
19
|
+
<%= text_field_tag "reference[#{reference.id}][relationship]", reference.relationship, class: "#{"form-control" if Fe.bootstrap} text #{css_class}", id: "name_#{reference.id}", readonly: reference.completed? || !@answer_sheet.try(:can_change_references?), disabled: reference.completed? || !@answer_sheet.try(:can_change_references?) %>
|
20
|
+
</li>
|
21
|
+
<li>
|
22
|
+
<label for="<%= "email_#{reference.id}" %>" class="desc"><%= _("E-mail") %></label>
|
23
|
+
<% if (!reference.email.blank?) %>
|
24
|
+
<div class="warningText">
|
25
|
+
<%= _("Please be aware that any changes to this email address after your reference has started filling out their form will cause their answers to be lost.") %>
|
26
|
+
</div>
|
27
|
+
<% end %>
|
28
|
+
<%= text_field_tag "reference[#{reference.id}][email]", reference.email, class: "#{"form-control" if Fe.bootstrap} text #{email_css_class}", id: "email_#{reference.id}", readonly: reference.completed? || !@answer_sheet.try(:can_change_references?), disabled: reference.completed? || !@answer_sheet.try(:can_change_references?) %>
|
29
|
+
</li>
|
30
|
+
<li>
|
31
|
+
<label for="<%= "phone_#{reference.id}" %>" class="desc"><%= _("Phone") %></label>
|
32
|
+
<%= text_field_tag "reference[#{reference.id}][phone]", reference.phone, class: "#{"form-control" if Fe.bootstrap} text #{phone_css_class}", id: "phone_#{reference.id}", readonly: reference.completed? || !@answer_sheet.try(:can_change_references?), disabled: reference.completed? || !@answer_sheet.try(:can_change_references?) %>
|
33
|
+
</li>
|
34
|
+
<li>
|
35
|
+
<% if reference.completed? %>
|
36
|
+
<p><strong><%= _("This reference is completed") %></strong></p>
|
37
|
+
<% else %>
|
38
|
+
<p>
|
39
|
+
<%= _("An invitation will be sent to this reference when you submit your application. If you would " \
|
40
|
+
"like to get a head start, please feel free to click "Send Email Invitation" below.") %><br/>
|
41
|
+
<em><strong>
|
42
|
+
<%= _("If you already submitted your application and have returned to update your reference information - you must click "Send Email Invitation" after you " \
|
43
|
+
"have edited the information in order for your reference to receive another email.") %>
|
44
|
+
</strong></em></p></li>
|
45
|
+
|
46
|
+
<li><%= link_to(_("Send Email Invitation"), @answer_sheet ? send_reference_invite_fe_answer_sheet_path(@answer_sheet, reference_id: reference.id) : "#", class: "#{"form-control" if Fe.bootstrap} reference_send_invite button no-left-margin", disabled: !reference.all_affecting_questions_answered) %>
|
47
|
+
<% if reference.question && !reference.all_affecting_questions_answered %>
|
48
|
+
<div>
|
49
|
+
<strong><i>This button is disabled because there are questions that affect whether this reference is required that need to answered first:</i></strong>
|
50
|
+
<ul>
|
51
|
+
<% reference.question.visibility_affecting_questions.each do |q| %>
|
52
|
+
<% next if q.has_response?(@answer_sheet) %>
|
53
|
+
<li>"<%= q.pages.where(question_sheet_id: @answer_sheet.question_sheet_ids).first.label %>" Page: "<%= q.label %>"</li>
|
54
|
+
<% end %>
|
55
|
+
</ul>
|
56
|
+
</div>
|
57
|
+
<% end %>
|
58
|
+
<br/><%= _("Invitation last sent:") %> <span id="ref_last_sent_<%= reference.id %>"><% if reference.email_sent_at.nil? -%><%= _("Never") %><% else %><%= reference.email_sent_at.strftime("%Y-%m-%d @ %I:%M%p") %><% end %></span></li>
|
59
|
+
<% end %>
|
60
|
+
</ul>
|
61
|
+
</div>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render "fe/questions/fe/reference_question", reference_question: reference_roommate, title: _("Roommate Reference") %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render "fe/questions/fe/reference_question", reference_question: reference_spiritual, title: _("Spiritual Reference") %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render "fe/questions/fe/reference_question", reference_question: reference_staff, title: _("Staff Reference") %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<h4><%= raw section.label(session[:locale]) %></h4>
|